LDIF修改ldap记录或配置示例

1. 添加组织或条目

创建一个Marketing部门,添加一个dn记录:

# cat add_entry.ldif
dn: ou=Marketing, dc=example,dc=com
changetype: add
objectclass: top
objectclass: organizationalUnit
ou: Marketing

dn: cn=Pete Minsky,ou=Marketing,dc=example,dc=com
changetype: add
objectclass: person
objectclass: organizationalPerson
objectclass: inetOrgPerson
cn: Pete Minsky
sn: Pete
ou: Marketing
description: sb, sx
description: sx
uid: pminsky
# ldapmodify -xWD 'cn=admin,dc=example,dc=com' -f add_entry.ldif

或去掉changetype后
# ldapmodify -a -xWD 'cn=admin,dc=example,dc=com' -f add_entry.ldif
# ldapadd -xWD 'cn=admin,dc=example,dc=com' -f add.ldif

2. 修改组织或条目

添加mail属性,修改sn的值,删除一个description属性:

# cat modify_entry.ldif
dn: cn=Pete Minsky,ou=Marketing,dc=example,dc=com
changetype: modify
add: mail
mail: pminsky@example.com
-
replace: sn
sn: Minsky
-
delete: description
description: sx
# ldapmodify -xWD 'cn=admin,dc=example,dc=com' -f modify_entry.ldif
# ldapsearch -xD 'cn=admin,dc=mydomain,dc=net' -b 'ou=People,dc=mydomain,dc=net' -s sub 'objectclass=*' -w mydomain -LLL

3. 重命名条目

dn: cn=Pete Minsky,ou=Marketing,dc=example,dc=com
changetype: modrdn
newrdn: cn=Susan Jacobs
deleteoldrdn: 1

modrdn只允许修改dn最左边的部分,且不能重命名带叶子或分支的子树,如果要将一个用户移动到另一个部门下,只能在新部门创建dn,然后删除旧的dn。

4. 删除组织或条目

LDAP协议只能删除无分支的叶子dn:

# cat delete_entry.ldif
dn: cn=Susan Jacobs,ou=Marketing,dc=example,dc=com
changetype: delete

或
# ldapdelete -xWD "cn=admin,dc=example,dc=com" -h localhost -p 389 "cn=Susan Jacobs,ou=Marketing,dc=example,dc=com"

5. LDIF配置backend

OpenLDAP的配置采用以cn=config为根的目录树的形式组织起来,采用config作为database,默认情况下包括admin或root用户都没有访问权限,需要赋予读写权限,然而赋予修改权限要求首先要提供认证信息,初始化安装后的cn=config是没有credentials

# ldapmodify -Y EXTERNAL -H ldapi:/// -f modify_config.ldif
SASL/EXTERNAL authentication started
SASL username: gidNumber=0+uidNumber=0,cn=peercred,cn=external,cn=auth
SASL SSF: 0
modifying entry "olcDatabase={0}config,cn=config"
ldap_modify: Insufficient access (50)

所以这里不得不手动编辑olcDatabase={0}config.ldif文件,获得最初认证权限(虽然官方不推荐手动修改配置):

# vi /etc/ldap/slapd.d/cn\=config/olcDatabase\=\{0\}config.ldif
olcRootPW: {SSHA}your_slappasswd_secret

重启slapd后(不是说不用重启吗)便可以修改config:

# ldapwhoami -x -D cn=config -W 

修改示例:
# ldapmodify -xWD 'cn=config'
Enter LDAP Password:
dn: olcDatabase={0}config,cn=config
changetype: modify
replace: olcRootDN
olcRootDN: cn=config
-
replace: olcRootPW
olcRootPW: {SSHA}your_slappasswd_secret

modifying entry "olcDatabase={0}config,cn=config"

/etc/ldap/slapd.d/cn=config/olcDatabase={0}config.ldifolcRootDN变成base64加密后的值(两个":")。

最后,如果要在slapd服务未启动的情况下修改配置可以通过以下命令转换成ldif中间文件:

# slapcat -n0 -F /etc/ldap/slapd.d/ > /tmp/config-in-portable-format.ldif
编辑ldif文件后,重新shengc slapd.d目录
# slapadd -n0 -F /tmp/slapd.d -l /tmp/config-in-portable-format.ldif

使用这类命令行工具有助于对 LDAP concept 理解,如果要达到快速配置的效果,可以使用 ldapbrowser 或 Apache Directory Studio图形化工具,特别是 Apache Directory Studio 不仅提供了 LDAP Browser/Editor 的功能,还能编辑LDIF文件和自定义schema,智能提示非常友好。

时间: 2024-09-16 21:00:44

LDIF修改ldap记录或配置示例的相关文章

rxvt一个功能强大的终端配置示例

rxvt 是一个http://www.aliyun.com/zixun/aggregation/17547.html">功能强大的的终端,它占用资源少,启动速度快,很多人都喜欢使用它.所以我在这里介绍一下Debian系统中rxvt中文终端的安装.在 Debian中有很多个rxvt包,可用apt-cache search rxvt命令查询.主要有以下三类,一个就叫rxvt,不支持中文显示:一个叫rxvt-ml,支持GB和BIG5中文编码:还有一个叫rxvt- unicode,支持unicod

