Generate Ssl Key Pair Linux
Today we will discuss how to generate a self-signed SSL certificate on Linux. SSL is on a lot of people’s minds today. With free Let’s Encrypt certificates becoming extremely common, there’s no reason for anyone to not use SSL – not to mention the search ranking benefits, and the fact that browsers will trust your site.
However, you can also create your own self-signed SSL certificate for private use on your server. One big reason to do this is encryption. While your personal certificate won’t mean anything to browsers, and visitors will still get a warning message if they visit your site directly, you can at least be sure that you’re protected against “man-in-the-middle” attacks. A self-signed certificate is a good first step when you’re just testing things out on your server, and perhaps don’t even have a domain name yet.
So here’s a step by step procedure on how to create a self-signed SSL certificate on Linux.
Step 1: Create an RSA Keypair
While Encrypting a File with a Password from the Command Line using OpenSSL is very useful in its own right, the real power of the OpenSSL library is its ability to support the use of public key cryptograph for encrypting or validating data in an unattended manner (where the password is not required to encrypt) is done with public keys. For server.key, use openssl rsa in place of openssl x509. The server.key is likely your private key, and the.crt file is the returned, signed, x509 certificate. If this is for a Web server and you cannot specify loading a separate private and public key: You may need to.
Openssl generate rsa 2048 key. The first step is to use the “openssl” package on Linux/CentOS to create an RSA key pair. To do this, make sure that you have the package installed. If not, install it with:
Chances are that you already have it available on your system. If so, generate the key/pair using the following command:
This command uses 2048 bit encryption and outputs a file called “keypair.key” as shown here:
As you can see, the key has been generated and placed in the current directory.
Step 2: Extract the Private Key into an “httpd” Folder
The “/etc/httpd” folder is where the system keeps all the important SSL related stuff. So first, let’s create a new folder to hold all the files relating to our private key:
I’ve called the folder “httpscertificate” and will refer to it for all the other command line examples.
To extract the private key from the keypair file that we just created, type in the following:
Replace the section in bold with the IP address of your own server. Or if you’re able to access your site with a domain name, you can use that as well.
This will create a “key” file in the folder that we just created. And when that’s done, we can delete the original keypair file:
Generate Ssl Key Linux
Step 3: Creating a “Certificate Signing Request” or CSR File
With the key, we can create a special “csr” file that we can either sign ourselves or submit to a “Certificate Authority”. It’s in a standardized format. To create it, type the following command:
Again, replace the items in bold with the IP address or domain name that you settled on in step 2. When you run this command, the tool will ask you for a bunch of personal information:
Download google maps app on mac os. A CA can use these details to verify that you are indeed who you say you are. Fill up as much information as you can.
Once you’ve finished entering these details, the tool will wrap up its work and place a “csr” file in the directory we created for just this purpose.
Step 4: Creating the Certificate “.crt” File
With the CSR, we can create the final certificate file as follows:
This creates a “crt” file along with all the others. Here’s a screenshot of the final files in our security folder:
Openssl Generate Private Key
Now we need to tell Apache where these files are.
Step 5: Configuring Apache to Use the Files
First, we need to install the “mod_ssl” package with the command:
Once done, this will place a “ssl.conf” file inside the /etc/httpd/conf.d/ folder. We need to modify this default file:
Now scroll down till you find the lines starting with:
Change the default paths with the paths to the certificate file and key file respectively as shown here:
Save your changes. Now just restart Apache with:
And you’re done! When Apache restarts, it will be configured to allow SSL connections.
When you connect to your IP address via HTTPS the next time, you’ll be warned that it’s not a trusted certificate:
That’s ok. We know this since we signed it ourselves! Just proceed and it’ll take you to the final site:
Here you can see that it’s using the certificate that we created. It’s not much use for anyone else visiting your site since they can’t verify your identity. But you know it’s safe, and moreover that it’s encrypted. No man in the middle attacks!
If you are one of our Managed VPS hosting clients, we can do all of this for you. Simply contact our system administrators and they will respond to your request as soon as possible.
If you liked this blog post on how to create a self-signed SSL certificate on Linux, please share it with your friends on social media networks, or if you have any question regarding this blog post, simply leave a comment below and we will answer it. Thanks!