轻型目录访问协议(英文: LightweightDirectoryAccessProtocol,缩写: LDAP)是一个开放的,中立的,工业标准的应用协议,通过IP协议提供访问控制和维护分布式信息的目录信息。

OpenLDAP是轻型目录访问协议( LightweightDirectoryAccessProtocol, LDAP)的自由和开源的实现,在其 OpenLDAP许可证下发行,并已经被包含在众多流行的 Linux发行版中。

可以这样讲:市面上只要你能够想像得到的所有工具软件,全部都支持 LDAP协议。比如说你公司要安装一个项目管理工具,那么这个工具几乎必然支持 LDAP协议,你公司要安装一个 bug管理工具,这工具必然也支持 LDAP协议,你公司要安装一套软件版本管理工具,这工具也必然支持 LDAP协议。 LDAP协议的好处就是你公司的所有员工在所有这些工具里共享同一套用户名和密码,来人的时候新增一个用户就能自动访问所有系统,走人的时候一键删除就取消了他对所有系统的访问权限,这就是 LDAP。

有些领域并不像前端世界那么潮那么性感,但是缺了这个环节又总觉得很别扭。如果深入到运维的世界,你会发现大部分工具还活在上个世纪,产品设计完全反人类,比如 cn, dc, dn, ou这样的命名方式,如果不钻研个一天两天,鬼知道它在说什么,比如说 dns, dns是什么鬼?域名吗?不是,它只是某个懒惰的工程师起了 dn这么一个缩写,再加一个复数,就成了 dns,和域名服务器没有任何关系; cn是什么?中国的缩写?你想多了,这和中国没有任何关系。经过一系列这样疯狂的洗脑之后,你才能逐渐明白 LDAP到底想干什么。抛弃你所有的认知,把自己当成一个什么都不懂的幼儿园孩子,然后我们从头学起 LDAP。

如果你搜索 OpenLDAP的安装指南,很不幸地告诉你,网上不管中文的英文的, 90%都是错的,它们都还活在上个世纪,它们会告诉你要去修改一个叫做 slapd.conf的文件,基本上看到这里,你就不用往下看了,这个文件早就被抛弃,新版的 OpenLDAP里根本就没有这个文件!取而代之的是 slapd.d的文件夹,然后另一部分教程会告诉你,让你修改这个文件夹下的某一个 ldif文件,看到这里,你也不用往下看了,你又看到了伪教程,因为这个文件夹下的所有文件的第一行都明确地写着:『 这是一个自动生成的文件,不要修改它!』你修改了它之后,它的 md5校验值会匹配不上,造成更多的问题。你应该用 ldapmodify来修改这个文件,而关于 ldapmodify的教程,可以说几乎就没有!我一开始不知道面临这样荒谬的处境,很多运维人员是怎么活下来的,不过等我自己配通了以后,真的是累到连写教程的精力都没有了,好吧,我已经配通了,你们各人自求多福吧。

架构

实际上,我的操作步骤很多都是反的,架构这部分是最后才意识到的,但实际上从最一开始就应该先想到。实际上整个 OpenLDAP的架构大致包含 3个部分,而网上没有教材提到这块。

OpenLDAP

首先,是 OpenLDAP的服务器本身,这个东西其实只相当于是一个 mysql数据库,它是没有酷炫的图形界面的,如果你愿意每次都手敲一大堆代码,也可以用它,但这种反人类的设计真的不是给人用的。

phpLDAPadmin

所以,你需要安装一个叫作 phpLDAPadmin的工具,好歹这是一个图形界面,虽然奇丑无比,并且配置起来也并不容易。

PWM

光装管理工具还不够,你总要给用户提供一个修改密码的地方。

客户端

最后,你还需要配置各种工具。

架构图

我画了一个简单的架构图如下:

安装 安装OpenLDAP

安装 OpenLDAP非常简单,直接安装这 3个东西就够了,甚至运气好的话,也许你的操作系统已经自带安装好了:

  1. yum install openldap openldap-clients openldap-servers

安装完了之后可以直接启动 OpenLDAP服务,不需要做任何配置,我一开始还有顾虑,后来发现完全不用多想直接启动即可:

  1. service slapd start

配置OpenLDAP

这一块在最一开始是最麻烦的部分,网上所有教程讲的都不对。因为现在是 2018年了,而很多教程还停留在 2008年甚至 1998年。配置 OpenLDAP最正确的姿势是通过 ldapmodify命令执行一系列自己写好的ldif文件,而不要修改任何OpenLDAP装好的配置文件

举个例子来说,你要想修改 RootDN,那么你就自己写这么一个 ldif文件,假设给它起名叫 a.ldif,然后执行它就可以了:

  1. dn: olcDatabase={2}bdb,cn=config
  2. changetype: modify
  3. replace: olcRootDN
  4. olcRootDN: cn=admin,dc=qiban,dc=com
  5. -
  6. replace: olcSuffix
  7. olcSuffix: dc=qiban,dc=com

