如何基于 PowerShell 实现对于活动目录管理?

 我来答
惠企百科
2022-12-11 · 百度认证:北京惠企网络技术有限公司官方账号
惠企百科
惠企百科网是一家科普类综合网站,关注热门中文知识,集聚互联网精华中文知识,本着自由开放、分享价值的基本原则,向广大网友提供专业的中文知识平台。
向TA提问
展开全部
在 Windows Server 2000、2003 和2008 中,管理员使用各种命令行工具和管理控制台管理单元连接到其 Active Directory 域进行管理工作,通常我们习惯于使用MMC界面,但是很多高级管理操作只能在CMD下完成,而CMD下的命令经常成为我们的困惑。并且基于CMD的脚本的编写对于系统管理员要求很高。为了解决这种情况Windows Server 2008 R2 中的 Active Directory 模块合并了一组 cmdlet的Windows PowerShell 模块.通过使用这些cmdlet,可在单一的独立程序包中管理您的 Active Directory 域、Active Directory 轻型目录服务 (AD LDS) 配置集和 Active Directory 数据库装载工具实例。\x0d\x0a首先让我们了解一下PowerShell的功能,系统维护、管理中大家常在命令提示符(cmd.exe)下进行操作,对Windows PowerShell可能还是比较陌生。Windows PowerShell将成为CDM的继任者,是下一代命令行工具。Windows PowerShell目前最高版本为2.0,并且已经集成到Windows Server 2008及Windows 7中。Windows PowerShell使得IT管理员更容易地控制系统管理和加速自动化,作为系统管理员应该掌握和使用它。Windows PowerShell 是一种新的交互式的命令行和基于任务脚本编写技术,它使信息技术 (IT) 管理员能够全面地自动操作和控制系统管理任务,从而提高了管理员的生产力。Windows PowerShell 包括多个系统管理实用工具、一致的语法和命名惯例、及对普通管理数据更好地导航,如登记、证书存储 或 Windows Management Instrumentation (WMI)。Windows PowerShell 还专门针对 IT 管理,提供直观的脚本编写语言。之前的UNIX 的世界就有功能强大的 shell,而现在 Windows 环境也有了;Windows PowerShell 不仅提供功能相当于BASH的命令列 shell,同时也内建脚本语言以及辅助脚本程序的工具。Windows PowerShell 是以 .NET 技术为基础,并且与现有的 WSH 保持回溯兼容,因此 Windows PowerShell 的脚本程序不仅能存取 .NET CLR,也能使用现有的 COM 技术。PowerShell有一个非常好的特点,那就是它有一个非常全面的帮助系统,并与Shell本身紧密集成。现在仅仅知道了cmdlet的名字,就可以通过调用Get-Help来获取其他有关这个cmdlet的信息例如:Get-Help Get-Command。然而,这些信息主要是一个语法图和一些简单描述。如果希望获取到更多的信息,包括了例子和参数的详细描述等信息,就需要加入-full参数,例如:Get-Help Get-Command _Full。对例子感兴趣,那么就加入-examples参数,例如Get-Help Get-command _examples。最让人高兴的是可以使用管道技术将Get-Help定向输出到more命令中,它允许你每次显示一个屏幕的内容,例如Get-Help Get-Command _full | more。Windows PowerShell 包含了数种系统管理工具、简易且一致的语法,提升管理者处理常见如登录数据库、WMI。Exchange Server 2007 以及 System Center Operations Manager 2007 等服务器软件都将内建 Windows PowerShell。PowerShell现在配备了Active Directory域服务(AD DS)模块,包含了超过75个Active Directory cmdlets。并且可以使用全新的PowerShell脚本,在Technet网站上提供了大量的脚本资源,现在可以通过脚本和PoweShell图形界面实现对于活动目录的管理。最让人感到惊喜的是tab-completion--按Tab键自动补齐功能,在用户敲击Tab键时,Windows会根据用户当时的情况,自动补齐下一步要输入的字符。这样将大大简化管理员的工作并且降低使用CMD时命令容易拼写错误的问题。\x0d\x0a下面是列举的常用命令:\x0d\x0aDisable-ADAccount 禁用 Active Directory 帐户。\x0d\x0aEnable-ADAccount 启用 Active Directory 帐户。\x0d\x0aUnlock-ADAccount 解锁 Active Directory 帐户。\x0d\x0aGet-ADAccountAuthorizationGroup 获取包含帐户的 Active Directory 安全组。\x0d\x0aSet-ADAccountExpiration 设置 Active Directory 帐户的截止日期。\x0d\x0aSet-ADAccountPassword 修改 Active Directory 帐户的密码。\x0d\x0aSet-ADDefaultDomainPasswordPolicy 修改 Active Directory 域的默认密码策略。\x0d\x0aMove-ADDirectoryServerOperationMasterRole 将操作主机(也称为灵活单主机操作或 FSMO)角色移动到 Active Directory 域控制器。\x0d\x0aGet-ADDomain 获取 Active Directory 域。\x0d\x0aAdd-ADDomainControllerPasswordReplicationPolicy 将用户、计算机和组添加至只读域控制器 (RODC) 密码复制策略 (PRP) 的允许列表或拒绝列表。\x0d\x0aSet-ADDomainMode 设置 Active Directory 域的域功能级别。\x0d\x0aSet-ADForestMode 设置 Active Directory 林的林模式。\x0d\x0aGet-ADGroup 获取一个或多个 Active Directory 组。\x0d\x0aNew-ADGroup 创建 Active Directory 组。\x0d\x0aRemove-ADGroup 删除 Active Directory 组。\x0d\x0aSet-ADGroup 修改 Active Directory 组。\x0d\x0aAdd-ADGroupMember 向 Active Directory 组添加一个或多个成员。\x0d\x0aGet-ADGroupMember 获取 Active Directory 组的成员。\x0d\x0aRemove-ADGroupMember 从 Active Directory 组删除一个或多个成员。\x0d\x0aGet-ADObject 获取一个或多个 Active Directory 对象。\x0d\x0aMove-ADObject 将 Active Directory 对象或对象容器移动至不同的容器或域。\x0d\x0aNew-ADObject 创建 Active Directory 对象。\x0d\x0aRemove-ADObject 删除 Active Directory 对象。\x0d\x0aRename-ADObject 更改 Active Directory 对象的名称。\x0d\x0aRestore-ADObject 还原 Active Directory 对象。\x0d\x0aSet-ADObject 修改 Active Directory 对象。\x0d\x0aGet-ADOptionalFeature 获取一个或多个 Active Directory 可选功能。\x0d\x0aGet-ADOrganizationalUnit 获取一个或多个 Active Directory OU。\x0d\x0aNew-ADOrganizationalUnit 新建 Active Directory OU。\x0d\x0aRemove-ADOrganizationalUnit 删除 Active Directory OU。\x0d\x0aSet-ADOrganizationalUnit 修改 Active Directory OU。\x0d\x0aAdd-ADPrincipalGroupMembership 将成员添加至一个或多个 Active Directory 组。\x0d\x0aGet-ADPrincipalGroupMembership 获取拥有指定用户、计算机或组的 Active Directory 组。\x0d\x0aRemove-ADPrincipalGroupMembership 将成员从一个或多个 Active Directory 组中删除。\x0d\x0aNew-ADServiceAccount 新建 Active Directory 服务帐户。\x0d\x0aRemove-ADServiceAccount 删除 Active Directory 服务帐户。\x0d\x0aSet-ADServiceAccount 修改 Active Directory 服务帐户。\x0d\x0aGet-ADUser 获取一个或多个 Active Directory 用户。\x0d\x0aNew-ADUser 新建 Active Directory 用户。\x0d\x0aRemove-ADUser 删除 Active Directory 用户。\x0d\x0aSet-ADUser 修改 Active Directory 用户。\x0d\x0a\x0d\x0a1、要增加Active Directory域服务模块,使用“Add-Module ActiveDirectory”命令,然后“Get-Module”;\x0d\x0a2、要得到Contoso.com域的信息, Get-ADDomain “Contoso.com”;\x0d\x0a3、要显示域控制器的具体信息, Get-ADDomainController _Discover(参数);\x0d\x0a4、要在Contoso.com域下的下建立Guangzhou组织单元,\x0d\x0aNew-ADOrganizationalUnit -Name "guangzhou" -Path "DC=Contoso,DC=com"\x0d\x0a5、将新的提供程序驱动器连接到 Active Directory 域、AD LDS 服务器或 Active Directory 数据库装载工具实例,\x0d\x0aNew-PSDrive -Name -PSProvider ActiveDirectory -Root "" _Server -Credential \\x0d\x0a参数描述\x0d\x0a-Name 指定要添加的驱动器的名称。\x0d\x0a-PSProvider ActiveDirectory 提供程序的名称,在本例中为 ActiveDirectory。\x0d\x0a-Root "" 指定提供程序的内部根目录或路径。\x0d\x0a_Server 指定托管您的 Active Directory 域或 AD LDS 实例的服务器。\x0d\x0a-Credential \ 指定连接到 Active Directory 域 AD LDS 服务器必须拥有的凭据。\x0d\x0a\x0d\x0a虽然PoweShell对于很多人比较陌生,但是只要使用 Get-Help -Detailed\x0d\x0a和Get-Help -Full,其中 是要研究的cmdlet 的名称。就可以获取详细的信息,这样更加便于我们尽快掌握PowerShell的使用。希望大家可以通过新的PowerShell更加有效的管理活动目录。
光点科技
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件... 点击进入详情页
本回答由光点科技提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式