In this tutorial I will show you how to configure free, auto-renewing SSL certificates for WordPress websites that are hosted on Google Cloud Platform using the Bitnami version of WordPress on Google Cloud Platform.
Having SSL Security on your website will improve your Google search ranking.
Luckily for you, this step-by-step tutorial is super easy to follow. All you have to do is follow along with the video as I install an SSL certificate for my domain eborchids.com.
Before getting started with this tutorial, you should have already installed WordPress on Google Cloud Platform, and set up a domain name for your WordPress website.
So let’s get started.
There are 9 steps in this tutorial:
-
1. Connect to WordPress via SSH
-
2. Install Git
-
3. Install CertBot Client
-
4. Generate Certificates
-
5. Setup Certificate Auto-Renewal
-
6. Configure the Certificates
-
7. Update Domain URLs
-
7. Restart your Apache Server
-
8. Test your Configuration
1. Connect to WordPress via SSH
data:image/s3,"s3://crabby-images/4c7c8/4c7c8dc0354189a787fbf597b2ed301a9de73b8f" alt="ssl certificates wordpress on google cloud access menu"
Go to your Google Compute homepage and click the hamburger menu in the upper left-hand corner.
data:image/s3,"s3://crabby-images/b4b5b/b4b5b6c95a12a755c060186bae857250c7c6516c" alt="ssl certificate for wordpress on google cloud go to compute engine then vm instances"
Go to your Compute Engine, then to VM instances to access your WordPress installation.
data:image/s3,"s3://crabby-images/7e0dd/7e0dd358f7f7e2b7e01b99434a25cb071f99c830" alt="ssl certificate setup for wordpress on google cloud"
Once inside your Compute Engine, click on the SSH button to connect to your WordPress installation.
2. Install Git
data:image/s3,"s3://crabby-images/b76b6/b76b6d408e2684bedb3220b13014da688e53fef0" alt="ssl certificate setup for wordpress on google cloud"
Once you’ve connected to your instance, we will run the commands below to tell Apache to install Git. The Sudo -i command will put you in root mode, and the apt-get command will tell Apache to download Git. Press “ENTER” after entering each command.
sudo -i
sudo apt-get install git-all
3. Install CertBot Client
data:image/s3,"s3://crabby-images/edfc2/edfc2494d4eccb93650d78954da6c54728c6489c" alt="download certbot command ssl certificate setup for wordpress on google cloud"
Now that you’ve installed Git, we will enter the “cd /tmp” command to navigate to our temporary file directory. Next, we will run the “git clone …” command to download the certbot files.
cd /tmp
git clone https://github.com/certbot/certbot
After running each of these commands, you can stay in the same SSH window or exit and open a new one.
4. Generate Certificates
data:image/s3,"s3://crabby-images/4cec0/4cec021c1bd871b91b068f6800c96bf669e35e6a" alt="change to certbot director, then enter webroot and domain name ssl certificate setup wordpress on google cloud"
In this step, we are going to generate our certificates. Based on the picture, figure 1 represents the command to access your certbot directory. Figures 2 and 3 are part of one command, where 2 is the path to your website’s root directory, and 3 is your website’s domain name.
cd /tmp/certbot
./certbot-auto certonly --webroot -w /opt/bitnami/apps/wordpress/htdocs/ -d eborchids.com -d www.eborchids.com
data:image/s3,"s3://crabby-images/e0b3b/e0b3bb12ced396e47e596d7aa74ae165e5007d86" alt="the directory where your certificates are installed ssl certificate setup for wordpress on google cloud"
After entering these commands, your certificates will be generated. Take note of the directory where your certificates are installed.
5. Setup Certificate Auto-Renewal
data:image/s3,"s3://crabby-images/e2a9f/e2a9fab9d616397edff866721497959f0dfd49c4" alt="auto-renew function for ssl certificates setup for wordpress on google cloud"
Before setting up auto-renewal for our certificates, we are first going to run the function below in order to test the auto-renew function.
cd /tmp/certbot/
./certbot-auto renew --dry-run
data:image/s3,"s3://crabby-images/79ac8/79ac8f07d14e270f4477deb156900fdbf5dd6706" alt="use chrontab to automatically renew certificate ssl setup for wordpress on google cloud"
Next, we will use the crontab command to set a schedule for checking for renewals. Then, we will enter 1 to choose nano as our text editor.
crontab -e
1
data:image/s3,"s3://crabby-images/f354b/f354b10d0f66dec69dc461503960b7844d84d7a3" alt="command to call for auto-renewal ssl certificate setup for wordpress on google cloud"
Next, we will enter a command that tells the server to check for certificate renewals two times per day. After entering the command, press ctrl+o to save changes to the file.
0 0 * * * cd && ./certbot-auto renew --quiet --no-self-upgrade
0 12 * * * cd && ./certbot-auto renew --quiet --no-self-upgrade
6. Configure the Certificates
data:image/s3,"s3://crabby-images/f10bd/f10bdda0e355f869cd17dd9d7bf8b91725b79854" alt="edit bitnami wordpress configuration file ssl certificate setup for wordpress on google cloud"
The next step is to configure your certificates. We will run the first command to enable root access, then the second command to edit our bitnami configuration file.
sudo -i
nano /opt/bitnami/apache2/conf/bitnami/bitnami.conf
data:image/s3,"s3://crabby-images/13baf/13baf1f742707a46330384f8cef6406b61a97733" alt="configure ssl certificates wordpress on google cloud bitnami"
Now that we've entered the Bitnami configuration file, deactivate the existing certificates by placing a # next to them. Below, copy your new certificate paths and paste them into the file with shift+insert.
SSLCertificateFile "/etc/letsencrypt/live/eborchids.com/cert.pem"
SSLCertificateKeyFile "/etc/letsencrypt/live/eborchids.com/privkey.pem"
SSLCertificateChainFile "/etc/letsencrypt/live/eborchids.com/chain.pem"
data:image/s3,"s3://crabby-images/81612/81612dbaa85ce614c81b1f891dec499ec2b2a143" alt="rewrite file to serve https google cloud setup wordpress on google cloud"
Next, we need to paste the following 3-lines of code below the VirtualHost_default_:80 section of the bitnami configuration file. This will tell the server to always serve our website's pages with HTTPS encryption.
RewriteEngine On
RewriteCond %{HTTPS} !=on
RewriteRule ^/(.*) https://%{SERVER_NAME}/$1 [R,L]
After adding this code, enter ctrl+o to save changes, followed by ctrl+x to exit back to our home screen.
7. Update Domain URLs
Changing your website URLs via Settings > General is disabled in the Bitnami version, so you'll need to change your URLs by editing your wp-config.php folder.
data:image/s3,"s3://crabby-images/ac2ad/ac2ad4ccbac59022d34f91c6a94b1ce188a0958d" alt="compute engine"
From your Google Cloud Platform dashboard navigate to "Compute Engine" > "VM Instances".
data:image/s3,"s3://crabby-images/0c2e4/0c2e4996fae363b6584abe5872a412762b3a7f1b" alt="ssh google cloud platform"
Once inside of your Compute Engine, click on the SSH button to connect to your WordPress installation.
data:image/s3,"s3://crabby-images/3782e/3782e8d6bd8cfdfe74ae0d9751a66ce91d140be7" alt="domain configuration wordpress on google cloud"
Once connected via SSH, connect as a root user and open your wp-config.php file in the nano editor.
sudo -i
nano /opt/bitnami/apps/wordpress/htdocs/wp-config.php
data:image/s3,"s3://crabby-images/13d9a/13d9ac2a6cc3eb8a0112a700e2b5f29783241d3f" alt="domain name configuration wordpress on google cloud"
Inside of your wp-config.php file, you will need to replace your SiteURL and HomeURL definitions as shown below.
REPLACE THIS:
define('WP_SITEURL', 'http://' . $_SERVER['HTTP_HOST'] . '/');
define('WP_HOME', 'http://' . $_SERVER['HTTP_HOST'] . '/');
WITH THIS:
define('WP_HOME','https://yourdomain.com');
define('WP_SITEURL','https://yourdomain.com');
Remember to replace DOMAIN with either the www. or non-www. version of your domain name - whichever your prefer. For example:
define('WP_HOME', 'https://www.yourdomain.com');
define('WP_SITEURL', 'https://www.yourdomain.com');
After adding this code, enter CTRL+o to save changes, followed by CTRL+x to exit back to your home screen.
8. Restart your Apache Server
data:image/s3,"s3://crabby-images/a9568/a95688533b5778ceb1e6d82a040ce426ff694e01" alt="restart apache webserver ssl certificate setup for wordpress on google cloud"
In order for your certificate changes to take effect, you need to restart you Apache server by entering the command below.
sudo /opt/bitnami/ctlscript.sh restart apache
9. Test your Configuration
data:image/s3,"s3://crabby-images/3e9f5/3e9f51245a924a5f5340d75ab4a121eb42b9f1b6" alt="check that the ssl certificate was installed properly wordpress bitnami on google cloud platform"
Visit the domain where where you installed the certificate. If your SSL certificate isn't working, check your configuration at www.ssllabs.com/ssltest/.
Did it Work?
If your SSL certificates were configured properly, you will notice that your website is being loaded with a green padlock icon.
Because we configured auto-renewal for our certificates, we don't ever need to renew them or setup new ones.
Pretty cool, huh?