怎么执行呢?

  1. ldapmodify -Q -Y EXTERNAL -H ldapi:/// -f a.ldif

这么长的命令是什么意思? -Q表示安静执行, -Y和后面的 EXTERNAL表示,好吧,我也不知道什么意思,总之需要这样配合,然后 -H表示地址, -f表示文件名。几乎所有的 ldapmodify命令都这么执行就好了。

再来讲解一下上面的 ldif文件的内容,你不要问为什么叫 ldif这么一个破后缀,总之你记住它就是这个后缀就好了。 dn表示你要修改什么东西,在这里我们用的是 {2}bdb,你的系统不一定是 {2}bdb,不管是几,总之你去查一下目录里的内容就好了:

  1. ls /etc/openldap/slapd.d/cn=config/

得到的结果大概如下,不一样也不要害怕:

  1. cn=module{0}.ldif cn=schema/ cn=schema.ldif olcDatabase={0}config.ldif olcDatabase={-1}frontend.ldif olcDatabase={1}monitor.ldif olcDatabase={2}bdb/ olcDatabase={2}bdb.ldif

这里面有一大堆奇奇怪怪的数字,不要担心,其中有一个带什么 db.ldif的就是你最终需要修改的数据库文件,我这里是 bdb.ldif,你的可能是 mdb.ldif,还有人是 hdb.ldif,不管什么 db,总之你要改的是一个叫 db的文件就对了,你可以 cat打开看一看,但是不要用 vi去修改它。

changetype就是 modify,表示我们要修改这个文件。第 3行是 replace,表示我们要替换里面的某个值,你可以把这个操作理解为 mysql数据库的 update操作,如果你把第 3行改成 add,那就是 mysql的 insert操作了。不过这里我们操作的只是配置文件本身,还牵涉不到添加用户或者更改用户,如果你以为事情就这么简单,那就是你太天真了。

RootDN在这里就表示你整个 OpenLDAP系统的管理员用户名是什么,不要奇怪,后面这一砣都是用户名 cn=admin,dc=qiban,dc=com,长的有点像 email地址,实际意思也差不多,但总之就不是 email就行了。不要问为什么,总之 cn就是 email前面的那个名字,后面带 dc的都是域名。

真实情况是你还需要给这个用户设置一个密码,具体怎么设自行 Google,但还是那句话:不要修改系统文件,要用ldapmodify来执行。

添加memberOf模块

这个工作应该一开始就做好,要不然后面要做的话,还得把建好的组全删掉再重建。这个模块的作用是当你建一个组的时候,把一些用户添加到这个组里去,它会自动给这些用户添加一个 memberOf属性,有很多应用需要检查这个属性。

添加的时候比较麻烦,需要建 3个 ldif文件,然后 1个执行 ldapmodify, 2个执行 ldapadd,错一点都不行:

memberof_config.ldif

再一次重申:文件名叫做什么根本无所谓,只要后缀名为 ldif即可。

  1. dn: cn=module,cn=config
  2. cn: module
  3. objectClass: olcModuleList
  4. olcModuleLoad: memberof
  5. olcModulePath: /usr/lib64/openldap
  6. dn: olcOverlay={0}memberof,olcDatabase={2}bdb,cn=config
  7. objectClass: olcConfig
  8. objectClass: olcMemberOf
  9. objectClass: olcOverlayConfig
  10. objectClass: top
  11. olcOverlay: memberof
  12. olcMemberOfDangling: ignore
  13. olcMemberOfRefInt: TRUE
  14. olcMemberOfGroupOC: groupOfNames
  15. olcMemberOfMemberAD: member
  16. olcMemberOfMemberOfAD: memberOf

小心第 5行和第 7行,先找到你的模块目录是不是在 /usr/lib64下面,然后看清楚你的数据库类型和数字,不要瞎复制。

对于这个文件,我们需要执行 ldapadd:

  1. ldapadd -Q -Y EXTERNAL -H ldapi:/// -f memberof_config.ldif

执行完之后,检查你的 /etc/openldap/slapd.d/cn=config/,看是不是多了一个模块,这个模块的数字编号直接影响下一步操作。

refint1.ldif

  1. dn: cn=module{0},cn=config
  2. add: olcmoduleload
  3. olcmoduleload: refint

这个文件里我的 memberOf是第一个模块,所以编号是 0,你的不一定,要看清楚到底第几号模块是 memberof,然后就改成几就可以了,对于这个文件,我们要执行 ldapmodify操作:

  1. ldapmodify -Q -Y EXTERNAL -H ldapi:/// -f refint1.ldif

