1,基本概念
- 为了方便管理和集成jenkins,k8s、harbor、jenkins均使用openLDAP统一认证。
2,部署openLDAP
- 根据之前的文档,openLDAP使用GFS进行数据持久化。
- 下载对应的openLDAP文件
git clone https://github.com/xiaoqshuo/k8s-cluster.git
2.1 创建openLDAP
[root@k8s-master01 k8s-cluster]# kubectl apply -f openldap/
deployment.extensions/ldap created
persistentvolumeclaim/openldap-data created
secret/ldap-secret created
service/ldap-service created
deployment.extensions/phpldapadmin created
service/phpldapadmin created
- 此处参考的是:https://github.com/osixia/docker-openldap,更新DN可以更改environment下的yaml文件,默认的example.org
2.2 创建ldap-ui-ingress
[root@k8s-master01 openldap]# kubectl create -f traefik-ldap.yaml
ingress.extensions/ldap-ui created
[root@k8s-master01 openldap]# cat traefik-ldap.yaml
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: ldap-ui
namespace: public-service
annotations:
kubernetes.io/ingress.class: traefik
spec:
rules:
- host: ldap.k8s.net
http:
paths:
- backend:
serviceName: phpldapadmin
servicePort: 8080
3, 查看验证
[root@k8s-master01 openldap]# kubectl get po,svc,pvc -n public-service | grep ldap
pod/ldap-6c9fcc7446-r52r7 1/1 Running 0 4m19s
pod/phpldapadmin-6784bf8db-gxqw2 1/1 Running 0 4m16s
service/glusterfs-dynamic-openldap-data ClusterIP 10.96.177.154 <none> 1/TCP 3m29s
service/ldap-service ClusterIP 10.111.36.109 <none> 389/TCP,636/TCP 4m16s
service/phpldapadmin ClusterIP 10.103.142.162 <none> 8080/TCP 4m11s
persistentvolumeclaim/openldap-data Bound pvc-252ac771-01da-11e9-b0c8-000c2927a0d0 1Gi RWX gluster-heketi 4m20s
3.1 访问web
- 访问phpldapadmin:ldap.k8s.net
data:image/s3,"s3://crabby-images/1716b/1716b04b9f9f23e158cc839214cc615a41d5aa10" alt="1306461-20181217170715571-1509304917.png"
- 登录
- 默认DN:cn=admin,dc=example,dc=org,默认Password:admin(线上系统需自定义修改)
data:image/s3,"s3://crabby-images/4a341/4a341392b1dbf1af9e00b538c52a3864737ea0e7" alt="1306461-20181218092409949-1560719290.png"
data:image/s3,"s3://crabby-images/7c9d6/7c9d659596deec2733bfc5b32bcf3a0ed398e6e8" alt="1306461-20181218092506123-602106939.png"
4, 添加用户和组
4.1 创建Groups和People OU
data:image/s3,"s3://crabby-images/88ed6/88ed6102159de2c892942eb39cac87bdcdffe1a4" alt="1306461-20190128134152609-22993057.png"
data:image/s3,"s3://crabby-images/9721d/9721dc882d5d0cd69e77c0dda85426b1f1bad3ef" alt="1306461-20181221112915442-620641964.png"
4.2 创建组和用户
4.2.1 组 dev devops test
data:image/s3,"s3://crabby-images/4bbe1/4bbe1078057d4983f786e9ac96088d6fdc00eed2" alt="1306461-20190128134256646-781093785.png"
data:image/s3,"s3://crabby-images/e958c/e958cca23e0a9259cd0214d9ba9d99b9f11c50fa" alt="1306461-20181221113102427-2121130888.png"
data:image/s3,"s3://crabby-images/23851/23851bca29da5b3947971acc49114fdcdd058c02" alt="1306461-20181221113245308-2132636969.png"
4.2.2 用户
data:image/s3,"s3://crabby-images/e72c3/e72c39b15a71244c6cc1e528e1f0a9193256bc66" alt="1306461-20181221113449142-1201712806.png"
- 填写基本信息,选择组和Login Shell
- 注意修改Common Name
data:image/s3,"s3://crabby-images/82dea/82deaed7690d7dade16861005bea1b346703d402" alt="1306461-20181221113904907-480411119.png"
data:image/s3,"s3://crabby-images/9ad1b/9ad1b2df84ef73f4bb3b23762a2061472d85564a" alt="1306461-20181221113929093-2121698363.png"
data:image/s3,"s3://crabby-images/20372/20372356bbcd8a833ca077b19ff347277da38927" alt="1306461-20181221113951541-2110954495.png"
4.3 为每个用户添加Email,没有Email无法登陆gitlab
data:image/s3,"s3://crabby-images/1535b/1535baea21af55468b7cb705159a59900497107b" alt="1306461-20181221114047973-1700401100.png"
5,配置k8s使用ldap登录
未完待续
- 参考:
- https://www.cnblogs.com/dukuan/p/9983899.html
- https://github.com/osixia/
- https://icicimov.github.io/blog/virtualization/Kubernetes-LDAP-Authentication/
- https://github.com/nginxinc/nginx-ldap-auth.git
所有评论(0)