1.2. 在服务器离线时使用命令行导入数据
如果 Directory 服务器实例离线,请使用 dsctl ldif2db 命令导入数据。
警告
当您启动导入操作时,目录服务器首先从数据库中删除所有现有数据,然后从 LDIF 文件中导入数据。因此,如果导入失败,服务器不会返回条目或部分条目集合。
先决条件
-
LDIF 文件权限允许
dirsrv用户读取该文件。 - 要导入的 LDIF 文件包含 root 后缀条目。
- 要导入数据的后缀及其数据库存在于目录中。
- 目录服务器实例没有运行。
- 要导入的 LDIF 文件使用 UTF-8 字符集编码。
流程
可选:默认情况下,Directory 服务器将所有导入的条目序列号(USN)设置为 0。
要设置替代的 initial USN 值,请设置nsslapd-entryusn-import-initval参数。例如,要将所有导入的值的 USN 设置为12345,请输入:# dsconf -D "cn=Directory Manager" ldap://server.example.com config replace nsslapd-entryusn-import-initval=12345如果要将要导入的文件复制到
/var/lib/dirsrv/slapd-instance_name/ldif/,请在该文件中重置 SELinux 上下文:# restorecon -Rv /var/lib/dirsrv/slapd-instance_name/ldif/example.ldif使用
dsctl ldif2db命令从 LDIF 文件中导入数据。例如,要将/var/lib/dirsrv/slapd-instance_name/ldif/example.ldif文件导入到userRoot数据库中:# dsctl instance_name ldif2db userRoot /var/lib/dirsrv/slapd-instance_name/ldif/example.ldif OK group dirsrv exists OK user dirsrv exists [17/Jul/2021:13:42:42.015554231 +0200] - INFO - ldbm_instance_config_cachememsize_set - force a minimal value 512000 ... [17/Jul/2021:13:42:44.302630629 +0200] - INFO - import_main_offline - import userRoot: Import complete. Processed 160 entries in 2 seconds. (80.00 entries/sec) ldif2db successful-
搜索
/var/log/dirsrv/slapd-instance_name/errors日志在导入过程中出现问题。 可选:启动实例:
# dsctl instance_name start
验证
搜索导入的后缀下的条目,如
dc=example,dc=com:# ldapsearch -D "cn=Directory Manager" -W -H ldap://server.example.com -b "dc=example,dc=com" -s sub -x