Introduction
Docker Desktop provides many features, but it also is heavy and takes a lot of time to start. This made me remove it and install only Docker Engine directly in WSL and reduced the startup time from minutes to seconds.
In this post I’ll show how to do it and some configurations to better the experience.
Quick definition
A quick definition of the terms:
- Docker Engine: It is the core component of Docker, providing orchestration of the container runtime, image management and networking and storage capabilities;
- Docker CLI: The command line interface to interact with the Docker API;
Installing Docker Engine on WSL
To install Docker Engine in WSL, first we follow the official docs for the distro we are using. I use Ubuntu, so I’ll give instructions for it in this post, but for other distros, click here.
We need to add the docker repository to apt’s sources and install its components (Docker Engine, Docker CLI, Containerd, BuildX and Docker Compose):
|  |  | 
To be able to use the docker CLI command without root permissions, we need to create a docker group and add our user it:
|  |  | 
Then we can start the Docker service:
sudo service docker start
And run the hello-world image to test:
docker run hello-world
How to auto start Docker in WSL starts
There are two ways to auto start Docker in WSL
With systemd
For WSL version 0.67.6 or newer, we can enable the use of systemd:
In the WSL distro, edit the /etc/wsl.conf file and add the following lines:
|  |  | 
Then, from Windows, run the following command to kill WSL:
wsl --shutdown
Open the WSL distro shell and run a docker ps to validate that Docker has auto-started.
With a profile script
I recommend using systemd, but it adds a bit of latency in the startup (14 seconds in my machine).
If this is a problem, Docker can be started with the following script in the profile script (.zshrc, .bashrc, etc):
|  |  | 
It checks if the distro is a WSL distro (in case you share your profile script between machines) and start the docker service if its not running.
Source: https://github.com/nickjj/dotfiles/commit/badd3265e5c8f6eca90d3b57df29292545332500
How to access Docker from Windows
To access the Docker socket from outside the WSL distro, we have to add an extra configuration to Docker Daemon.s
If using systemd:
Edit the /lib/systemd/system/docker.service and add -H tcp://0.0.0.0:2375 in the ExecStart as shown below:
|  |  | 
And restart Docker:
sudo service docker restart
If starting with a profile script
Edit the /etc/docker/daemon.json and add the hosts configuration as shown below:
|  |  | 
And restart Docker:
sudo service docker restart
Then, on Windows, configure the DOCKER_HOST environment variable to tcp://localhost:2375 (or tcp://[::1]:2375 if using IPv6).
With this environment variable set, tools like Testcontainers and Localstack will work using the Docker engine installed in WSL.
💡 I wrote some posts about Testcontainer and Localstack.
Access from the command line
I prefer to run commands from the shell in WSL, but if needed, there are some options:
- Install the Docker CLI on Windows (It will respect the DOCKER_HOSTset above);
- Run with the wslcommand:wsl -d Ubuntu docker ps
I won’t dive into details about this though.
Possible errors
Invalid credsStore config
If Docker Desktop was installed, the credentials store may have been set to to docker-credential-desktop and the following error will be shown:
|  |  | 
To fix the error, edit the file ~/.docker/config.json and remove the credsStore property.
Duplicated hosts configuration
If Docker initialization was setup using systemd and the following error occur when starting Docker service, it can be because of duplicated host configuration.
|  |  | 
systemd will use the docker.service configuration, that passes the hosts as arguments in with the -H parameter and this error will happen if you also set the hosts in /etc/docker/daemon.json.
To fix, remove the hosts parameter from /etc/docker/daemon.json and follow the configuration here.
