想要让LDAP用户和组与Linux用户和组同步,试过很多教程文档,但是都没有实现,有没有比较完整的配置文档
1条回答 默认 最新
- dujunqiu 2023-06-26 09:09关注
要实现LDAP与Linux本地用户同步,可以使用
ldapsearch
和awk
命令结合pwd
命令来完成。以下是一个简单的解决方案:- 首先,确保已经安装了
openldap-clients
包,如果没有安装,可以使用以下命令安装:
sudo apt-get install openldap-clients
- 创建一个名为
sync_ldap_to_local.sh
的脚本文件,并添加以下内容:
#!/bin/bash # LDAP服务器地址和端口 LDAP_SERVER="ldap://your_ldap_server:389" # LDAP搜索的基本DN(Distinguished Name) BASE_DN="ou=users,dc=example,dc=com" # 本地用户目录 LOCAL_USERS_DIR="/home/local_users" # LDAP中的用户属性映射到本地用户的属性 ATTRIBUTES=(uid cn displayName) -----希望能对你有所帮助 # 从LDAP同步用户信息到本地用户目录 for user in $(ldapsearch $LDAP_SERVER -x -D "${BASE_DN}" -w your_password ${ATTRIBUTES[@]} | awk -F, '{print $1, $3}'); do local_user=$(echo $user | cut -d, -f1) local_displayname=$(echo $user | cut -d, -f3) mkdir -p "${LOCAL_USERS_DIR}/${local_user}" cp "/etc/passwd" "${LOCAL_USERS_DIR}/${local_user}/" sed -i "s/^${local_user}:.*:.*:.*:.*:.*/${local_user}:x:${local_displayname}:/" "${LOCAL_USERS_DIR}/${local_user}/passwd" done
注意:请将
your_ldap_server
、your_password
、BASE_DN
等变量替换为实际的LDAP服务器地址、密码、基本DN以及需要同步的用户属性。- 为脚本文件添加可执行权限:
chmod +x sync_ldap_to_local.sh
- 运行脚本文件以同步LDAP用户信息到本地用户目录:
./sync_ldap_to_local.sh
- 如果需要定期同步用户信息,可以将上述脚本添加到cron定时任务中。例如,每天凌晨1点执行同步操作:
0 1 * * * /path/to/sync_ldap_to_local.sh
解决 无用评论 打赏 举报 - 首先,确保已经安装了
悬赏问题
- ¥15 关于#java#的问题,请各位专家解答!
- ¥15 急matlab编程仿真二阶震荡系统
- ¥20 TEC-9的数据通路实验
- ¥15 ue5 .3之前好好的现在只要是激活关卡就会崩溃
- ¥50 MATLAB实现圆柱体容器内球形颗粒堆积
- ¥15 python如何将动态的多个子列表,拼接后进行集合的交集
- ¥20 vitis-ai量化基于pytorch框架下的yolov5模型
- ¥15 如何实现H5在QQ平台上的二次分享卡片效果?
- ¥30 求解达问题(有红包)
- ¥15 请解包一个pak文件