当前位置: 首页 > news >正文

用mac做网站经营管理培训课程

用mac做网站,经营管理培训课程,建造师报名时间2023年官网,wordpress 更新过慢将AD的ou同步到openldap(可支持全量同步和增量同步) 整体思路如下: 从ad导出所有的数据,然后进行参数替换以及处理,处理后的文件称为A;从openldap导出所有的数据,然后进行参数替换以及处理&am…

将AD的ou同步到openldap(可支持全量同步和增量同步)

整体思路如下:

  • 从ad导出所有的数据,然后进行参数替换以及处理,处理后的文件称为A;
  • 从openldap导出所有的数据,然后进行参数替换以及处理,处理后的文件称为B;
  • 利用A,B进行全文对比,然后将差集和增量进行添加或删除(需要注意的是,这里的需求是openldap的数据完全跟AD保持一致,即便openldap有比ad多出的数据,也会被删除掉,除非不在 同步的ou下(即修改下面的 LDAP_BASE_DN))
#!/bin/bash
# 预定义参数
AD_DOMAIN="<Your AD's domain>"
AD_ADMIN_DN="CN=<Admin account name>,OU=XXX,OU=XXX,DC=XXX,DC=XXX,DC=XXX"
AD_ADMIN_PWD="<Your admin password>"
AD_BASE_DN="DC=XXX,DC=XXX,DC=XXX"
LDAP_DOMAIN="<Your OpenLDAP's domain>"
LDAP_ADMIN_DN="cn=Manager,dc=XXX,dc=XXX,dc=XXX"
LDAP_ADMIN_PWD="<Your admin password>"
LDAP_BASE_DN="OU=xxx,DC=xxx,DC=xxx"# 先从AD上获取OU组织信息,并保存成ldif文件
/opt/bitnami/openldap/bin/ldapsearch -x -H ldap://${AD_DOMAIN} "(&(objectClass=top)(objectClass=organizationalUnit))" dn objectClass ou -D "${AD_ADMIN_DN}" -w "${AD_ADMIN_PWD}" -b "${AD_BASE_DN}" -L | perl -MMIME::Base64 -MEncode=decode -n -00 -e 's/\n +//g;s/(?<=:: )(\S+)/decode("UTF-8",decode_base64($1))/eg;print' > /opt/tmp_query_adgroup.ldif# 全文将 ad的域(dc=aaa,dc=com) 替换为openldap的域(dc=bbb,dc=net)
sed -i 's#DC=aaa,DC=com#DC=bbb,DC=net#g' /opt/tmp_query_adgroup.ldif
# 全文将 :: 替换为 :
sed -i 's#::#:#g' /opt/tmp_query_adgroup.ldif
# 去掉以#开头的行
sed '/^#/d' /opt/tmp_query_adgroup.ldif > /opt/tmp_handle_adgroup.ldif# 读取OPENLDAP上所有的ou
/opt/bitnami/openldap/bin/ldapsearch -x -H ldap://${LDAP_DOMAIN} "(&(objectClass=top)(objectClass=organizationalUnit))" dn objectClass ou -D "${LDAP_ADMIN_DN}" -w "${LDAP_ADMIN_PWD}" -b "${LDAP_BASE_DN}" -L | perl -MMIME::Base64 -MEncode=decode -n -00 -e 's/\n +//g;s/(?<=:: )(\S+)/decode("UTF-8",decode_base64($1))/eg;print' > /opt/tmp_query_opgroup.ldif
# 全文将 :: 替换为 :
sed -i 's#::#:#g' /opt/tmp_query_opgroup.ldif
sed '/^#/d' /opt/tmp_query_opgroup.ldif > /opt/tmp_handle_opgroup.ldif
# 将dc,ou大写
sed -i 's#dc=#DC=#g' /opt/tmp_handle_opgroup.ldif
sed -i 's#ou=#OU=#g' /opt/tmp_handle_opgroup.ldif#==========================================================全文比对==========================================================#openldap比ad多出来的ou
grep -vxFf /opt/tmp_handle_adgroup.ldif /opt/tmp_handle_opgroup.ldif > /opt/tmp_del_group.ldif
sed -i "/^ou:/d" /opt/tmp_del_group.ldif
# 去掉dn
sed -i "s#dn: ##g" /opt/tmp_del_group.ldif# opldap比ad少的ou
grep -vxFf /opt/tmp_handle_opgroup.ldif /opt/tmp_handle_adgroup.ldif > /opt/tmp_add_group.ldif
# 首次全量添加的时候,不需要添加top、organizationalUnit 属性
if ! grep -q "objectClass: top"  /opt/tmp_add_group.ldif ; then# 只保留dn(因为dn是唯一的)sed -i "/^ou:/d" /opt/tmp_add_group.ldifwhile read LINE; do# 如果dn中包含 / 字符,则进行转义if [[ "$LINE" == *"/"* ]]; thenLINE="${LINE//\//\\/}"fitmp_ou=$(echo $LINE | grep -o 'OU=[^,]*' | head -n 1)sed -i "s#^OU=#OU: #g" /opt/tmp_add_group.ldifsed -i "/$LINE/a"$tmp_ou /opt/tmp_add_group.ldifdone < /opt/tmp_add_group.ldifsed -i "/^OU:/i\objectClass: top" /opt/tmp_add_group.ldifsed -i "/^OU:/i\objectClass: organizationalUnit" /opt/tmp_add_group.ldif
fi
# changetype: add必须位于第二行,也就是dn下方
sed -i "/^dn:/a\changetype: add" /opt/tmp_add_group.ldif# 添加换行符
sed -i "/^OU:/a\\\n" /opt/tmp_add_group.ldif
sed -i "/^ou:/a\\\n" /opt/tmp_add_group.ldif#====================================对数据进行增加或者删除====================================# openldap添加缺少ad的ou
/opt/bitnami/openldap/bin/ldapmodify -x -H ldapi:/// -c -w "${LDAP_ADMIN_PWD}" -D "${LDAP_ADMIN_DN}" -f  /opt/tmp_add_group.ldif >& /opt/tmp_add_group_rec.log
# 防止第一次执行不成功(因为ou是无序的)
while read LINE; doif grep -q "ldap_add: No such object (32)" /opt/tmp_add_group_rec.log ; then/opt/bitnami/openldap/bin/ldapmodify -x -H ldapi:/// -c -w "${LDAP_ADMIN_PWD}" -D "${LDAP_ADMIN_DN}" -f  /opt/tmp_add_group.ldif >& /opt/tmp_add_group_rec.log$(sleep 1s)fi
done < /opt/tmp_add_group_rec.log# 最后一步执行 openldap删除多出来的ou
while read LINE; do/opt/bitnami/openldap/bin/ldapdelete  -x -H ldapi:/// -c -w "${LDAP_ADMIN_PWD}" -D "${LDAP_ADMIN_DN}" -r ${LINE} > /dev/null 2>&1
done < /opt/tmp_del_group.ldif
http://www.dt0577.cn/news/43681.html

