How to install Root Certificates on Linux
In this post, I will walk you through the process of installing root certificates on Linux. From placing the certificate in the appropriate directory to finally updating the trusted certificate store.
Whether you’re adding a corporate certificate or a third-party CA, these steps are straightforward and essential for maintaining a reliable Linux environment.
Install Root Certificates on SUSE Linux Enterprise Server and Ubuuntu
To install root certificates in SUSE Linux Enterprise Server, we first need to copy them into the /etc/pki/trust/anchors/ folder.
The same also for intermediate certificates issued by a so called Subordinate CA.
The certificates needs to be in PEM format and the file extension like .pem, .cert or something different, SUSE doesn’t really care about and finally accept all.
For Ubuntu these certificates also needs to be in PEM format but here they need the file extension to be .crt and must be copied to a different path /usr/local/share/ca-certificates.
data:image/s3,"s3://crabby-images/41aee/41aee069f7bc6c979568b750d3597034d9381292" alt=""
Now we need to run the following command, this command also works for Ubuntu.
update-ca-certificates is a program that updates the directory /etc/ssl/certs to hold SSL certificates and generates ca-certificates.crt, a concatenated single-file list of certificates.
Source: https://manpages.ubuntu.com/manpages/xenial/man8/update-ca-certificates.8.html
# sudo update-ca-certificates
data:image/s3,"s3://crabby-images/78f01/78f018352318ca7f8ff46d9d59de12ad29801dd3" alt=""
Below we can check if the certificate was installed successfully in /etc/ssl/certs, also the same in Ubuntu.
# ls /etc/ssl/certs | grep MATRIX
data:image/s3,"s3://crabby-images/6b2c0/6b2c005d5130479b538bc74d06df848630246a41" alt=""
Finally we can also check if the root certificate was installed successfully by using the curl command to connect to a web server and web site which is using a certificate issued by the CA we installed its root certificate.
Looks good!
# curl --verbose https://matrix-ca-1.matrixpost-lab.net/
data:image/s3,"s3://crabby-images/1e113/1e113ff01a5dabe831fa61b02a5f89301faa9dc0" alt=""
Deinstall Root Certificates
To uninstall our previously installed root certificates, we just need to remove them in /etc/pki/trust/anchors and finally run the sudo update-ca-certificates command again.
data:image/s3,"s3://crabby-images/da767/da767d97761ab783e9dbff3aeb1d8a08fb77d9a8" alt=""
We can check if the root certificate was removed successfully by listing all certificates in /etc/ssl/certs and filter for the name.
Looks good and doesn’t find it anymore.
data:image/s3,"s3://crabby-images/6510d/6510da11cdbbc97c2c24af572d248acef24a71ea" alt=""
Finally we can also check if the root certificate was removed successfully by using the curl command again.
data:image/s3,"s3://crabby-images/93832/93832397e9c7bc4f84ab7b8e626d7bf8cf910459" alt=""
Install Root Certificates on Red Hat Linux Enterprise (RHEL), Oracle Linux, CentOS and Fedora
Below I will show this on Red Hat Linux Enterprise (RHEL) 9.4, finally the steps are also the same for Oracle Linux, CentOS and Fedora.
Under /etc/pki/ca-trust/source there is a README file in which the steps are explained. We just need to copy the certificate in PEM or DER file format to the list of CAs trusted on the system.
So we need to copy it to the /etc/pki/ca-trust/source/anchors/ subdirectory and run the update-ca-trust command.
data:image/s3,"s3://crabby-images/d0de4/d0de4f8f9cf8905a2b9cb5ee44ca2b692898215c" alt=""
As also mentioned above in the README file, if your certificate is in the extended BEGIN TRUSTED file format, then place it into the main source/ directory instead.
Extended BEGIN TRUSTED file format means it is encoded with additional metadata such as trust settings, which is used by some systems or tools (like OpenSSL or certain embedded Linux environments). These certificates typically look like this:
-----BEGIN TRUSTED CERTIFICATE----- <Encoded certificate data> <Metadata or trust attributes> -----END TRUSTED CERTIFICATE-----
So I will now copy the root CA from my own on-premise PKI to the /etc/pki/ca-trust/source/anchors/ subdirectory and then run the update-ca-trust command. Further also for the intermediate certificate from my PKI I need to do the same.
# cp MATRIX-ROOT-CA-base64.pem /etc/pki/ca-trust/source/anchors/ # update-ca-trust
data:image/s3,"s3://crabby-images/37e1e/37e1e910bf56f4d7388fc018992ce9c6828bec3b" alt=""
We can also verify whether a CA can be trusted by looking at the anchor value in the trust key:
# trust list --filter=ca-anchors | grep MATRIX -i -A 2 -B 3
data:image/s3,"s3://crabby-images/89035/890359a2fe2fcf3dcbb492e26436e36083313ca0" alt=""
Finally we can also check if the root certificate was installed successfully by using the curl command to connect to a web server and web site which is using a certificate issued by the CA we installed its root certificate.
Looks good!
# curl --verbose "https://matrix-ca-1.matrixpost-lab.net"
data:image/s3,"s3://crabby-images/ffcaf/ffcaf608ace3169338cdbd09a734bc3787a56de6" alt=""
Deinstall Root Certificates
To uninstall our previously installed root certificates, we just need to remove them in /etc/pki/ca-trust/anchors and finally run the sudo update-ca-trust command again.
# sudo rm /etc/pki/ca-trust/source/anchors/MATRIX-ROOT-CA-base64.pem # sudo rm /etc/pki/ca-trust/source/anchors/Matrix-CA-1-base64.pem # sudo update-ca-trust
data:image/s3,"s3://crabby-images/39ea0/39ea09fe508431406d07b4c865c3c37a22585ee6" alt=""
Finally we can also check if the root certificate was removed successfully by using the curl command again.
data:image/s3,"s3://crabby-images/41409/41409927cddb7928dbf1e41a60f508b76a6e5f68" alt=""
Install Root Certificates on Chrome running on Linux
For Linux, Chrome uses its own certificate store. You can import your Root CA’s in Chrome directly.
data:image/s3,"s3://crabby-images/ec56a/ec56a272abb353f701545ccc4986c202a6bedf0e" alt=""
In Chrome open Settings -> Privacy and security -> Security -> Manage certificates -> Authorities
data:image/s3,"s3://crabby-images/58299/58299af8741183eaf8b3122df8ea39f740ba2528" alt=""
data:image/s3,"s3://crabby-images/17a97/17a97fda5f5ce6130a3d6c3918ace66dd8d6d6e5" alt=""
Click on Import and select the desired root certificates.
data:image/s3,"s3://crabby-images/a1e9d/a1e9d15380d1bc2f8e00bd036695ec3bb5729f81" alt=""
Select which Trust settings you want to allow for the CA.
data:image/s3,"s3://crabby-images/9cd6b/9cd6b681452b1a30876b17cdc6163d8cf2dd2925" alt=""
data:image/s3,"s3://crabby-images/81a3a/81a3a38b72448d2399089e6561efe63443a3efd1" alt=""
Looks good!
data:image/s3,"s3://crabby-images/1d9d6/1d9d616c8c640ba76464e09efb3821cf74d323b2" alt=""
About how to set up your own PKI you can also read my following post.
Links
update-ca-certificates
https://manpages.ubuntu.com/manpages/xenial/man8/update-ca-certificates.8.htmlHow to configure your CA trust list in Linux
https://www.redhat.com/en/blog/configure-ca-trust-list