Using HTTPS in docker for local development
As a web application developer, one of the most common challenge faced is, not having the local development environment close enough to the production environment. While there can be many aspects to this, in this post we will focus on the following two
- Having a domain name, instead of something like
http://localhost:8080
- Having a valid
HTTPS
certificate on the local development machine
Also, I am going to use docker for this demonstration. So lets begin.
I am going to use Wordpress as my example application. So lets head over the the docker page for Wordpress. Scrolling to the bottom shows us a sample configuration which can be used with docker-compose to have Wordpress running with MySQL.
Open a terminal and make a folder with name, say wordpress-with-http
and move inside it. Now create a file with name docker-compose.yml
and paste the contents copied from here.
Save and exit from the file. Now lets start the docker containers — docker-compose up
. This will fire up the Wordpress and MySQL containers with appropriate configuration. Open a browser and type the URL - http://localhost:8080
and press enter. At this point, we can see that we have now successfully opened up the Wordpress setup page.
In order to access the Wordpress app over domain name, we need to make an entry in the /etc/hosts
files and add the following at the end of the file - 127.0.0.1 my-wordpress-blog.local
. After this, now we should be able to access - http://my-wordpress-blog.local:8080
in browser.
In order to have HTTPS in the local development environment, we will use a utility called mkcert. In order to have mkcert, we first need to install the dependency — libnss3-tools
. Open a terminal and run - sudo apt install libnss3-tools -y
. Now lets download the pre-built mkcert binary from the github releases page. Download the appropriate binary. Since I am using Ubuntu on my develoment machine, so I will use mkcert-v1.4.3-linux-amd64. Download the binary file and move it to /usr/local/bin
. We also need to make the file executable - chmod +x mkcert-v1.4.3-linux-amd64
. Now lets create a softlink with name - mkcert
- ln -s mkcert-v1.4.3-linux-amd64 mkcert
. The first step is to become a valid Certificate Authority for local machine - mkcert -install
. This will install the root CA for local machine.
Now lets get back to generating self-signed SSL certificates. Lets move back to our development folder wordpress-with-https
. Here we will create directory proxy
and inside it certs
and conf
. Lets move inside proxy/certs
and generate the certificates.
This will generate the SSL key and certificate file which is valid for domain — my-wordpress-blog.local
. Now lets modify the contents of file docker-compose.yml
to use nginx as the proxy. Add the following contents under services
tag.
Now lets focus on the nginx configuration to use it as proxy. Edit the file wordpress-with-https/proxy/conf/nginx.conf
and add the following configuration.
If the docker containers are still running, press Ctrl + C
to stop them. Now lets fire up the docker containers with the updated contents in docker-compose.yml
. If all has been done correctly, we should have everything ready. Now lets open the browser and enter the url - http://my-wordpress-blog.local
. This should redirect to https://my-wordpress-blog.local
. Now if you look at the top left of the browser, the lock icon is green, which means that the browser has accepted our locally generated self signed ssl certificates.
The github repository can be found here
Originally published at https://dev.to on May 13, 2021.