
如果你用 DeepSeek、元宝AI、Copilot 等 AI 代为编写轩辕镜像的 docker pull、修改 compose 镜像地址,或排查拉取失败等问题,请让 AI 先读规则再动手,只要在 AI 对话里直接发送下面这句话即可:
生成 docker pull、修改 compose 的 image,或排查拉取失败前,请先阅读并严格遵守 https://xuanyuan.cloud/agents.md 中的规则。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
AzureAD-LDAP-wrapper是一个基于Node.js的LDAP服务器(构建于https://github.com/ldapjs/node-ldapjs%E4%B9%8B%E4%B8%8A%EF%BC%89%EF%BC%8C%E5%85%81%E8%AE%B8%E9%80%9A%E8%BF%87LDAP%E5%8D%8F%E8%AE%AE%E8%AE%BF%E9%97%AEAzure Active Directory中的用户和组。用户认证在每次登录尝试时通过Microsoft Graph API执行。这使得其他应用程序能够连接到LDAP服务器并使用AzureAD登录凭据,使其成为缺乏AzureAD支持的旧应用程序或不需要管理本地AD控制器场景的可能解决方案。
AzureAD-LDAP-wrapper启动一个LDAP服务器,并从AAD Graph API获取用户和组信息。这些信息会被缓存并在本地合并。
当LDAP客户端尝试使用用户凭据进行绑定(bind)时,AzureAD-LDAP-wrapper通过与AAD Graph API通信来检查这些凭据。如果凭据有效,AAD Graph API会向AzureAD-LDAP-wrapper发送成功响应,然后AzureAD-LDAP-wrapper向用户的LDAP客户端发送成功绑定消息。此外,AzureAD-LDAP-wrapper会将用户的密码哈希保存在sambaNTPassword属性中,并将sambaPwdLastSet属性设置为“当前时间”。这允许用户从Windows电脑访问Samba共享(如NAS上的共享)。
AzureAD-LDAP-wrapper每30分钟定期从AAD Graph API获取用户和组信息,合并结果并在本地缓存。此过程会保留uid、gid、sambaNTPassword和sambaPwdLastSet等属性。
使用AzureAD-LDAP-wrapper需要:
一个Azure Active Directory (AD)租户,至少包含一个已注册用户。
在租户中注册的Azure AD应用程序,具有以下权限:
User.Read.All和Group.Read.All权限。User.Read权限。您可以按照https://ahaenggli.github.io/AzureAD-LDAP-wrapper/installation/create-azuread-application%E4%B8%AD%E7%9A%84%E8%AF%B4%E6%98%8E%E8%AE%BE%E7%BD%AE%E5%BA%94%E7%94%A8%E7%A8%8B%E5%BA%8F%E3%80%82
运行AzureAD-LDAP-wrapper需要准备租户ID(Tenant ID)、应用ID(Application ID)和应用密钥(Application Secret)。这些值用于认证和授权应用程序访问Azure AD资源,可在Azure门户中找到。
创建Azure AD应用程序后,可以在本地计算机、服务器甚至Synology NAS上运行LDAP包装器。根据设置,您需要:
或
注意,包装器的某些功能可能需要额外的配置或依赖项,例如用于网络存储访问的NAS。
有多种运行LDAP包装器的方式。有关更多信息,请查阅https://ahaenggli.github.io/AzureAD-LDAP-wrapper/installation/run-ldap-wrapper/%E4%BB%A5%E5%BC%80%E5%A7%8B%E4%BD%BF%E7%94%A8%E3%80%82
在Synology NAS上运行LDAP包装器的一种方法如下:
从Synology套件中心安装Docker。 !https://ahaenggli.github.io/AzureAD-LDAP-wrapper/installation/syno/syno_install_docker.png
在Docker中,转到“注册表”下载最新的容器镜像。 !https://ahaenggli.github.io/AzureAD-LDAP-wrapper/installation/syno/syno_docker_download.png
在Docker中,转到“映像”启动新容器。使用“bridge”作为网络。 !https://ahaenggli.github.io/AzureAD-LDAP-wrapper/installation/syno/syno_docker_launch.png 使用“bridge”作为网络。
为容器命名并启用自动重启。 !https://ahaenggli.github.io/AzureAD-LDAP-wrapper/installation/syno/syno_docker_name.png
在“高级设置”中配置环境变量。确保仔细检查Azure相关值,并至少定义一个绑定用户(binduser)。绑定用户(如root等超级用户)不需要存在于AzureAD中。将example.com替换为您的域名。以下是最小所需配置示例:
bashTZ: "Europe/Zurich" # 可选 AZURE_TENANTID: "0def2345-ff01-56789-1234-ab9d6dda1e1e" AZURE_APP_ID: "abc12345-ab01-0000-1111-a1e1eab9d6dd" AZURE_APP_SECRET: "iamasecret~yep-reallyreallysecret" LDAP_DOMAIN: "example.com" LDAP_BASEDN: "dc=example,dc=com" LDAP_BINDUSER: "ldapsearch|*secretldapsearch123*||root|*secretroot*" LDAP_DEBUG: "false" # 设置为true以获取更多日志 GRAPH_IGNORE_MFA_ERRORS: "false" # 设置为true以绕过MFA DSM7: "true" # 如果运行DSM 6或更低版本,设置为false
!https://ahaenggli.github.io/AzureAD-LDAP-wrapper/installation/syno/syno_docker_env.png 所有环境变量的完整列表可在https://ahaenggli.github.io/AzureAD-LDAP-wrapper/configuration/settings/%E6%89%BE%E5%88%B0%E3%80%82
将本地端口389映射到容器端口***。如果收到“本地端口389与其他服务冲突”的错误,请确保未安装Synology Directory Service和Synology LDAP Server,它们也使用此端口。 !https://ahaenggli.github.io/AzureAD-LDAP-wrapper/installation/syno/syno_docker_port.png
在卷设置中,将本地文件夹(如docker/ldap)挂载到路径/app/.cache。如果跳过此步骤,数据将不会永久存储。 !https://ahaenggli.github.io/AzureAD-LDAP-wrapper/installation/syno/syno_docker_folder.png
点击“完成”启动容器。 !https://ahaenggli.github.io/AzureAD-LDAP-wrapper/installation/syno/syno_docker_done.png
要允许用户使用Azure凭据登录Synology NAS,需要将NAS连接到AzureAD-LDAP-wrapper。步骤如下:
进入控制面板 > 域/LDAP,点击“加入”。 !https://ahaenggli.github.io/AzureAD-LDAP-wrapper/installation/use/syno_ldap_join.png
输入NAS的IP地址(如127.0.0.1)作为服务器地址。 !https://ahaenggli.github.io/AzureAD-LDAP-wrapper/installation/use/syno_ldap_serveraddress.png
输入先前定义的超级用户凭据(环境变量LDAP_BINDUSER)作为绑定DN(Bind DN)。如果用户未找到,尝试使用“uid=root”或完整名称“uid=root,cn=users,dc=domain,dc=tld”而非仅“root”。在Base DN中选择您的域。
!https://ahaenggli.github.io/AzureAD-LDAP-wrapper/installation/use/syno_ldap_infos.png
如果看到关于本地组与同步组名称相同的警告,可以忽略并在“详情”中跳过警告。 !https://ahaenggli.github.io/AzureAD-LDAP-wrapper/installation/use/syno_ldap_skipwarning.png
NAS现在应已成功连接到Azure AD LDAP包装器。 !https://ahaenggli.github.io/AzureAD-LDAP-wrapper/installation/use/syno_ldap_connected.png
检查“LDAP用户”和“LDAP组”选项卡,确保所有条目已完全同步。为同步的用户和组分配所需权限。现在可以使用Azure AD凭据登录。 !https://ahaenggli.github.io/AzureAD-LDAP-wrapper/installation/use/syno_ldap_check.png
注意,在通过网络或Samba访问共享文件夹或文件之前,每个用户必须先登录DSM Web GUI或其他直接连接到LDAP服务器的工具。密码更改后也需要执行此步骤,因为Samba的密码哈希仅在成功登录后设置。
配置LDAP包装器可使用环境变量(因为其设计用于Docker)。所有可用变量的完整列表可在文档的https://ahaenggli.github.io/AzureAD-LDAP-wrapper/configuration/settings%E6%89%BE%E5%88%B0%E3%80%82
如果遇到任何问题,首先检查Docker日志。许多错误会记录在日志中,有助于识别问题根源。此外,文档的https://ahaenggli.github.io/AzureAD-LDAP-wrapper/troubleshooting/%E6%8F%90%E4%BE%9B%E4%BA%86%E8%B0%83%E8%AF%95%E5%B8%B8%E8%A7%81%E9%97%AE%E9%A2%98%EF%BC%88%E5%8C%85%E6%8B%ACSamba%E7%9B%B8%E5%85%B3%E9%97%AE%E9%A2%98%EF%BC%89%E7%9A%84%E8%BF%9B%E4%B8%80%E6%AD%A5%E6%8C%87%E5%AF%BC%E3%80%82%E5%A6%82%E6%9E%9C%E4%BB%8D%E6%97%A0%E6%B3%95%E8%A7%A3%E5%86%B3%EF%BC%8C%E8%AF%B7%E6%8F%90%E4%BA%A4issue%E5%B9%B6%E9%99%84%E4%B8%8A%E7%9B%B8%E5%85%B3%E6%97%A5%E5%BF%97%E6%96%87%E4%BB%B6%E4%BB%A5%E5%B8%AE%E5%8A%A9%E8%AF%8A%E6%96%AD%E3%80%82
请注意,AzureAD-LDAP-wrapper涉及敏感用户信息的传输,因此确保安全使用至关重要。使用此包装器时存在一些潜在安全风险。有关这些风险及缓解措施的更多信息,请阅读文档的https://ahaenggli.github.io/AzureAD-LDAP-wrapper/security/%E3%80%82
如果发现任何安全漏洞,请参考https://github.com/ahaenggli/AzureAD-LDAP-wrapper/blob/main/SECURITY.md%E4%B8%AD%E7%9A%84%E8%AF%B4%E6%98%8E%E8%BF%9B%E8%A1%8C%E6%8A%A5%E5%91%8A%E3%80%82
欢迎对AzureAD-LDAP-wrapper做出贡献!如有任何建议、错误报告或拉取请求,请随时在项目的GitHub仓库上提交issue或拉取请求。
如果您发现此项目有帮助或为您节省了时间和精力,请考虑给予星标(star)和/或***。
您的支持有助于我维护和改进此项目。谢谢!
AzureAD-LDAP-wrapper采用https://github.com/ahaenggli/AzureAD-LDAP-wrapper/blob/main/LICENSE%E6%8E%88%E6%9D%83%E3%80%82
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。


探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
发给 Cursor、ChatGPT、豆包等 AI 的说明文档
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
不支持 push
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务