自建 Docker Hub Proxy

由于国内的网络环境,和极其不做人的 docker,在 2024 年 10月这个时间点,在国内环境使用 docker 真的和吃翔一样难受。

写篇文章总结一下最近本地打镜像遇到的恶心经历,和解决方案。

解决方案

自建镜像源代理

git clone https://github.com/bboysoulcn/registry-mirror.git
cd registry-mirror/docker/dockerhub
docker-compose up -d

之后配置 nginx,可参考的配置文件:

server {
    listen 80;
    server_name example.site ;
    root /home/wwwroot/example.site;

    location ~ /.well-known {
        allow all;
    }

    location ~ /\. {
        deny all;
    }

    location / {
        return 301 https://$host$request_uri;
    }

    access_log off;
}

server {
    listen 443 ssl http2;
    #listen [::]:443 ssl http2;
    server_name example.site ;
    root /home/wwwroot/example.site;

    ssl_certificate /usr/local/nginx/conf/ssl/example.site_ecc/fullchain.cer;
    ssl_certificate_key /usr/local/nginx/conf/ssl/example.site_ecc/example.site.key;
    ssl_session_timeout 5m;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3;
    ssl_prefer_server_ciphers on;
    ssl_ciphers "TLS13-AES-256-GCM-SHA384:TLS13-CHACHA20-POLY1305-SHA256:TLS13-AES-128-GCM-SHA256:TLS13-AES-128-CCM-8-SHA256:TLS13-AES-128-CCM-SHA256:EECDH+CHACHA20:EECDH+CHACHA20-draft:EECDH+AES128:RSA+AES128:EECDH+AES256:RSA+AES256:EECDH+3DES:RSA+3DES:!MD5";
    ssl_session_cache builtin:1000 shared:SSL:10m;
    ssl_dhparam /usr/local/nginx/conf/ssl/dhparam.pem;


    location ~ /.well-known {
        allow all;
    }

    location ~ /\. {
        deny all;
    }

    location / {
        proxy_pass http://127.0.0.1:5000;
        client_max_body_size 1000m;
    }

    access_log off;
}

然后修改 ~/.docker/daemon.json

注意
本文描述的是 MacOS 上的解法,其他 OS 配置文件的路径可能不一样
➜  ~ cat ~/.docker/daemon.json                                                                                                  
{
    "builder": {
        "gc": {
            "defaultKeepStorage": "20GB",
            "enabled": true
        }
    },
    "experimental": false,
    "registry-mirrors": ["https://example.site"]
}

 

国内镜像源的问题

我大 XX 自有国情在此

镜像非常的不全。以阿里云为例,pull 一个 jdk 基础镜像,例如 docker pull amazoncorretto:21.0.5-alpine,都会报 403 Forbidden。

阿里云相关链接:https://help.aliyun.com/zh/acr/product-overview/product-change-acr-mirror-accelerator-function-adjustment-announcement

Docker 本地代理的问题

http/https 代理不生效

下面的方法都不行。

 5342  docker build . --build-arg HTTP_PROXY=socks5://127.0.0.1:11111 --build-arg HTTPS_PROXY=socks5://127.0.0.1:11111  -f DockerfileBase -t some.site/abc/def:1.2.3
 5344  docker build . --build-arg HTTP_PROXY=http://xx:xx@1.2.3.4:4321 --build-arg HTTPS_PROXY=http://xx:xx@1.2.3.4:4321 -f DockerfileBase -t some.site/abc/def:1.2.3

socks5 代理居然需要企业级订阅??

Docker,你是真不要脸啊。一个 socks5 代理的功能你敢收 24 刀一个月。

 

CC BY-NC-SA 4.0 本作品使用基于以下许可授权:Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License.

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注