我正在为我们的组织规划Active Directory安装的布局.我正在研究使用组策略来强制执行特定设置,增强桌面和服务器的安全性,并从我们的标准计算机映像中提供更一致的用户体验.我们将在我们的环境中混合使用 Windows XP,Windows 7 Pro,Windows Server 2003,Windows Server 2008 R2 Standard,Macintosh OS X(10.6)以及各种 Linux(CentOS和Ubuntu)服务器.

>我正在寻找想法,提示,建议,甚至资源,以确定适用于这些不同机器的组策略的适当方法和适当的布局.
>您在实施组策略时学到了什么?
>你会改变什么?
>您是如何设计它与客户端和服务器一起工作的?
>您是如何处理或适应各种操作系统的?
>人们应该遵循普遍接受的群体政策设计吗?
>嵌套策略以创建类似模型的分层树是一个好主意吗?
>环回处理是一个好主意吗?
>对于与策略结构设计相关的客户端计算机登录减速是否有任何问题?
>由于有Windows XP和Windows 7计算机,ADM文件和ADMX文件之间有区别吗?我如何知道何时使用其中一个?它甚至重要吗?
>有人告诉我,我应该考虑在组策略对象中禁用用户配置设置或禁用计算机配置设置选项.这是一件聪明的事吗?这是否重要?

我们将非常感谢您提供的任何帮助和想法.我有兴趣向您和您的经验学习,以帮助我们的移民取得成功 – 特别是我们不必一年后重新设计并重新设计一切.

背景:

自2000年中期我开始部署Windows 2000 Server和Windows 2000 Professional客户端以来,我一直在我的客户站点中大量使用组策略.与其他Samba和其他与Windows客户端操作系统兼容的单点登录机制相比,组策略是Windows Server / Active Directory平台最引人注目的功能之一.

您在实施组策略时学到了什么?

>异步策略处理提供非确定性体验.默认情况下,它在Windows 2000 Processional中关闭,但在Windows客户端操作系统的所有更高版本中默认打开.我强烈建议强制该过程恢复同步以提供确定性体验.
>了解如何选择GPOs中的设置并将其应用于计算机和用户,具有极大的价值.该算法非常简单(“块继承”和“无覆盖”只会使算法稍微复杂化).大多数策略应用程序问题最终都是系统管理员对用于应用组策略的算法的理解与操作系统实际执行的操作之间的不匹配.依靠RSoP或GPRESULT等工具而不是对功能如何工作有充分的了解是一个坏主意.
>不要忘记网站级别的GPO链接.它们可以非常非常方便.当便携式计算机在站点之间移动时,请注意可能导致重大事件发生的设置(如在计算机“超出范围”时强制删除的软件安装).
>在部署到生产之前,在实验室OU和测试计算机上进行计划和测试 – 尤其是使用软件安装功能.测试,测试,然后再次测试.如果您犯了错误,组策略可以让您非常轻松地破坏数百或数千台计算机的配置.
>不要将组策略看作是为安全做任何事情本身.组策略可以帮助实现“纵深防御”策略(启用AppLocker等功能,强制执行组成员身份等),但如果有人在计算机上获得“管理员”权限,那么他们很容易“杀掉”组该机器的政策.
>确保您了解“阻止继承”,“无覆盖”以及WMI和安全组筛选的工作原理.这些功能可以让您管理简单地链接OU无法处理的GPO的方案.尽量不要过度使用这些功能,因为它们可能在几个月之后不直观地进行逆向工程,或者让其他系统管理员无法理解.
>在进行更改之前备份关键GPO. GPMC工具添加了此功能,非常非常方便.您应该正在进行AD的系统状态备份,但使用GPMC从备份还原单个GPO比系统状态还原更容易.
>我经常利用作为“陷阱门”的脚本.客户端可以应用脚本,只要它们不是给定组的成员即可.脚本的最后一行将客户端放入该组,以便在下次引导时客户端不再执行该脚本.这是非常方便的行为.

你会改变什么?

不多.我有各种不同的客户,我的组策略应用程序“样式”有各种不同的“修订版”.我本不会“做任何不同的事情”本身,但我确实努力将所有事情归一化为一个非常相似的配置.对我而言,这只是调整GPO“风格”的问题,而不是做出任何广泛而彻底的改变.主要是我必须做出的改变是因为在投入生产之前没有进行足够的测试.我提到你应该尽早测试吗?

