In this quick-start tutorial you will learn how to configure free, auto-renewing SSL certificates for WordPress websites that are hosted on Google Cloud compute engine using the Click-to-Deploy version of WordPress on Google Cloud.
Having SSL Security on your website will improve your Google search ranking.
If you’re using the Bitnami version of WordPress on Google Cloud, you can view that SSL certificate tutorial here.
Before getting started with this tutorial, you should have already:
- Installed WordPress on Google Cloud
- Set up a Domain Name for your WordPress website
- Reserved a Static IP Address for your VM instance.
So let’s get started…
1. Connect to WordPress via SSH
data:image/s3,"s3://crabby-images/4c7c8/4c7c8dc0354189a787fbf597b2ed301a9de73b8f" alt="ssl certificates wordpress on google cloud access menu"
data:image/s3,"s3://crabby-images/b4b5b/b4b5b6c95a12a755c060186bae857250c7c6516c" alt="ssl certificate for wordpress on google cloud go to compute engine then vm instances"
data:image/s3,"s3://crabby-images/65d92/65d92cce1b09fd63fd7245272fc1a45bdeed2e6c" alt=""
2. Install CertBot Client
data:image/s3,"s3://crabby-images/9ef06/9ef068ad84ca63d89bec7a0ddcb49562220fff54" alt="ssl certificate setup wordpress google cloud click to deploy"
wget https://dl.eff.org/certbot-auto && chmod a+x certbot-auto
After executing each of these commands, you can either stay in the same SSH window or exit and open a new one.
3. Generate Certificates
data:image/s3,"s3://crabby-images/cc250/cc25084c1f4c1a53e961840113a8551669c6d284" alt="ssl certificate setup wordpress google cloud click to deploy"
./certbot-auto certonly --webroot -w /var/www/html/ -d 1pagezen.com -d www.1pagezen.com
data:image/s3,"s3://crabby-images/2c1fc/2c1fc41710bba775c42233778a5fb0cd43fbf185" alt="ssl certificate setup wordpress google cloud click to deploy"
4. Configure the Certificates
data:image/s3,"s3://crabby-images/0cf22/0cf22133f1dcca5d2d93d9ad40c32290c565e413" alt="ssl certificate setup wordpress google cloud click to deploy"
sudo nano /etc/apache2/sites-available/default-ssl.conf
data:image/s3,"s3://crabby-images/066ff/066ff4397258660d94638eab6d5e39e658518269" alt="ssl certificate setup wordpress google cloud platform compute engine click-to-deploy"
<Directory /var/www/html/>Options Indexes FollowSymLinks MultiViewsAllowOverride AllOrder allow,denyallow from all</Directory>
data:image/s3,"s3://crabby-images/c6da7/c6da7f5854f8000e9be9b39acb2ec262e5acaf28" alt="ssl certificate setup wordpress google cloud click to deploy"
SSLCertificateFile "/etc/letsencrypt/live/1pagezen.com/cert.pem"SSLCertificateKeyFile "/etc/letsencrypt/live/1pagezen.com/privkey.pem"SSLCertificateChainFile "/etc/letsencrypt/live/1pagezen.com/chain.pem"
After adding this code, enter ctrl+o to save changes, followed by ctrl+x to exit back to your home screen.
5. Enable HTTPS Redirect
data:image/s3,"s3://crabby-images/e6c06/e6c06b9c6c5226d3f2562fa26141f1ab8a017222" alt="ssl certificate setup wordpress google cloud click to deploy"
sudo nano /etc/apache2/sites-available/wordpress.conf
data:image/s3,"s3://crabby-images/b3eee/b3eee486d90cd43a436ae1750be25266d9c0fce4" alt="wordpress conf file configurations"
<VirtualHost *:80>ServerAdmin webmaster@localhostDocumentRoot /var/www/htmlServerName www.1pagezen.comServerAlias 1pagezen.comRedirect permanent / https://www.1pagezen.com/<Directory />Options FollowSymLinksAllowOverride None</Directory><Directory /var/www/html/>Options Indexes FollowSymLinks MultiViewsAllowOverride AllOrder allow,denyallow from all</Directory>ScriptAlias /cgi-bin/ /usr/lib/cgi-bin/<Directory "/usr/lib/cgi-bin">AllowOverride NoneOptions +ExecCGI -MultiViews +SymLinksIfOwnerMatchOrder allow,denyAllow from all</Directory>ErrorLog ${APACHE_LOG_DIR}/error.log# Possible values include: debug, info, notice, warn, error, crit,# alert, emerg.LogLevel warnCustomLog ${APACHE_LOG_DIR}/access.log combined</VirtualHost>
After adding the code to your wordpress.conf file, enter ctrl+o to save your changes and ctrl+x to exit the wordpress.conf file.
6. Restart the Apache Server
data:image/s3,"s3://crabby-images/96aa0/96aa03fe77173abda67c2c82a48fa6ae1388d7ee" alt="ssl certificate setup wordpress google cloud platform compute engine bitnami"
sudo a2ensite default-sslsudo a2enmod sslsudo service apache2 restart
7. Update WordPress URLs
data:image/s3,"s3://crabby-images/109ed/109edc7288658760d5457b5eec21a86351d13135" alt="enter url for domain"
data:image/s3,"s3://crabby-images/1c638/1c638f8c9e1f09383bfb7e2520777dbfafbd9efa" alt="ssl certificate setup wordpress google cloud click to deploy"
SSL Auto-Renewal Configuration (Optional)
8. Configure SSL Auto-Renewal
Do you want your SSL certificates to renew automatically? In the following steps you will learn how to configure auto-renewal for your SSL certificates – so let’s get started!
data:image/s3,"s3://crabby-images/39d0e/39d0e89fc68b138c3c2c0f81208be8c921b6d4c2" alt="move certbot to letsencrypt directory with mv command"
sudo mv certbot-auto /etc/letsencrypt/
data:image/s3,"s3://crabby-images/9d101/9d1014c8220472086620aa20516752ec00074f12" alt="moved certbot package"
8.1 Edit Crontab File
Now that you’ve moved your certbot-Auto package to the /etc/letsencrypt/ directory, the next step is to open your crontab file.
To open your crontab file, execute the following command:
sudo crontab -e
data:image/s3,"s3://crabby-images/57f1c/57f1cdddcf7d11cfbd4fd262de9b7fa047fe43b9" alt="opening crontab file for editing"
8.2 Configure Auto-Renew Script
Now that you’ve opened your crontab file, the next step is to add a script at the bottom of the crontab file which will execute once per week and will automatically renew the SSL certificates if they are about to expire.
data:image/s3,"s3://crabby-images/cf308/cf308795e6fb0ed79da5518118002ea8787d0188" alt="inside of crontab file with ssl auto renew script"
For Click-to-deploy or standard Apache users, add the following script:
45 2 * * 6 cd /etc/letsencrypt/ && ./certbot-auto renew && /etc/init.d/apache2 restart
That’s it!
If you’re interested in learning about additional auto-renewal testing methods, check out the full Certbot auto-renewal tutorial here. You may also be interested in boosting your website’s performance by configuring Cloudflare’s free CDN.
If you run into any issues with your certificates and want to verify that they’re configured properly, check out the SSL Checker tool. Also check out this tutorial on how to fix SSL errors.