ldap实现Linux登录账号统一管理-server

LDAP简介

引用百度百科的简介: http://baike.baidu.com/link?url=XhsDV07AY6vKU1R8cMT_ogt1Wee-QbCOU6HJ-lBTIId3IHn1tYKV0etZEP1xj53iUAmcZQ6zw0a1LOMNOH-9aq

实验环境

一台Centos 6.8 安装ldap server
一台Centos 6.8安装ldap client

ldap server 端安装

修改hosts文件,使IP对应域名

本环境中没有使用dns ,由hosts文件代替
<pre>

本环境中没有使用dns ,由hosts文件代替

echo '192.168.85.129 dev.com' >> /etc/hosts
</pre>

关闭防火墙

<pre>
service iptables stop
chkconfig iptables off
</pre>

关闭selinux

<pre>
setenforce 0
sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/sysconfig/selinux
</pre>

安装ldap server软件
#安装软件
yum install -y openldap openldap-*
#安装nss 模块和用户转换工具
yum install nss-* pcre-*  migrationtools -y
修改ldap 配置文件
#复制配置文件 
cp /usr/share/openldap-servers/slapd.conf.obsolete /etc/openldap/slapd.conf
#备份配置文件
test -e /etc/openldap/slapd.conf.bak || cp /etc/openldap/slapd.conf /etc/openldap/slapd.conf.bak
#编辑ldap配置文件
**vi /etc/openldap/slapd.conf **
将
dc=my-domain,dc=com   修改为  dc=dev,dc=com
cn=Manager,dc=my-domain,dc=com  修改为  cn=admin,dc=dev,dc=com
rootpw    dfadfagwrer234251    #ldapde 管理密码,使用 "slappasswd -s 密码"   工具生产

#在文件最后添加如下内容
loglevel 296   # 定义日志级别
cachesize 1000  #换成条目数
checkpoint 2048 10   #表示内存中达到2048k或者10分钟 ,执行一次checkpoint 即写入数据文件的操作

test -e /etc/rsyslog.conf || cp /etc/rsyslog.conf /etc/rsyslog.conf.bak
**vi  /etc/rsyslog.conf**
local4.*      /var/log/ldap.log

#重启rsyslog 
service rsyslog restart
配置ldap 数据库
cp /usr/share/openldap-servers/DB_CONFIG.example /var/lib/ldap/DB_CONFIG

mv /etc/openldap/slapd.d{,.bak}
chmod 700 /var/lib/ldap/
chown ldap.ldap /etc/openldap/\*
chown ldap.ldap /var/lib/ldap/\*

test -f /etc/openldap/slapd.d/ || mkdir /etc/openldap/slapd.d/
slaptest -f /etc/openldap/slapd.conf -F /etc/openldap/slapd.d/ 
chown -R ldap.ldap /etc/openldap/slapd.d/
chkconfig slapd on 

#启动ldap 服务
service slapd restart
创建一个Test用户

<pre>
useradd test01
echo 'abc'| passwd --stdin test01
</pre>

迁移本地用户数据到ldap 数据库

test -e /usr/share/migrationtools/migrate_common.ph.bak || cp /usr/share/migrationtools/migrate_common.ph /usr/share/migrationtools/migrate_common.ph.bak

sed -i '71d' /usr/share/migrationtools/migrate_common.ph
sed -i '74d' /usr/share/migrationtools/migrate_common.ph
sed -i -e '/DNS/a\$DEFAULT_MAIL_DOMAIN = "dev.com";' /usr/share/migrationtools/migrate_common.ph
sed -i -e '/Turn/i\$DEFAULT_BASE = "dc=dev,dc=com";' /usr/share/migrationtools/migrate_common.ph

#将本地用户
/usr/share/migrationtools/migrate_base.pl >/tmp/base.ldif
/usr/share/migrationtools/migrate_passwd.pl /etc/passwd >/tmp/passwd.ldif
/usr/share/migrationtools/group.pl /etc/group >/tmp/group.ldif

#导入base  ,导入的时候会提示输入ldap管理员的密码 ,就是slapd.conf配置文件中 rootpw  的密码,明文加密都可以
ldapadd -x -D "cn=admin,dc=dev,dc=com" -W -f /tmp/base.ldif
ldapadd -x -D "cn=admin,dc=dev,dc=com" -W -f /tmp/group.ldif
ldapadd -x -D "cn=admin,dc=dev,dc=com" -W -f /tmp/passwd.ldif


ps aux | grep ldap
ldap server端安装脚本:
#!/bin/bash

#关闭防火墙和selinux
service iptables stop
chkconfig iptables off
setenforce 0
sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/sysconfig/selinux

