AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 499856
Accepted
HVNSweeting
HVNSweeting
Asked: 2013-04-17 07:05:55 +0800 CST2013-04-17 07:05:55 +0800 CST 2013-04-17 07:05:55 +0800 CST

如果我手动更改 /etc/ldap/slapd.d/cn=config.ldif 是否会发生任何不好的事情?

  • 772

从 2.3 开始,OpenLDAP 使用名为 slapd-config 的配置引擎。他们说使用它可以即时更改所有 LDAP 配置。

这是 /etc/ldap/slapd.d/cn=config.ldif 的标题:

# AUTO-GENERATED FILE - DO NOT EDIT!! Use ldapmodify.

我已经更改了其中的数据和其他一些具有该标头的文件,在重新启动 slapd 后,我的更改生效了。

如果我手动更改这些文件,还会发生其他情况吗?如果我不需要“即时更改”,我应该手动编辑这些文件而不是使用 ldapmodify 吗?哪个应用程序生成了这些文件,什么时候生成的?

注意:我在 Ubuntu 12.04 上使用 openldap-2.4.28

ubuntu
  • 2 2 个回答
  • 11467 Views

2 个回答

  • Voted
  1. Best Answer
    Samuli Seppänen
    2013-06-28T00:49:57+08:002013-06-28T00:49:57+08:00

    如果您手动更改 cn=config 中的 LDIF 文件,它们的内容和校验和将不匹配,这不是致命的,但在使用slapcat等工具时会很烦人。

    使用ldapmodify以正确的方式修改 cn=config是非常痛苦的,您最终会积累大量手工精心制作的、单一用途的一次性 LDIF 文件。与仅仅编辑 slapd.conf 相比,这是一场噩梦。无论如何,如果您需要更改运行时配置,ldapmodify是您唯一的选择。但是,如果您能承受一些停机时间,您还有另外两种毒药可供选择。

    首先,如果您知道自己在做什么,则有一种不受支持但快速且肮脏的方法,它适用于初始 OpenLDAP 配置:

    $ service slapd stop
    $ cp -a /etc/ldap/slapd.d /etc/ldap/slapd.d.old
    <edit the LDIF files in /etC/ldap/slapd.d>
    $ service slapd start
    

    如果 slapd 启动,它应该可以正常工作,但在启动服务时跟踪 /var/log/syslog总是一个好主意:

    $ tail -n 0 -f /var/log/syslog|grep slapd
    

    您可以使用slapcat和slapadd修复校验和错误,如下所述。

    其次,有一种不太受支持的方法涉及使用slapcat和slapadd(根据这些说明修改):

    $ slapcat -n0 -F /etc/ldap/slapd.d > config.ldif
    <edit config.ldif>
    $ mkdir /etc/ldap/slapd.d.new
    $ slapadd -n0 -F /etc/ldap/slapd.d.new -l config.ldif
    

    如果 slapadd 成功且没有错误,您可以迁移到修改后的 slapd.d 目录。根据这个线程 slapadd只添加数据,所以覆盖原来的 slapd.d 目录内容是不可能的。因此我们需要稍微移动一下目录:

    $ service slapd stop
    $ mv /etc/ldap/slapd.d /etc/ldap/slapd.d.old
    $ mv /etc/ldap/slapd.d.new /etc/ldap/slapd.d
    $ chown -R openldap:openldap /etc/ldap/slapd.d
    $ service slapd start
    

    这两个或多或少不受支持的方法使 cn=config 的生活稍微更容易忍受。

    • 11
  2. voretaq7
    2013-04-17T07:39:22+08:002013-04-17T07:39:22+08:00

    当你看到一个文件说

    # AUTO-GENERATED FILE - DO NOT EDIT!! Use ldapmodify.
    

    您最好按照有关如何正确更改该文件内容的说明进行操作。

    在这种情况下,这意味着根据 OpenLDAP 手册使用命令更新 OpenLDAP 配置。ldapmodify
    这允许您即时将更改应用到 OpenLDAP 配置,并将重新生成slapd.conf文件(在启动 LDAP 服务器时作为引导配置使用)


    一般来说,不遵守指示(例如“不要编辑此文件,因为它是自动生成的!”)会导致痛苦和折磨。

    在这种特殊情况下,你可能会发现你对文件的更改在下次有人以正确的方式做事时被清除,你将不得不重建你的配置(可能没有它的记录,因为你编辑的文件将是更换)。
    下次您不注意这样的警告时,您可能会导致系统无法启动,甚至更糟。

    • -1

相关问题

  • 无法通过 Ubuntu VPN 访问外部网络

  • ubuntu apt-get upgrade - 如何在 shell 中单击确定?

  • VirtualBox 上 Ubuntu 的访客优化技巧 [关闭]

  • 外部硬盘上的 virtualbox 虚拟硬盘驱动器(Vista 主机上的 ubuntu 客户机)

  • 如何在 Ubuntu 上挂载 LVM 分区?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve