Compare the contents of two LDIF files, the output being an LDIF file needed to bring the source file in sync with the target.
The 'ldif-diff' tool should not be used on very large LDIF files because it stores the contents of each file in memory while computing the difference. The memory used by ldif-diff can be customized by editing the ldif-diff.java-args setting in the config/java.properties file and running dsjavaproperties.
ldif-diff --sourceLDIF actual.ldif --targetLDIF expected.ldif
ldif-diff --sourceLDIF actual.ldif --targetLDIF expected.ldif \ --outputLDIF result.ldif --includeOperational --excludeNoUserModification
-V
--version
Description | Display Directory Server version information |
-H
--help
Description | Display general usage information |
--help-debug
Description | Display help for using debug options |
Advanced | Yes |
-s {file}
--sourceLDIF {file}
Description | LDIF file to use as the source data |
Required | Yes |
Multi-Valued | No |
--sourceEncryptionPassphraseFile {file}
Description | The path to a file that contains the encryption passphrase needed to decrypt the source LDIF file if it is encrypted. If the source LDIF file is encrypted and this argument is not provided, then the tool will interactively prompt for the encryption passphrase. If a passphrase file is provided, then it must contain exactly one line that consists entirely of the passphrase |
Required | No |
Multi-Valued | No |
-t {file}
--targetLDIF {file}
Description | LDIF file to use as the target data |
Required | Yes |
Multi-Valued | No |
--targetEncryptionPassphraseFile {file}
Description | The path to a file that contains the encryption passphrase needed to decrypt the target LDIF file if it is encrypted. If the target LDIF file is encrypted and this argument is not provided, then the tool will interactively prompt for the encryption passphrase. If a passphrase file is provided, then it must contain exactly one line that consists entirely of the passphrase |
Required | No |
Multi-Valued | No |
-o {file}
--outputLDIF {file}
Description | File to which the output should be written |
Required | No |
Multi-Valued | No |
--compressOutput
Description | GZIP-Compress the data written to the output LDIF file |
--encryptOutput
Description | Encrypt the data written to the output LDIF file. If the --targetEncryptionPassphraseFile argument is provided, then that passphrase will be used to encrypt the data; otherwise, the tool will interactively prompt for the passphrase |
--outputEncryptionPassphraseFile {file}
Description | The path to a file that contains the encryption passphrase needed to encrypt the output LDIF file if the --encryptOutput argument is provided. If the output is to be encrypted but no passphrase file is provided, then the tool will interactively prompt for the passphrase. If a passphrase file is given, then it must contain exactly one line that consists entirely of the passphrase |
Required | No |
Multi-Valued | No |
-O
--overwriteExisting
Description | Any existing output file should be overwritten rather than appending to it |
-i
--includeOperational
Description | Operational attributes will also be compared in addition to user attributes |
-e
--excludeNoUserModification
Description | Attributes marked with the NO-USER-MODIFICATION option in the schema will be excluded from comparison |
-S
--singleValueChanges
Description | Each attribute-level change should be written as a separate modification per attribute value rather than one modification per entry |
--stripTrailingSpaces
Description | Strip out any illegal trailing spaces contained in entries rather than rejecting those entries |