qq_30238975 2021-06-16 23:47 采纳率: 0%
浏览 75

求一个LDAP与Linux本地用户同步的解决方案

想要让LDAP用户和组与Linux用户和组同步,试过很多教程文档,但是都没有实现,有没有比较完整的配置文档

  • 写回答

1条回答 默认 最新

  • dujunqiu 2023-06-26 09:09
    关注

    要实现LDAP与Linux本地用户同步,可以使用ldapsearchawk命令结合pwd命令来完成。以下是一个简单的解决方案:

    1. 首先,确保已经安装了openldap-clients包,如果没有安装,可以使用以下命令安装:
    sudo apt-get install openldap-clients
    
    1. 创建一个名为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_serveryour_passwordBASE_DN等变量替换为实际的LDAP服务器地址、密码、基本DN以及需要同步的用户属性。

    1. 为脚本文件添加可执行权限:
    chmod +x sync_ldap_to_local.sh
    
    1. 运行脚本文件以同步LDAP用户信息到本地用户目录:
    ./sync_ldap_to_local.sh
    
    1. 如果需要定期同步用户信息,可以将上述脚本添加到cron定时任务中。例如,每天凌晨1点执行同步操作:
    0 1 * * * /path/to/sync_ldap_to_local.sh
    
    评论

报告相同问题?

悬赏问题

  • ¥30 STM32 INMP441无法读取数据
  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动
  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥500 把面具戴到人脸上,请大家贡献智慧
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。
  • ¥15 各位 帮我看看如何写代码,打出来的图形要和如下图呈现的一样,急
  • ¥30 c#打开word开启修订并实时显示批注
  • ¥15 如何解决ldsc的这条报错/index error
  • ¥15 VS2022+WDK驱动开发环境