最近在研究将AD的数据如何快速筛选、查找、比较、分析。在AD里并不好操作,希望导入到SQL Server做统一查询,并且可以和其他系统WSUS、SCCM、SCOM、HR等关联。
1. 创建SQL连接器:
建立Linked Server:
1
2
3
EXEC sp_addlinkedserver 'ADSI', 'Active Directory Services 2.5',
'ADSDSOObject', 'adsdatasource'
GO
2. 添加权限:
因为查询的LDAP,需要用AD域账户进行认证
3. 通过SQL 语句查询AD信息:
1
2
3
4
5
6
SELECT * FROM OPENQUERY
(
ADSI,'SELECT cn
FROM ''LDAP://ServerName/DC=Contoso,DC=domain''
where objectClass = ''computer''
')
4. 创建查询视图
1
2
3
4
5
6
7
8
9
10
CREATE VIEW viewADContacts
AS
SELECT *
FROM OPENQUERY( ADSI,
'SELECT Name, SN, ST,CN
FROM ''LDAP://ServerName/DC=Contoso,DC=Domain''
WHERE objectCategory = ''Person'' AND
objectClass = ''user'' ')
GO
SELECT * FROM viewADContacts
PS:
因为LDAP限制返回的信息行数只有1000,当你的域信息大于1000时会非常麻烦。接下来分享如何通过NTDSUtil来修改默认值。
前提是你是域管理员,修改有风险,前请三思。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
# Run as Administrator进入命令行模式执行NTDSUTIL.exe
PS C:\Windows\system32> ntdsutil
# 输入LDAP Policies,进入LDAP策略设置模式
# 如果不知道如何输入,可以用?或help 查询帮忙
C:\Windows\system32\ntdsutil.exe: LDAP policies
# 设置连接服务器
ldap policy: connections
# 可以连接服务器,也可以连接域名
server connections: connect to domain Contoso.Domain
Binding to ...
Connected to credentials of locally logged on user.server
# 输入quit返回上一层
server connections: quit
# 使用Show values显示目前的设定值
ldap policy: show values
Policy Current(New)
MaxPoolThreads 4
MaxDatagramRecv 4096
MaxReceiveBuffer 10485760
InitRecvTimeout 120
MaxConnections 5000
MaxConnIdleTime 900
MaxPageSize 5000
MaxQueryDuration 120
MaxTempTableSize 10000
MaxResultSetSize 262144
MinResultSets 0
MaxResultSetsPerConn 0
MaxNotificationPerConn 5
MaxValRange 1500
# 使用set 修改MaxPageSize就是我们要扩充的对象
ldap policy: set MaxPageSize to 5000
# 使用commit changes提交变更
ldap policy: commit changes
# 修改完成quit返回退出
ldap policy: quit
C:\Windows\system32\ntdsutil.exe: quit
PS C:\Windows\system32>
再用SQL查询看看,不会再报错,也不会有1000条的限制啦。
运维网声明
1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网 享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com