简介 LDAP(轻量级目录访问协议,Lightweight Directory Access Protocol)是为了实现目录服务的信息服务。 目录服务是一种特殊的数据库系统,其专门针对读取,浏览和搜索操作进行了特定的优
简介
- LDAP(轻量级目录访问协议,Lightweight Directory Access Protocol)是为了实现目录服务的信息服务。
- 目录服务是一种特殊的数据库系统,其专门针对读取,浏览和搜索操作进行了特定的优化。在网络中应用了LDAP后,用户只需要使用一个账号和密码就可以轻松访问网络中的所有服务,实现用户身份的统一认证。
- 简单来说:拿LDAP来统一管理一些账号,例如: Gitlab,JenKins,Samba,SVN,Zabbix等。
关于SSL/TLS
# LDAP over SSL 也就是 ldaps
# ldap默认不加密情况下是走的389端口
# 当使用ldaps的时候走的就是636端口了
# 可以简单理解成http和https的关系
# 当然ldaps已经淘汰了,不然也不会有LDAP over TLS出来
# TLS可以简单理解为ldaps的升级
# 它默认走389端口,但是会通讯的时候加密
# 客户端连接LDAP时,需要指明通讯类型为TLS,所以他可以跟不加密的模式一样,任意端口都行
对比一下连接方式:
ldaps: ldapsearch -H ldaps://127.0.0.1
TLS: ldapsearch -ZZ -H ldap://127.0.0.1
环境
CentOS Linux release 7.5.1804
Kernel 4.20.0-1.el7.elrepo.x86_64
docker-ce 18.09
docker-compose 1.23.1
安装docker-compose
yum install -y python-pip
pip install docker-compose
docker-compose -v
准备证书
wget -O /bin/cfssl https://pkg.cfssl.org/R1.2/cfssl_linux-amd64
wget -O /bin/cfssljson https://pkg.cfssl.org/R1.2/cfssljson_linux-amd64
wget -O /bin/cfssl-certinfo https://pkg.cfssl.org/R1.2/cfssl-certinfo_linux-amd64
for cfssl in `ls /bin/cfssl*`;do chmod +x $cfssl;done;
cd $HOME && mkdir ssl && cd ssl
# ca配置文件
cat > ca-config.json << EOF
{
"signing": {
"default": {
"expiry": "87600h"
},
"profiles": {
"ldap": {
"usages": [
"signing",
"key encipherment",
"server auth",
"client auth"
],
"expiry": "87600h"
}
}
}
}
EOF
# 自签名ca的证书申请
cat > ldap-ca-csr.json << EOF
{
"CN": "ldap",
"key": {
"algo": "rsa",
"size": 2048
},
"names": [
{
"C": "CN",
"ST": "Shenzhen",
"L": "Shenzhen",
"O": "ldap",
"OU": "LDAP Security"
}
]
}
EOF
# ldap证书申请资料
# 下面hosts字段里就是使用这张证书的主机
# 特别注意一定要加上宿主机的IP地址,反正是自己颁发的证书,怎么加都行!!!
# 加上本机回环地址,加上ldap容器名,我这里容器名待会设置成openldap
# 如果你要放到公网去的话,那一可以加上FQDN地址
cat > ldap-csr.json << EOF
{
"CN": "ldap",
"hosts": [
"127.0.0.1",
"192.168.1.1",
"openldap",
"ldap.lotbrick.com",
"lotbrick.com"
],
"key": {
"algo": "rsa",
"size": 2048
},
"names": [
{
"C": "CN",
"ST": "Shenzhen",
"L": "Shenzhen",
"O": "ldap",
"OU": "LDAP Security"
}
]
}
EOF
# CA自签名
cfssl gencert -initca ldap-ca-csr.json | cfssljson -bare ca
# LDAP证书签名,ldap需要的文件为:ca证书,ldap证书,ldap私钥
cfssl gencert -ca=ca.pem -ca-key=ca-key.pem -config=ca-config.json -profile=ldap ldap-csr.json | cfssljson -bare ldap
# 查看生成的证书
# 其中 ldap-key.pem ldap.pem ca.pem 是我们需要的
[root@master ssl]#ls
ca-config.json ca.csr ca-key.pem ca.pem ldap-ca-csr.json ldap.csr ldap-csr.json ldap-key.pem ldap.pem
开始安装ldap
- 克隆仓库,获取docker-compose.yaml文件
cd $HOME
git clone https://github.com/JyBigBoss/docker-compose.git
cd docker-compose/LDAP/
mkdir ssl/
cp $HOME/ssl/{ldap-key.pem,ldap.pem,ca.pem} ssl/
vi docker-compose.yaml
# 修改下面的几项
# 镜像使用的是osixia/openldap
# 详细的配置解释:https://github.com/osixia/docker-openldap
LDAP_ORGANISATION: "lotbrick.com"
LDAP_DOMAIN: "lotbrick.com"
LDAP_ADMIN_PASSWORD: "admin"
LDAP_CONFIG_PASSWORD: "admin"
LDAP_TLS: "true"
LDAP_TLS_CRT_FILENAME: "ldap.pem"
LDAP_TLS_KEY_FILENAME: "ldap-key.pem"
LDAP_TLS_CA_CRT_FILENAME: "ca.pem"
LDAP_TLS_ENFORCE: "true"
LDAP_TLS_VERIFY_CLIENT: "try"
domainname: "lotbrick.com"
hostname: "lotbrick.com"
# 特别注意LDAP_TLS_VERIFY_CLIENT
# 不要设置成demand,这个选项可以理解成双向认证,也就是客户端连接ldap时也许要提供证书,也就是客户端也需要有自己的证书
# 设置成try就行,客户端不提供证书也能连接,反正连接已经加密了。
# 官方文档:http://www.openldap.org/doc/admin24/tls.html
data:image/s3,"s3://crabby-images/9d617/9d6171bd6b3fc30fe79a9dcd0780a24b5a984ea0" alt="Centos7 搭建LDAP并启用TLS加密"
#第一次启动会比较慢,淡定点
docker-compose pull
docker-compose up -d
ls
docker ps -a
# 启动之后会生成几个文件夹
# ldapconf保存的是ldap的配置文件
# ldapdata保存的是ldap的数据
# lam保存的是lam管理工具的配置
[root@master LDAP]#docker-compose up -d
Creating network "ldap_default" with the default driver
Creating openldap ... done
Creating ldap-account-manager ... done
[root@master LDAP]#ls
docker-compose.yaml lam ldapconf ldapdata ssl
[root@master LDAP]#docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
9b4ebdad17eb jinyunboss/ldap-account-manager:6.6 "docker-php-entrypoi…" 2 minutes ago Up 2 minutes 0.0.0.0:8080->80/tcp ldap-account-manager
a7ff3bd5dced osixia/openldap:1.2.2 "/container/tool/run" 2 minutes ago Up 2 minutes 0.0.0.0:389->389/tcp, 0.0.0.0:636->636/tcp openldap
打开浏览器,配置LDAP Account Manager
- LDAP Account Manager容器监听在8080端口
- 打开http://192.168.1.1:8080
# 配置一下lam管理页面
# lam管理界面默认密码是: lam
# lam可以管理多个ldap服务器,所以可以拥有多个profile,每个profile对应一台服务器
# 简单添加个用户,然后用另一台linux机器测试ldap连接
data:image/s3,"s3://crabby-images/3cbfc/3cbfcf8486d4d95fef15296da8c9f3dfb1e9831b" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/0c1c9/0c1c9a8352adcdcad2e1702666fce6b67c2caf6b" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/a9516/a95160db1ffd326b673a5bac7e7cb6a4ca179a4d" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/634e8/634e819c0cf70414071a5111d0c86fbf862d5c7a" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/5421c/5421c5ad30747643b88403c8c9985e16a6e99726" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/0c2b9/0c2b90089598880e74adb7514bf782d5b40e9517" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/5d524/5d524390738a4dfd087d13c94c6a0d47cd958110" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/a6efe/a6efe46cb40330200b29058adc89f9cc2def347d" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/20f57/20f5701c84e4d2a53a47bc7c935d979ca24eac84" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/2fc0d/2fc0d9dde4a8c5aa0ae2c67e464b168d9458c0a2" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/b1940/b1940cdc86ee278978494d3e5de1375d1afc6fbf" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/e5c82/e5c82b12d908cfb62c75adc4a2d1f02ee3c94f97" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/813b8/813b81d335da5882f5ef5bf1a877a53b8973b8d5" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/f669b/f669bb51f313d3a54c1a5568bf882b3b53f1791a" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/9512b/9512b2146d614b1ca25f38e9346313eadade4e99" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/1ab3d/1ab3d11d813250e02d64d1c9552fa5a96d6654cc" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/1f389/1f3897916fee3bbfcca976e8447951f15056e1d6" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/d69a6/d69a6208304360ba1a7fa7dc0af6689690739458" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/9faed/9faed0daaf9b8026c02c3ca4c61b5e6d99ed62aa" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/76f0a/76f0a3b51733f225e8ac5d8d797fe74fcc672db7" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/a343a/a343a99fad1fb9ae4a464618ab8d6c172a0c0fb8" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/fb62d/fb62d039564d4d8c17dc1081d96f0457d2d29eef" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/8c603/8c6031a495ce600ec9772b01608712d6ee22414f" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/2f6b8/2f6b817defb1113d69dc750fcac621e3f0d40379" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/e624b/e624b06e5346fe88be6b37564a6ff4c94962eb47" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/5821e/5821eb969f67d91439ffe39ebde303c123fda684" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/93182/9318279c6cb84f6e60ca6ab1a1369f0cf99728c6" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/dd140/dd140573104c97243e4a7601051f016deb25e06e" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/970e3/970e313554665e7b5a30a0ba6fab0f9e6c510ec0" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/e433f/e433fee12aa274b9c1dde2307082f9b82b5c5c07" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/575c1/575c1db9dd6b586a0000172c7c6f475943bacb4d" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/adcf4/adcf47c3d25807f015959dbe25147445b5a67bcd" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/93320/933204b3fe571fea4ab357cef0326be83e221da6" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/24360/243605f07412f3220254436604d8f6d4a336489e" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/a0876/a087644389294f9200936e9f302300076643e498" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/cbb01/cbb0187c3b81c748f701722c909e5c78b6b48330" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/f852b/f852be91c64e85bbda7250fe7cef5c8515cd0be2" alt="Centos7 搭建LDAP并启用TLS加密"
测试LDAP
yum install -y openldap-clients nss-pam-ldapd
# 配置系统使用ldap认证
authconfig-tui
# 将自签名的ca证书给客户端
cd /etc/openldap/cacerts/
# 修改/etc/nslcd.conf,添加管理员凭据
echo "binddn cn=admin,dc=lotbrick,dc=com" >> /etc/nslcd.conf
echo "bindpw admin" >> /etc/nslcd.conf
cat /etc/nslcd.conf
# 重启nslcd服务
systemctl restart nslcd
data:image/s3,"s3://crabby-images/2f66d/2f66dcf4998594ca8986749c40f5f52472f7308f" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/c0b72/c0b7268f67cc0d8b7a54e9d6d40c4d2e89d70230" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/f977a/f977a2c4f7ee65876714d1f72ce20eb5840ac7c3" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/02ed8/02ed80e59ab2d468ba264f84ae3f93573ac4feed" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/536f7/536f7c5a3168662da6c62fd2f60a0753e30c9ad1" alt="Centos7 搭建LDAP并启用TLS加密"
# 执行命令看看能不能读取到LDAP用户
# 能连接上ldap的话,执行之后会出现ldap用户
getent passwd
id bigboss
# 切换成bigboss用户试试
su - bigboss
data:image/s3,"s3://crabby-images/c3145/c31453d5b609133fcc52b19b288d3a0bc082a91b" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/ebc95/ebc9518369329c5e6012d9a3bc49819f08a279fb" alt="Centos7 搭建LDAP并启用TLS加密"
data:image/s3,"s3://crabby-images/4a28b/4a28b271269e25e08c2527b6be4f6e441979f70b" alt="Centos7 搭建LDAP并启用TLS加密"