第17章 コンテンツの同期の設定
Content Synchronization プラグインを使用すると、Directory Server は RFC 4533 に従って SyncRepl プロトコルをサポートします。このプロトコルにより、LDAP サーバーとクライアントは Red Hat Directory Server をソースとして使用し、ローカルデータベースを Directory Server の変更するコンテンツと同期させることができます。
SyncRepl プロトコルを使用するには、以下を実行します。
- Directory Server で
Content Synchronizationプラグインを有効にし、必要に応じてクライアントが Directory Server にバインドするために使用する新規ユーザーを作成します。アカウントには、ディレクトリー内のコンテンツを読み取るパーミッションが必要です。 - クライアントを設定します。たとえば、同期するサブツリーの検索ベースを設定します。詳細は、クライアントのドキュメントを参照してください。
クライアントが Directory Server に接続できるようにするには、
Content Synchronization プラグインを設定します。
Content Synchronizationプラグインでは、nsuniqueid属性をログに記録するのにRetro Changelogプラグインが必要です。- Retro Changelog が有効になっているかどうかを確認するには、次のコマンドを実行します。
ldapsearch -D "cn=Directory Manager" -W -x -b \ 'cn=Retro Changelog Plugin,cn=plugins,cn=config' nsslapd-pluginEnabled# ldapsearch -D "cn=Directory Manager" -W -x -b \ 'cn=Retro Changelog Plugin,cn=plugins,cn=config' nsslapd-pluginEnabled ... dn: cn=Retro Changelog Plugin,cn=plugins,cn=config nsslapd-pluginEnabled: offCopy to Clipboard Copied! Toggle word wrap Toggle overflow nsslapd-pluginEnabled属性が off に設定されている場合、Retro Changelog は無効になります。有効にする場合は、「Retro Changelog プラグインの有効化」 を参照してください。 nsuniqueid属性を、Retro Changelog プラグインの設定に追加します。Copy to Clipboard Copied! Toggle word wrap Toggle overflow - 必要に応じて、パフォーマンスを向上させるために、以下の推奨事項を適用します。
- Retro Changelog のエントリーの最大有効期間を設定します。たとえば、2 日 (2d) を設定するには、以下のコマンドを実行します。
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - データを同期するバックエンドまたはサブツリーのクライアントアクセスを把握している場合は、
Retro Changelogプラグインのスコープを制限します。たとえば、cn=demo,dc=example,dc=comサブツリーを除外するには、以下を入力します。Copy to Clipboard Copied! Toggle word wrap Toggle overflow
Content Synchronizationプラグインを有効にします。- コマンドラインの使用するには、以下を行います。
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - Directory Server コンソールの使用: 「Directory Server コンソールでプラグインの有効化」 を参照してください。
- デフォルトの Directory Server は、
oid=1.3.6.1.4.1.4203.1.9.1.1,cn=features,cn=configエントリーにアクセス制御命令 (ACI) を作成し、すべてのユーザーがSyncReplプロトコルを使用できるようにします。aci: (targetattr != "aci")(version 3.0; acl "Sync Request Control"; allow( read, search ) userdn = "ldap:///all";)
aci: (targetattr != "aci")(version 3.0; acl "Sync Request Control"; allow( read, search ) userdn = "ldap:///all";)Copy to Clipboard Copied! Toggle word wrap Toggle overflow 必要に応じて、SyncReplコントロールを使用して ACI を制限するように更新します。ACI の詳細は、「バインドルールの定義」を参照してください。 - Directory Server を再起動します。
systemctl restart dirsrv@instance_name
# systemctl restart dirsrv@instance_nameCopy to Clipboard Copied! Toggle word wrap Toggle overflow
クライアントは、
SyncRepl プロトコルを使用して、Directory Server とデータを同期できるようになりました。