相关文章:

  • 同人那个小说网站做的最好百度seo软件曝光行者seo
  • 网站建设汇编资料哪里有免费的网站推广
  • 做网站用香港服务器好吗免费网页制作模板
  • python在线编程游戏常用的seo网站优化排名
  • 网站公司做网站微信指数
  • 网站营销中常见问题重庆网站推广
  • 网站建设项目简介国际新闻头条今日要闻
  • 广州网站设计服务长沙网络推广只选智投未来
  • 如何做彩票网站代理百度灰色关键词代做
  • 网站做众筹需哪些条件服务之家网站推广公司
  • 长春网站建设排名靠前seo诊断方案
  • 手机企业网站推广营销型企业网站诊断
  • 广州铁路投资建设集团网站营销方案设计思路
  • ps如何做游戏模板下载网站网站下载
  • 海宁网站怎么做seo网络营销推广目标
  • 长安高端装备网站设计公司百度seo排名培训
  • 网站建设的内容百度入驻绍兴
  • php+mysql网站开发今日重要新闻
  • 帝国cms做中英文网站厦门seo厦门起梦
  • 湖南网站建设公司速来磐石网络全网最低价24小时自助下单平台
  • php管理系统 网站模版网站排名软件
  • 白鹭引擎可以做网站吗seo对各类网站的作用
  • 徐州网站制作如何定位大地seo视频
  • 有什么网站做知识吗购买域名的网站
  • 动漫网站建设方案项目书目录seo推广网址
  • 河南网站备案系统短信做网络销售如何找客户
  • 《网站建设与维护》讲义信息流广告公司一级代理
  • 上下篇文章wordpress如何进行搜索引擎优化 简答案
  • 电子商务网站建设人才网络推广优化服务
  • 织梦网站如何做地区分站网站seo关键词排名优化