您是如何设计它以与客户端和服务器一起使用的?

就像我将不同类别的用户或客户端计算机隔离开来一样.我将客户端计算机和服务器计算机隔离到不同的OU中,并将不同的GPO链接到这些OU.可以进一步隔离不同角色的服务器(或将其放入安全组并过滤GPO应用程序).我有适用于这两种类型计算机的通用GPO(通常只有少数几个设置).

您是如何处理或适应各种操作系统的?

WMI筛选是处理各种Windows版本的一种方法.它工作正常,但我个人不喜欢它.

我通常部署一个启动脚本(我写在客户的时间,不幸的是,所以我不能在这里分享它)来检测Windows版本的组策略客户端(以及他们的32/64位和以及是否它们是裸机或在给定的虚拟机管理程序上运行)来填充组,以便我可以使用安全组过滤而不是WMI过滤.因为WMI过滤仅对GPO是原子的,而我可以在GPO中的单个软件安装中使用安全组过滤,所以我更喜欢安全组过滤.

我没有使用客户端软件的经验,允许非Windows客户端使用组策略,所以我根本不能说.

是否应该遵循普遍接受的群体政策设计?

我来自“老学校”,所以我学会了基于recommendations made by Microsoft “back in the day”设计Active Directory.当我布局我的OU结构时,我非常重视组策略(以及控制委派,这是我的第一个关注点:OU结构).

就个人而言,我更喜欢尽可能少的GPO来完成工作,而无需在多个GPO中重复常见设置.我尽可能限制使用“块继承”,“无覆盖”和安全组过滤(特别是“拒绝”权限).我试着详细命名GPO,以便它们“自我记录”.我从不修改使用Active Directory“开箱即用”的默认GPO,这样我就可以在“紧急”情况下禁用所有其他GPO并将产品恢复为“库存”行为.

嵌套策略以创建类似模型的分层树是一个好主意吗?

这是我的总体战略,对我来说效果很好.我可以在多个位置链接相同的GPO(例如,名为“成员服务器和域控制器计算机的通用设置”的GPO,它们链接在“成员服务器”OU和默认的“域控制器”OU).然后,当我向下移动到OU层次结构时,我会链接具有更多特定设置的addt’l GPO.链接“愚蠢”数量的GPO(数十或数百)会影响性能.我有客户的客户链接7 – 12 GPO没有不良的性能影响.

对于与策略结构设计相关的客户端计算机的登录减速是否有任何问题?

某些组策略客户端扩展(CSE)模块可能很慢.在某些情况下(如文件夹重定向或软件安装策略),它可能只是一次性减速.在其他情况下(如Windows XP SP3中的IE策略),它可以为每次登录添加几秒钟.一般来说,尽量保守,并根据需要链接少量GPO.根据需要运行尽可能少的脚本(如果您同步处理它们,它们可以真正添加).测试登录时间应该是测试的一部分.

由于有Windows XP和Windows 7计算机,ADM文件和ADMX文件之间有区别吗?我如何知道何时使用其中一个?它甚至重要吗?

There is no difference in the REGISTRY.POL files由ADM文件与ADMX文件创建.如果您要从Windows 2003或Windows XP管理组策略,则需要保留ADM文件.如果您要将GPO管理限制为Windows Vista或更新的操作系统,则可以丢弃ADM文件.我个人并不担心,但是我最大的SYSVOL只有400MB左右.如果我有数百个GPO,那么我可能想尽快远离ADM文件.

环回处理是一个好主意吗?

如果您需要它提供的功能,那么这绝对是个好主意.有些情况下没有它就无法配置.如果你理解它是如何工作的,Loopback策略处理工作正常.它的用途非常有用(无论用户是否登录,都将一致的用户设置应用于计算机).

有人告诉我,我应该考虑在组策略对象中禁用用户配置设置或禁用计算机配置设置选项.这是一件聪明的事吗?这是否重要?

这与问题re:登录时间有关.您可以对它进行基准测试并在您的环境中查看,但坦白地说,我看到没有性能差异.我在客户网站上不担心.