你如果能看懂它的意思的话,它的大意是说要修改我们刚刚添加的那个模块文件的内容。

refint2.ldif

  1. dn: olcOverlay={1}refint,olcDatabase={2}bdb,cn=config
  2. objectClass: olcConfig
  3. objectClass: olcOverlayConfig
  4. objectClass: olcRefintConfig
  5. objectClass: top
  6. olcOverlay: {1}refint
  7. olcRefintAttribute: memberof member manager owner

对这个文件执行 ldapadd操作:

  1. ldapadd -Q -Y EXTERNAL -H ldapi:/// -f refint2.ldif

还是要注意检查 db类型,否则你一定不能成功。

安装phpLDAPadmin

好吧,干完了上面这些啰里巴嗦的事情,你可以先给自己泡杯咖啡,接下来还有很多工作要做,不过难度已经没有刚才那么大了。

我们开始安装 phpLDAPadmin。

  1. yum install phpldapadmin

CentOS的 yum安装总是这么令人赏心悦目。

配置phpLDAPadmin

接下来让我们在 nginx里配置好它,以便让我们的管理员能够看到它。

  1. location /htdocs {
  2. alias /usr/share/phpldapadmin/htdocs;
  3. index index.php;
  4. location ~ .php$ {
  5. alias /usr/share/phpldapadmin;
  6. fastcgi_pass 127.0.0.1:9000;
  7. fastcgi_index index.php;
  8. fastcgi_param _FILENAME $document_root$fastcgi__name;
  9. include fastcgi_params;
  10. }
  11. }

缺省文件安装在 /usr/share/phpldapadmin/htdocs下,我们必得要在这里配置一个 alias才能访问到它,但在 php-fpm时又要配置另外一个 alias,这也是比较坑人的一个地方。

接下来你需要修改 /etc/phpldapadmin/config.php这个文件,里面有大段大段的注释,看到人头晕,注意这么 2点就够了,其它的都不要改:

  • 把 $servers->setValue('login','anon_bind',false);改成 false,因为我们不想让人匿名访问;
  • 把 $servers->setValue('login','allowed_dns',array('cn=admin,dc=qiban,dc=com'));,我们只允许管理员访问,其他任何人不得访问。

使用phpLDAPadmin

你现在可以通过 URL地址访问 phpLDAPadmin了,登录的时候输入你那一坨用户名: cn=admin,dc=qiban,dc=com,然后输入密码,如果你前面一切都设置对了,那么这里就可以登录进去了。

界面里透出一股浓浓的上世纪九十年代风格,不过好歹我们终于可以脱离纯手写代码管理的窘境了。

这时候你首先要建立两个 organizationalUnit,一个叫作 groups,一个叫作 users。不要问为什么。

然后在 users下面建几个 inetOrgPerson,这些就是你的用户了。注意,在创建新条目时,一定要选择 默认,不要选择什么 Posix或者 GenericUserAccount,那只会帮你建出一堆没用的 Linux账号出来,我们只想要 web用户,不想建什么 Linux用户。注意:密码这个地方一定要选 md5,否则你后面和其它系统连接会出问题。

然后在 groups下面建几个组吧,比如 admins, users等等,注意选择 objectClass为 groupOfNames就行了。然后把你刚刚建好的几个用户分门别类的给他们加到组里去。

在这一步上,如果你前面配置 memberOf模块配置正确的话,你会在 user的 显示内部属性里看到它的 memberOf属性,如果看不到,说明你没有配对。

配置第三方应用

到此为止,似乎真没有什么好说的了, Phabricator, Confluence, Zabbix, Grafana, 禅道等等,几乎你能想到的任何一个第三方应用都会有说明书教你怎么配置 dc, cn, ou这些东西,经过了上面这一番折腾,你怎么着也应该对 LDAP的一些术语有所了解了,如果还是不行,说明你玩它的时间还是不够长,再多玩两天,也就明白了。

配置好之后的好处就是你再也不用东一块西一块地建用户了,而可以在一个统一的地方集中管理你的用户和群组授权。

结语

总之,配置 OpenLDAP不是一个轻松的活,但是考虑到有那么多第三方应用都支持这个鬼东西,花点代价把它配通还是值得的。希望你一切顺利

