Shell's Home

Jun 30, 2015 - 1 minute read - Comments

hosts配错导致ldap安装问题一例

不废话了,要装ldap。

ubuntu下,最简单的方法是修改/etc/hosts,添加自己的域名,例如ldap.shell909090.org。然后安装包的时候,就会使用dc=shell909090,dc=org作为basedn。里面自动添加一个admin。

结果在某机器上,丫硬是一直管自己叫nodomain。

当然,内容可以后改。但是很麻烦。先要删除原始的,添加新的。还有一堆杂七杂八的问题。关键是,为啥TMD这么简单一个问题我居然搞不定。

方法1

绕过。

怎么绕?

经过检查发现,basedn这些东西,其实都是从debconf里读的,而不是直接来自系统。所以我可以重设debconf来修改配置。

echo slapd slapd/domain string shell909090.org | debconf-set-selections
echo slapd shared/organization string shell909090.org | debconf-set-selections

然后再安装,就全部正确了。

方法2

为什么?

检查同样发现了本质的原因。如果debconf里没有配,则去读取hostname -d。在一台机器上,这个配置没事,另一台就不行。

经过我反复测试,发现原因是这样的。

hostname -d读取域名的时候,是寻找/etc/hostname对应的域名作为行尾的那行,而不是127.0.0.1所在的那行。。。

而出问题的那台机器,/etc/hosts配置和没问题的那台严格一致。包括机器编号!

谁TM抄卷子把名字也抄了?