windows-server-2008 – 组策略设计的更多相关文章

  1. css绝对定位如何在不同分辨率下的电脑正常显示定位位置?(一定要看!)

    这篇文章主要介绍了css绝对定位如何在不同分辨率下的电脑正常显示定位位置,本文首先解释了常见的电脑分辨率,为了页面在不同的分辨率下正常显示,要给页面一个安全宽度,再去使用绝对定位,具体操作步骤大家可查看下文的详细讲解,感兴趣的小伙伴们可以参考一下。

  2. ios – Xcode项目在文档大纲中显示为灰色

    我一直在使用iCloud来“同步”我正在从我的笔记本电脑到桌面的Xcode项目.不幸的是,它似乎没有那么好用.我今天在台式机上打开了一个项目,我昨天在笔记本电脑上工作.如果我在桌面上打开文件,则会丢失故事板中的某些按钮和标签.看看文档,我可以看到这些,但它们是灰色的(见图).但是,当我构建文件时,它们在模拟器中显示为正常.知道为什么或如何让它们正常出现?

  3. ios – Xcode 9.2模拟器调试中断;无法附加到进程ID

    iOS模拟器上的Xcode9.2调试对我来说已经彻底破坏了.我花了几个小时研究这个问题并尝试了大量的建议,但没有完全擦除我的硬盘并开始安装新的操作系统.我最终向Apple提交了一个错误.如果有人遇到此问题并有任何建议,请在此处发布.摘要:尝试使用调试可执行文件在调试模式下构建和运行时.模拟器只将应用程序打开到白色屏幕,然后Xcode弹出错误:重现步骤:制作任何项目并尝试在任何模拟器上运行.预期成绩

  4. 在Xcode服务器中找不到代码签名标识

    使用Xcode7B4和Server5B4与Carthage项目.要构建项目,我需要首先构建它的依赖项.所以我使用以下代码向bot添加了BeforeIntegration步骤:自己运行一切都有效.但是当机器人运行时,我得到了这个:CodeSignerror:Nocodesigningidentitiesfound:Novalidsigningidentities(i.e.certificateand

  5. 可可 – NSTimer中的代码可防止自动睡眠

    我在我的应用程序中运行了一个NSTimer,它收集一些数据并定期发送到服务器.在生产中,计时器将每隔几个小时发射一次.我担心干扰自动睡眠.在测试中,计时器和睡眠时间的某些组合完全阻止自动睡眠–显示器休眠,系统保持运行.将我的NSTimer设置为一分钟始终会停止它.一些Mac应用程序因运行时干扰自动睡眠而臭名昭着.什么操作会阻止系统进入睡眠状态?

  6. xcode – 今天OS X上的Widget无法正常工作

    解决方法好的终于找到了问题.我手工编写了我的应用程序,因为我有一个应用程序依赖的复杂框架,需要使用copy/Runscript后构建脚本手工复制它们.无论如何,它似乎至少从Xcode7开始,这不再像预期的那样工作.应用程序的工作原理和协同设计说应用程序已经正确签名,但很明显,幕后发生的事情正在打破代码签名.我最终删除了所有手动代码签名的东西,只需使用Xcode的“复制框架”构建后步骤并选中“登录复制”.它现在终于按预期工作了.

  7. 反应原生 – 如何通过Xcode构建React Native iOS应用程序到设备?

    我试图将AwesomeProject应用程序构建到设备上.构建成功并启动屏幕显示,但后来我看到一个红色的“无法连接到开发服务器”屏幕.它表示“确保节点服务器正在运行–从Reactroot运行”npmstart“.看起来节点服务器已经运行,因为当我做npm启动时,我收到一个EADDRINUSE消息,表示该端口已经在使用.解决方法从设备访问开发服务器您可以使用开发服务器快速迭代设备.要做到这一点,你的

  8. xcode – Mac OSX Lion / X11 / CImg库

    所以我试图将CImg图像编写库并入到我的XCodeproject中但是,库的头文件包含以下包含,XCode给出了此错误警告:我的笔记本电脑正在运行OSXLion10.8.2,显然,苹果拿走了X11的Lion,所以我去了thissite,下载了XQuartz,因为这是AppleSupportpage所说的.所以在安装之后,我重新启动了我的电脑,并尝试运行我的XCode项目,但我仍然得到相同的确切的错

  9. 调试 – iOS设备上的remote console.log()

    我正在开发涉及touchEvent的网络应用程序.如果我可以在我的Mac上远程查看控制台,那么调试它会更容易一些.我可以在iOS设备上使我的MobileSafari将控制台日志存储在系统中的某个位置.我已经越狱了我的iPad.谢谢!

  10. ios – 有没有办法加速iPad模拟器的OpenGL性能?

    iPad模拟器太慢,无法测试OpenGL图形.有没有办法让它更快?

随机推荐

  1. static – 在页面之间共享数据的最佳实践

    我想知道在UWP的页面之间发送像’selectedItem’等变量的最佳做法是什么?创建一个每个页面都知道的静态全局变量类是一个好主意吗?

  2. .net – 为Windows窗体控件提供百分比宽度/高度

    WindowsForm开发的新手,但在Web开发方面经验丰富.有没有办法为Windows窗体控件指定百分比宽度/高度,以便在用户调整窗口大小时扩展/缩小?当窗口调整大小时,可以编写代码来改变控件的宽度/高度,但我希望有更好的方法,比如在HTML/CSS中.在那儿?

  3. 使用Windows Azure查询表存储数据

    我需要使用特定帐户吗?>将应用程序部署到Azure服务后,如何查询数据?GoogleAppEngine有一个数据查看器/查询工具,Azure有类似的东西吗?>您可以看到的sqlExpressintance仅在开发结构中,并且一旦您表示没有等效,所以请小心使用它.>您可以尝试使用Linqpad查询表格.看看JamieThomson的thispost.

  4. windows – SetupDiGetClassDevs是否与文档中的设备实例ID一起使用?

    有没有更好的方法可以使用DBT_DEVICEARRIVAL事件中的数据获取设备的更多信息?您似乎必须指定DIGCF_ALLCLASSES标志以查找与给定设备实例ID匹配的所有类,或者指定ClassGuid并使用DIGCF_DEFAULT标志.这对我有用:带输出:

  5. Windows Live ID是OpenID提供商吗?

    不,WindowsLiveID不是OpenID提供商.他们使用专有协议.自从他们的“测试版”期结束以来,他们从未宣布计划继续它.

  6. 如果我在代码中进行了更改,是否需要重新安装Windows服务?

    我写了一个Windows服务并安装它.现在我对代码进行了一些更改并重新构建了解决方案.我还应该重新安装服务吗?不,只需停止它,替换文件,然后重新启动它.

  7. 带有双引号的字符串回显使用Windows批处理输出文件

    我正在尝试使用Windows批处理文件重写配置文件.我循环遍历文件的行并查找我想要用指定的新行替换的行.我有一个’函数’将行写入文件问题是%Text%是一个嵌入双引号的字符串.然后失败了.可能还有其他角色也会导致失败.如何才能使用配置文件中的所有文本?尝试将所有“在文本中替换为^”.^是转义字符,因此“将被视为常规字符你可以尝试以下方法:其他可能导致错误的字符是:

  8. .net – 将控制台应用程序转换为服务?

    我正在寻找不同的优势/劣势,将我们长期使用的控制台应用程序转换为Windows服务.我们为ActiveMQ使用了一个叫做java服务包装器的东西,我相信人们告诉我你可以用它包装任何东西.这并不是说你应该用它包装任何东西;我们遇到了这个问题.控制台应用程序是一个.NET控制台应用程序,默认情况下会将大量信息记录到控制台,尽管这是可配置的.任何推荐?我们应该在VisualStudio中将其重建为服务吗?我使用“-install”/“-uninstall”开关执行此操作.例如,seehere.

  9. windows – 捕获外部程序的STDOUT和STDERR *同时*它正在执行(Ruby)

    哦,我在Windows上:-(实际上,它比我想象的要简单,这看起来很完美:…是的,它适用于Windows!

  10. windows – 当我试图批量打印变量时,为什么我得到“Echo is on”

    我想要执行一个简单的批处理文件脚本:当我在XP中运行时,它给了我预期的输出,但是当我在Vista或Windows7中运行它时,我在尝试打印值时得到“EchoisOn”.以下是程序的输出:摆脱集合表达式中的空格.等号(=)的两侧可以并且应该没有空格BTW:我通常在@echo关闭的情况下启动所有批处理文件,并以@echo结束它们,所以我可以避免将代码与批处理文件的输出混合.它只是使您的批处理文件输出更好,更清洁.

返回
顶部