懂了 OpenLDAP的更多相关文章

  1. [转]我花了一个五一终于搞懂了OpenLDAP

    轻型目录访问协议(英文:Lightweight Directory Access Protocol,缩写:LDAP)是一个开放的,中立的,工业标准的应用协议,通过IP协议提供访问控制和维护分布式信息的 ...

  2. LDAP-轻量级目录访问协议(统一认证)

    概念 LDAP是轻量目录访问协议,英文全称是Lightweight Directory Access Protocol,一般都简称为LDAP. 参考资料 LDAP概念和原理介绍 我花了一个五一终于搞懂 ...

  3. Linux系统下安装配置 OpenLDAP + phpLDAPadmin

    实验环境: 操作系统:Centos 7.4 服务器ip:192.168.3.41 运行用户:root 网络环境:Internet LDAP(轻量级目录访问协议)是一个能实现提供被称为目录服务的信息服务 ...

  4. OpenLDAP 安装教程

    OpenLDAP 安装教程 本文原始地址:https://sitoi.cn/posts/48217.html 在centos7上安装OpenLDAP 环境准备 两台虚拟机 node01 IP:192. ...

  5. 《Linux就该这么学》培训笔记_ch23_使用OpenLDAP部署目录服务

    <Linux就该这么学>培训笔记_ch23_使用OpenLDAP部署目录服务 文章主要内容: 了解目录服务 目录服务实验 配置LDAP服务端 配置LDAP客户端 了解目录服务 其实目录可以 ...

  6. OpenLDAP配置坎坷路

    https://segmentfault.com/a/1190000014683418 轻型目录访问协议(英文:Lightweight Directory Access Protocol,缩写:LDA ...

  7. 基于OPENldap搭建postfix 虚拟用户

    本文首发: https://www.somata.work/2019/DependOPENldapBuildPostfixVirtualMailUser.html postfix + dovecot ...

  8. 金瓯无缺江河一统|Win10系统基于Docker和Python3搭建并维护统一认证系统OpenLdap

    原文转载自「刘悦的技术博客」https://v3u.cn/a_id_180 OpenLdap(Lightweight Directory Access Protocol)是什么?它其实是一个开源的.具 ...

  9. [C#] C# 知识回顾 - 你真的懂异常(Exception)吗?

    你真的懂异常(Exception)吗? 目录 异常介绍 异常的特点 怎样使用异常 处理异常的 try-catch-finally 捕获异常的 Catch 块 释放资源的 Finally 块 一.异常介 ...

  10. 彻底搞懂Javascript的“==”

    本文转载自:@manxisuo的<通过一张简单的图,让你彻底地.永久地搞懂JS的==运算>. 大家知道,==是JavaScript中比较复杂的一个运算符.它的运算规则奇怪,容让人犯错,从而 ...

随机推荐

  1. IDEA中基于SSM框架进行web开发部署项目到Tomcat时报错:Error:Cannot build artifact '******:war exploded' because it is included into a circular depency的解决办法

    在Idea中使用Maven创建父子工程,第一个Model的那个项目可以很好的运行,在创建一个Model运行时报这个错.原因是tomcat部署了多个Web项目,可能最开始是两个项目的配置文件混用用,最后 ...

  2. Android SELinux 权限问题总结

    SELinux TE 添加权限不生效的解决方法==============================================selinux security level引起的denied ...

  3. 编译树莓派Linux内核

    1.建议边看视频边跟着教程走 https://www.bilibili.com/video/av91990721?zw 2.准备工作 下载官方提供的交叉编译工具链 git clone https:// ...

  4. Mysql连接报错排查解决记录

    Mysql连接报错排查解决记录 背景: 系统:uos server-1060e ​ 运行环境kvm虚拟机 ​ mysql版本:5.7.44, for Linux (x86_64) 问题现象: 宿主机重 ...

  5. 性能测试工具_nGrinder

    1. ngrinder-controller-3.4.3.war 放置到tomcat的webapps目录下:2. 启动tomcat;3. 访问地址: http://localhost:8080/ngr ...

  6. SpringBoot 项目模板-摆脱步步搭建

    本文以一个简单的电商订单系统为例,源代码请访问: git clone https://github.com/e-commerce-sample/order-backendgit checkout a4 ...

  7. Mysql存储引擎Innodb和MyISAM的区别

    一.mysql架构 mysql是一个单进程多线程架构的数据库. 二.存储引擎 InnoDB: 支持事务 行锁 读操作无锁 4种隔离级别,默认为repeatable 自适应hash索引 每张表的存储都是 ...

  8. 【Maven】---操作指南

    Maven坐标与依赖 最近想深度学习下maven,找到一本书叫<Maven实战>,这本书讲的确实很好,唯一遗憾的是当时maven教学版本是3.0.0的,而目前已经到了3.5.4了,版本存在 ...

  9. LeetCode 未验证规则

    1. for循环容易忘记break,很多提交不过,都是因为这个 2. 左右指针,思考起来比较复杂,但是以代码容易理解.code精简为主,不要在乎省下一两次运算时间 3. 左右指针,有时候以left & ...

  10. RockyLinux9编译安装MySQL8

    Linux版本: Rocky Linux release 9.5 (Blue Onyx) 1.下载 打开MySQL-Community-Server官方下载页面:https://downloads.m ...