This post is mostly sourced from https://techcommunity.microsoft.com/t5/itops-talk-blog/step-by-step-migrating-active-directory-certificate-service-from/ba-p/2328766, along with some helpful notes, screenshots, and code samples from my own experience. It’s mostly here for my own documentation purposes.
Backup the CA
data:image/s3,"s3://crabby-images/dc651/dc65116d4413eb334eab07acf3202f06bd259edc" alt=""
Select backup options
data:image/s3,"s3://crabby-images/a6503/a6503b2f309c76fb1d2bf206efc68c6934c7e374" alt=""
Generate and save a secure password
data:image/s3,"s3://crabby-images/425f0/425f0a00041ad13688f2fc1ac4d94d92e2b6511f" alt=""
Click Finish
data:image/s3,"s3://crabby-images/7a535/7a53596b95b6d52c3337f3ff552eb56cb0c00e71" alt=""
Export CA Registry Settings
data:image/s3,"s3://crabby-images/f74a8/f74a8df12326008c2bf943b5e798f988336bdb60" alt=""
data:image/s3,"s3://crabby-images/6db16/6db161ba5d3413c99966acef39466c1c1158a950" alt=""
Copy the backup files to the new server
data:image/s3,"s3://crabby-images/6228b/6228b95ac8a8dbc5c3a4d78fd172bb1553a9d17f" alt=""
Uninstall ADCS roles and restart the server
1 2 3 4 |
Remove-WindowsFeature -Name ADCS-Web-Enrollment -Confirm:$false Remove-WindowsFeature -Name ADCS-Online-Cert -Confirm:$false Remove-WindowsFeature -Name ADCS-Cert-Authority -Confirm:$false Restart-Computer |
Move alternative name (if in use) from old server to new server
1 |
netdom computername OLDCA.ad.domain.tld /remove PKI.ad.domain.tld |
1 2 |
netdom computername NEWCA.ad.domain.tld /add PKI.ad.domain.tld ipconfig /registerdns |
Install AD CS Roles on New Server
data:image/s3,"s3://crabby-images/b5e0d/b5e0d3f2fe3656ed4411adc2af5ba26f56e8c28b" alt=""
Configure the CA (remember to log in with Enterprise Admin credentials)
data:image/s3,"s3://crabby-images/55230/55230e7221b84d4d71d8205744239d51856a7b56" alt=""
data:image/s3,"s3://crabby-images/f52c9/f52c9cc7dafa918c051bb5cd04102b0bb83a55c3" alt=""
data:image/s3,"s3://crabby-images/f74ca/f74cab2d5597e0acb0ced7fc54cbfb419d33790e" alt=""
data:image/s3,"s3://crabby-images/8e64c/8e64c15c23884e25111ffb43fa09615e86e6cd2a" alt=""
data:image/s3,"s3://crabby-images/c7cce/c7cced88e9dea3c113ca3910d8726a5841ec614f" alt=""
data:image/s3,"s3://crabby-images/6ff2c/6ff2cea9e2e5084005b002e45fe31540190d98c6" alt=""
data:image/s3,"s3://crabby-images/32afe/32afeb9b7de7217a009ab4089692573775f68522" alt=""
data:image/s3,"s3://crabby-images/9114b/9114b8c4ecc469edb2c61cb18aea5ce0aee01261" alt=""
data:image/s3,"s3://crabby-images/46bfe/46bfe0a019f50d09ec449b4605b4d99894978b6b" alt=""
Restoring the CA Backup
Stop the CA service
1 |
Stop-Service -Name CertSvc |
Edit the registry backup and update the WebClientCAMachine
and CAServerName
values
data:image/s3,"s3://crabby-images/b5d6e/b5d6ee98fcf54bb46bd588eed7d3b7602a517263" alt=""
data:image/s3,"s3://crabby-images/6fb21/6fb212b0790b4e5d0093d581cc3b763ae188694a" alt=""
Restore the CA backup
data:image/s3,"s3://crabby-images/4619b/4619bde3e86cfd59d7bbeb8f39c8ba9624648ead" alt=""
data:image/s3,"s3://crabby-images/40813/408132f80bfc8702deb025c79aa49bda6aacb4ce" alt=""
data:image/s3,"s3://crabby-images/a75af/a75af21fb76f4dee01e75778f892cccae6e9c3f6" alt=""
Import the registry backup, and restart ADCS again
1 2 |
reg import .\CA_Backup.reg Restart-Service -Name CertSvc |
Unpublish default templates and publish custom templates
data:image/s3,"s3://crabby-images/39060/39060fcb274d5fd8c508e24529c06398f9b1ee56" alt=""
Enable Directory Browsing for CertEnroll directory in IIS
data:image/s3,"s3://crabby-images/ffe9c/ffe9c189c3a118be3f55382a434d19cbc257ab50" alt=""
Copy over previous AIA files from old CA (unsure if actually needed, but easy enough to do)
data:image/s3,"s3://crabby-images/dc91f/dc91f3283fb78922c87bce9318d56ea0a2f014fc" alt=""
Verify the new CDP can be accessed internally and externally via AAD App Proxy
data:image/s3,"s3://crabby-images/a9552/a9552b54883206cc14d8fb16e660933a82aacd6c" alt=""
Use pkiview.msc to verify CDP/AIA is valid (note, OCSP will be in an error state until reinstalled)
data:image/s3,"s3://crabby-images/a8535/a85359db0b901b9a703acc92e00da4a9d0b2b4f9" alt=""
Use certutil from a client to also verify CDP validity
1 |
certutil -url http://pki.corp.ajf.one/CertEnroll/AJF.ONE%20CORP%20SIGNING%20CA.crl |
data:image/s3,"s3://crabby-images/01d56/01d56ae6caf106ec1a1b815759d33a2216aba5fb" alt=""
Reinstalling OCSP
data:image/s3,"s3://crabby-images/405d1/405d1dd46d05a4e56083b6b448466413fb1f7c12" alt=""
data:image/s3,"s3://crabby-images/43969/439693f650b391a4b928875003919201e01e65b8" alt=""
Reconfiguring OCSP
data:image/s3,"s3://crabby-images/8960d/8960d964ea700c0e9bc541faf0ea19755b03151e" alt=""
data:image/s3,"s3://crabby-images/78120/781208be65b8dc2bc568dfa7ba862a7fba858457" alt=""
data:image/s3,"s3://crabby-images/ce9ed/ce9ed276d5b4747efd75b86f814b4391aa7587fd" alt=""
data:image/s3,"s3://crabby-images/8e0ff/8e0ff520ebb65a41362ec26efbdbe300e4c212cc" alt=""
data:image/s3,"s3://crabby-images/3956c/3956c336c263c60d01f40b92aef7e06007aa4d5f" alt=""
data:image/s3,"s3://crabby-images/78d52/78d52fc9e426ca3254b44ed5ace386755a6b90e7" alt=""
data:image/s3,"s3://crabby-images/b284c/b284c8d9a43d235993c8f07d77cb25469ae2a44a" alt=""
data:image/s3,"s3://crabby-images/a8f35/a8f3516ee8de9c5f9a42a28ae450aa725b0bdec6" alt=""
Verify OCSP Configuration
data:image/s3,"s3://crabby-images/3f130/3f130ddf15020093f4eb67d19126c824a18e15a1" alt=""
If the OCSP application does not appear in IIS, run the following to recreate it
1 |
certutil -vocsproot |
Validating everything via pkiview.msc
data:image/s3,"s3://crabby-images/f4178/f4178ee65d17f1c2d38717a105eedfb20a786de9" alt=""
Export a local cert and verify it via OCSP with certutil -url
data:image/s3,"s3://crabby-images/f952a/f952ab08b6a8ed955e3b46b588b120e0bf2523bf" alt=""
Congratulations! You’re done!
What is the behavior of the existing clients pointing to an existing OCSP responder, but was migrated to a new host? The existing machines pick up the new OCSP responder automatically or is there a manual process for updating them?
In my labs, I use an alias name for my CRL/AIA information, so in migrating the CA to a new host, the alias moves with it, and the OCSP responder continues to function as expected. If it moves to a new name, the CA configuration would need to be updated and new leaf certificated issued to endpoints to utilize the new responder before the old responder could be retired.