#修改hosts文件,使IP对应域名
echo '192.168.85.129    dev.com' >> /etc/hosts

#安装软件
yum install -y openldap openldap-*
#安装nss 模块和用户转换工具
yum install nss-* pcre-*  migrationtools -y

#配置ldap 配置文件
cp /usr/share/openldap-servers/slapd.conf.obsolete /etc/openldap/slapd.conf
test -e /etc/openldap/slapd.conf.bak || cp /etc/openldap/slapd.conf /etc/openldap/slapd.conf.bak

#ldap 管理密码
pw=`slappasswd -s abc123`

sed -i 's/"dc=my-domain,dc=com"/"dc=dev,dc=com"/' /etc/openldap/slapd.conf
sed -i 's/"cn=Manager,dc=my-domain,dc=com"/"cn=admin,dc=dev,dc=com"/' /etc/openldap/slapd.conf
sed -i -e '/secret/a\rootpw\t'$pw'' /etc/openldap/slapd.conf
cat >> /etc/openldap/slapd.conf<<EOF
loglevel 296
cachesize 1000
checkpoint 2048 10
EOF

test -e /etc/rsyslog.conf || cp /etc/rsyslog.conf /etc/rsyslog.conf.bak
echo '#ldap server log' >> /etc/rsyslog.conf
echo 'local4.* /var/log/ldap.log' >>/etc/rsyslog.conf
service rsyslog restart


#配置ldap数据库

cp /usr/share/openldap-servers/DB_CONFIG.example /var/lib/ldap/DB_CONFIG

mv /etc/openldap/slapd.d{,.bak}
chmod 700 /var/lib/ldap/
chown ldap.ldap /etc/openldap/*
chown ldap.ldap /var/lib/ldap/*

test -f /etc/openldap/slapd.d/ || mkdir /etc/openldap/slapd.d/
slaptest -f /etc/openldap/slapd.conf -F /etc/openldap/slapd.d/ 
chown -R ldap.ldap /etc/openldap/slapd.d/
chkconfig slapd on 
service slapd restart


#test用户
useradd test01
echo 'abc'| passwd --stdin test01


#迁移用户数据到目录服务数据库
test -e /usr/share/migrationtools/migrate_common.ph.bak || cp /usr/share/migrationtools/migrate_common.ph /usr/share/migrationtools/migrate_common.ph.bak

sed -i '71d' /usr/share/migrationtools/migrate_common.ph
sed -i '74d' /usr/share/migrationtools/migrate_common.ph
sed -i -e '/DNS/a\$DEFAULT_MAIL_DOMAIN = "dev.com";' /usr/share/migrationtools/migrate_common.ph
sed -i -e '/Turn/i\$DEFAULT_BASE = "dc=dev,dc=com";' /usr/share/migrationtools/migrate_common.ph

#将本地用户
/usr/share/migrationtools/migrate_base.pl >/tmp/base.ldif
/usr/share/migrationtools/migrate_passwd.pl /etc/passwd >/tmp/passwd.ldif
/usr/share/migrationtools/group.pl /etc/group >/tmp/group.ldif

#导入base
ldapadd -x -D "cn=admin,dc=dev,dc=com" -W -f /tmp/base.ldif
ldapadd -x -D "cn=admin,dc=dev,dc=com" -W -f /tmp/group.ldif
ldapadd -x -D "cn=admin,dc=dev,dc=com" -W -f /tmp/passwd.ldif

ps aux | grep ldap

为 ldap master 配置 web 管理接口

<pre>

安装依赖的软件服务,并检查

yum -y install httpd php php-ldap php-gd -y
rpm -qa httpd php php-ldap php-gd
</pre>

下载地址:3.7版本
https://www.ldap-account-manager.org/lamcms/
切换目录,将刚才下载的文件上传到此目录。解压,重命名这个软件
cd /var/www/html/

tar zxf ldap-account-manager-3.7.tar.gz

mv ldap-account-manager-3.7/ ldap
备份,重命名,并修改文件内容

cd ldap/config

cp config.cfg_sample config.cfg_sample.bak

cp lam.conf_sample lam.conf_sample.bak

mv config.cfg_sample config.cfg

mv lam.conf_sample lam.conf

sed -i ‘s#cn=Manager#cn=admin#g‘ lam.conf

sed -i ‘s#dc=my-domain#dc=dev#g‘ lam.conf

sed -i ‘s#dc=com#dc=com#g‘ lam.conf     #因为我的域名是 dev.com 所以并不需要这项
chown -R apache:apache /var/www/html/ldap

重启 httpd 服务

/etc/init.d/httpd start

http://IP/ldap
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容