execl如何查看最后一次修改的记录信息及修改时间,只有修改后excel文件

问题描述 execl如何查看最后一次修改的记录信息及修改时间,只有修改后excel文件 execl如何查看最后一次修改的记录信息及修改时间,只有修改后excel文件 解决方案 跟踪共享工作簿中的修订 通过修订可以跟踪.维护和显示有关对共享工作簿所做修订的信息. 修订突出显示和详细信息的示例 本文内容 修订概述 打开工作簿的修订 工作时突出显示修订 查看修订 接受或拒绝修订 查看历史记录工作表 Excel 不跟踪或突出显示的修订 关闭工作簿的修订 查看历史记录工作表 在"审阅"选项卡上的

《VMware Virtual SAN权威指南》一3.6 网络I/O控制配置示例

3.6 网络I/O控制配置示例 如前所述,网络I/O控制(NIOC)可以用来保证VSAN群集的通信和I/O传输所需的带宽.只有在vSphere分布式交换机(VDS)中才能配置NIOC,而在VMware标准交换机(VSS)中是不支持的.VDS的确只在某些高版本的vSphere中才提供,不过VSAN已经包含了VDS,而不管你使用的是哪个版本的vSphere. 如果你正在使用的分布式交换机版本早于vSphere版本,为了使用VSAN,我们建议你把它升级到最新版本,虽然vSphere的文档中没有特别指出

《VMware Virtual SAN权威指南(原书第2版)》一3.6 网络I/O控制配置示例

3.6 网络I/O控制配置示例 如前所述,网络I/O控制(NIOC)可以用来保证VSAN群集的通信和I/O传输所需的带宽.只有在vSphere分布式交换机(VDS)中才能配置NIOC,而在VMware标准交换机(VSS)中是不支持的.VDS的确只在某些高版本的vSphere中才提供,不过VSAN已经包含了VDS,而不管你使用的是哪个版本的vSphere.如果你正在使用的分布式交换机版本早于vSphere版本,为了使用VSAN,我们建议你把它升级到最新版本,虽然vSphere的文档中没有特别指出这

Dreamweaver开发ASP实例视频教程(6)修改数据库记录

dreamweaver|教程|视频教程|数据|数据库 本视频教程由本站合作网站陶益数码工作室http://www.ty502.com推出,欢迎大家访问他们的网站. 使用Dreamweaver开发ASP具有不用手工写代码的优点,非常适合初学者建设自己的动态网站.本套教程由我们精心设计奉献给大家,内容包含了文章整站教程.音乐整站教程.图片整站教程.文件上传系统教程.投票系统教程.会员分级管理系统教程和网站后台管理教程等,通过本教程的学习,相信您一定能很快掌握动态网站制作的方法,从代码的枯燥乏味中解脱

H3C交换机802.1x用户的RADIUS AAA方案的一个配置示例

18.6.3  802.1x用户的RADIUS认证.授权和计费配置示例 在802.1x认证中,采用远程RADIUS服务器是最常用的AAA访问控制方式,而且RADIUS服务器不仅可以实现802.1x用户所需的认证,还可对他们进行授权和计费.本示例拓扑如图18-6所示,所采用的RADIUS服务器是广泛应用,由H3C公司开发的iMC系统.现需要实现使用RADIUS服务器对通过交换机接入的802.1x用户进行认证.授权和计费.具体要求如下: l   在接入端口GigabitEthernet1/0/1上对

selfserverpassword-使用过Self service password来修改LDAP用户修改密码

问题描述 使用过Self service password来修改LDAP用户修改密码 因为现在统一用LDAP 做身份统一认证管理,所以现在想做到每个用户能自己自行的修改密码,在baidugoogle很多,可是解决这个根本的原因我查了又查,可是还是有点小问题. 问题贴出来了,求解决啊. 安装的步骤:@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ 安装 Self service password@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@

java 修改ldap后,LDAP中会明文显示密码。要求根据ldap中设置的不同的加密方式,显示密文

问题描述 java 修改ldap后,LDAP中会明文显示密码.要求根据ldap中设置的不同的加密方式,显示密文 java 修改ldap后,LDAP中会明文显示密码.要求根据ldap中设置的不同的加密方式,显示密文 解决方案 http://www.micmiu.com/opensource/java-ldap-demo/

企业内部文件服务器,有什么软件可以记录文件访问、删除、修改的记录?

问题描述 企业内部文件服务器,有什么软件可以记录文件访问.删除.修改的记录? 解决方案 解决方案二:用svn来管理文件吧解决方案三:vss.svn等文件管理软件.解决方案四:可以开启审核,通过日志记录.不过日志可能增长很快.解决方案五:你这个文件服务器的文件,是以什么形式保存的?不同的保存方式有不同的处理方式解决方案六:用SVN就可以了.