Skip to content

Commit 26aee2e

Browse files
authored
Instructions for Windows Docker Desktop (rpardini#95)
* Instructions for Windows Docker Desktop * Typo in doc: add missing word
1 parent d0101cb commit 26aee2e

File tree

2 files changed

+70
-4
lines changed

2 files changed

+70
-4
lines changed

Docker-Desktop-Windows.md

+66
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,66 @@
1+
# Configure Docker Desktop on Windows to use the proxy and trust its certificate
2+
3+
1. Let's say you set up the proxy on host `192.168.66.72`. Get the certificate using a browser (go to <http://192.168.66.72:3128/ca.crt>) and save it as a file (e.g., to `d:\ca.crt`)
4+
5+
1. Add the certificate to Windows:
6+
7+
1. Double click the certificate
8+
1. Chose to _Install certificate..._, then click _Next_
9+
1. Chose _Current user_, then click _Next_
10+
1. Select option _Place all certificates in the following store_, click _browse_, and select _Trusted Root Certification Authorities_
11+
1. Proceed with Ok and confirm to install the certificate
12+
13+
If you are not using the WSL2 backend for Docker, then restart Docker Desktop and skip the next step.
14+
15+
1. If you are using WSL2 for Docker, then you need to add the certificate to WSL too:
16+
17+
1. Open a terminal
18+
19+
1. Check the name of the WSL distribution:
20+
21+
```
22+
PS C:\> wsl --list
23+
Windows Subsystem for Linux Distributions:
24+
docker-desktop (Default)
25+
docker-desktop-data
26+
```
27+
28+
The distribution we are looking for is _docker-desktop_. If you installed another distribution, such as Ubuntu, and configured Docker to use that, and proceed with that distribution instead.
29+
30+
1. Get a shell into WSL
31+
32+
```
33+
PS C:\> wsl --distribution docker-desktop
34+
XXXYYYZZZ:/tmp/docker-desktop-root/mnt/host/c#
35+
```
36+
37+
1. Copy the certificate into WSL and import it
38+
39+
Note: The directory and the command below are for the _docker-desktop_ WSL distribution. On other systems you might need to tweak the commands a little, but they seem to be the same for [Ubuntu](https://www.pmichaels.net/2020/12/29/add-certificate-into-wsl/) and [Debian](https://github.com/microsoft/WSL/issues/3161#issue-320777324) as well.
40+
41+
```
42+
XXXYYYZZZ:/tmp/docker-desktop-root/mnt/host/c# cp /mnt/host/d/ca.crt /usr/local/share/ca-certificates/
43+
XXXYYYZZZ:/tmp/docker-desktop-root/mnt/host/c# update-ca-certificates
44+
WARNING: ca-certificates.crt does not contain exactly one certificate or CRL: skipping
45+
```
46+
47+
Don't mind the warning, the operation still succeeded.
48+
49+
1. We are done with WSL, you can `exit` this shell
50+
51+
1. Configure the proxy in Docker Desktop:
52+
53+
1. Open Docker Desktop settings
54+
1. Go to _Resources/Proxies_
55+
1. Enable the proxy and set `http://192.168.66.72:3128` as both the HTTP and HTTPS URL.
56+
57+
1. Done. Verify that pulling works:
58+
59+
```
60+
# execute this in a Windows shell, not in WSL
61+
docker pull hello-world
62+
```
63+
64+
You can check the logs of the proxy to confirm that it was used.
65+
66+
If pulling does not work and complains about not trusting the certificate then Docker and/or the WSL distribution might need a restart. You might try restarting Docker, or you can restart Windows too to force WSL to restart.

README.md

+4-4
Original file line numberDiff line numberDiff line change
@@ -256,9 +256,9 @@ docker run --rm --name docker_registry_proxy -it
256256
- If you authenticate to a private registry and pull through the proxy, those images will be served to any client that can reach the proxy, even without authentication. *beware*
257257
- Repeat, **this will make your private images very public if you're not careful**.
258258
- ~~**Currently you cannot push images while using the proxy** which is a shame. PRs welcome.~~ **SEE `ALLOW_PUSH` ENV FROM USAGE SECTION.**
259-
- Setting this on Linux is relatively easy.
260-
- On Mac and Windows the CA-certificate part will be very different but should work in principle.
261-
- Please send PRs with instructions for Windows and Mac if you succeed!
259+
- Setting this on Linux is relatively easy.
260+
- On Mac follow the instructions [here](Docker-for-Mac.md).
261+
- On Windows follow the instructions [here](Docker-Desktop-Windows.md).
262262

263263
### Why not use Docker's own registry, which has a mirror feature?
264264

@@ -280,7 +280,7 @@ Yeah. Docker Inc should do it. So should NPM, Inc. Wonder why they don't. 😼
280280
### TODO:
281281

282282
- [x] Basic Docker-for-Mac set-up instructions
283-
- [ ] Basic Docker-for-Windows set-up instructions.
283+
- [x] Basic Docker-for-Windows set-up instructions.
284284
- [ ] Test and make auth work with quay.io, unfortunately I don't have access to it (_hint, hint, quay_)
285285
- [x] Hide the mitmproxy building code under a Docker build ARG.
286286
- [ ] "Developer Office" proxy scenario, where many developers on a fast LAN share a proxy for bandwidth and speed savings (already works for pulls, but messes up pushes, which developers tend to use a lot)

0 commit comments

Comments
 (0)