Ce contenu n'est pas disponible dans la langue sélectionnée.
Chapter 22. Migrating From Certificate System 8 to 9
			Red Hat Certificate System does not support in-place upgrades from an older major version, such as from 8.2 to 9. For major version upgrades, you must migrate the old instance. Additionally, you can use the same procedure to create a copy of your production environment for testing and debugging purposes.
		
Important
				Before migrating, read the Red Hat Certificate System Release Notes.
			
			A Certificate System migration requires the following steps:
		
22.1. Exporting Data from the Previous System
Copier lienLien copié sur presse-papiers!
				Before you set up the new Certificate System instance, export the data of the current certificate authority (CA).
			
				On the host that runs the Certificate System instance:
			
- Create a directory for the files to export. For example:mkdir -m 770 /tmp/cs_bak/ # mkdir -m 770 /tmp/cs_bak/Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Export the signing certificate and key:- When using a hardware security module (HSM):- List the CA signing certificate nickname. For example:grep ca.cert.signing.nickname /etc/pki/instance_name/ca/CS.cfg # grep ca.cert.signing.nickname /etc/pki/instance_name/ca/CS.cfg ca.signing.nickname=<nickname>Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Export the CA certificate:certutil -L -d /var/lib/pki/instance_name/alias/ \ -n <nickname> \ -a > /tmp/cs_bak/ca_signing.crt# certutil -L -d /var/lib/pki/instance_name/alias/ \ -n <nickname> \ -a > /tmp/cs_bak/ca_signing.crtCopy to Clipboard Copied! Toggle word wrap Toggle overflow The key is stored in the HSM and must be available to the new instance.
 
- When not using an HSM:- In the configuration file, find the password that protects the CA Network Security Service (NSS) database, and write it to a file:grep "internal=" /var/lib/pki/instance_name/conf/password.conf | \ awk -F= '{print $2;}' > /tmp/cs_bak/nss_password.txt# grep "internal=" /var/lib/pki/instance_name/conf/password.conf | \ awk -F= '{print $2;}' > /tmp/cs_bak/nss_password.txtCopy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Create a file with a password that will be used in the next step. For example:echo Secret123 > /tmp/cs_bak/pkcs12_password.txt # echo Secret123 > /tmp/cs_bak/pkcs12_password.txtCopy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Export the signing certificate and key:PKCS12Export -d /var/lib/instance_name/alias/ \ -p /tmp/cs_bak/nss_password.txt \ -w /tmp/cs_bak/pkcs12_password.txt \ -o /tmp/cs_bak/ca.p12# PKCS12Export -d /var/lib/instance_name/alias/ \ -p /tmp/cs_bak/nss_password.txt \ -w /tmp/cs_bak/pkcs12_password.txt \ -o /tmp/cs_bak/ca.p12Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
 
 
- Export the certificate signing request (CSR):Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
- If the CA is an intermediate CA, extract the root CA or certificate chain from the NSS database:certutil -L -d /var/lib/pki/instance_name/alias/ -n "root_CA_nickname" \ -a > /tmp/cs_bak/ca_rootca_signing.crt# certutil -L -d /var/lib/pki/instance_name/alias/ -n "root_CA_nickname" \ -a > /tmp/cs_bak/ca_rootca_signing.crtCopy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Copy the directory that contains the exported files to the new server. For example:scp -r /tmp/cs_bak/ new_server:/tmp/ # scp -r /tmp/cs_bak/ new_server:/tmp/Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Find the name of the CA database in the Directory Server:grep internaldb.database /etc/pki/instance_name/ca/CS.cfg \ internaldb.database=<CS_database_name> # grep internaldb.database /etc/pki/instance_name/ca/CS.cfg \ internaldb.database=<CS_database_name>Copy to Clipboard Copied! Toggle word wrap Toggle overflow This name is needed to export the database later.
				On the host that runs the Directory Server instance:
			
- Create a directory for the files to export, and grant write permissions to the Directory Server user. For example:mkdir -m 770 /tmp/ds_bak/ chown root:dirsrv /tmp/ds_bak/ # mkdir -m 770 /tmp/ds_bak/ # chown root:dirsrv /tmp/ds_bak/Copy to Clipboard Copied! Toggle word wrap Toggle overflow Note The db2ldif command runs under the Directory Server user (e.g. dirsrv). Therefore the destination directory must be writable by this user.
- Export the Directory Server database:db2ldif -Z<DS_instance_name> -n <CS_database_name> -a /tmp/ds_bak/old_ca.ldif # db2ldif -Z<DS_instance_name> -n <CS_database_name> -a /tmp/ds_bak/old_ca.ldifCopy to Clipboard Copied! Toggle word wrap Toggle overflow In the example:- DS_instance_nameis the Directory Server instance name used by the CA. For example:- slapd-host_name.
- CS_database_nameis the name of the CA database obtained earlier.
 
- Copy the directory that contains the exported files to the new server. For example:scp -r /tmp/ds_bak/ new_server:/tmp/ # scp -r /tmp/ds_bak/ new_server:/tmp/Copy to Clipboard Copied! Toggle word wrap Toggle overflow