docker registry
install registry
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
  | # sample, https://docs.docker.com/registry/configuration/
cat > /usr/local/etc/docker-registry-config.yml << EOF
version: 0.1
log:
  fields:
    service: registry
storage:
    delete:
        enabled: true
        blobdescriptor: inmemory
    filesystem:
        rootdirectory: /var/lib/registry
http:
    addr: :5000
    headers:
        X-Content-Type-Options: [nosniff]
health:
  storagedriver:
    enabled: true
    interval: 10s
    threshold: 3
EOF
# https://hub.docker.com/_/registry
# docker
docker run -d \
--restart=always \
-v /usr/local/etc/docker-registry-config.yml:/etc/docker/registry/config.yml \
-p 5000:5000 \
--name docker-registry \
-v docker-registry:/var/lib/registry \
registry:2.8.3
# podman
podman run -d \
-v /usr/local/etc/docker-registry-config.yml:/etc/docker/registry/config.yml \
-p 5000:5000 \
--name registry \
-v docker-registry:/var/lib/registry \
registry:2.8.3
buildah tag de3ebb1b260b registry.wiloon.com/pingd-proxy:v0.0.1
buildah push registry.wiloon.com/pingd-proxy:v0.0.1
podman pull registry.wiloon.com/pingd-proxy:v0.0.1
registry.wiloon.com/pingd-proxy
registry.wiloon.com/ping-proxy
  | 
docker 测试
1
2
3
4
5
6
  | sudo docker image tag hello-world registry.wiloon.com/myfirstimage
sudo docker image ls
sudo docker push registry.wiloon.com/myfirstimage
sudo docker image rm hello-world
sudo docker pull  registry.wiloon.com/myfirstimage
sudo docker image ls
  | 
nginx config
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
  | server {
    listen              443 ssl;
    server_name         registry.wiloon.com;
    ssl_certificate     /etc/letsencrypt/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/privkey.pem;
    ssl_protocols       TLSv1.2;
    ssl_ciphers 'EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH'; 
    ssl_prefer_server_ciphers on;
    ssl_session_cache shared:SSL:10m;
    client_max_body_size 0;
    chunked_transfer_encoding on;
    location /v2/ {
      if ($http_user_agent ~ "^(docker/1.(3|4|5(?!.[0-9]-dev))|Go ).*$" ) {
        return 404;
      }
      proxy_pass                          http://192.168.50.13:5000;
      proxy_set_header  Host              $http_host;   # required for docker client's sake
      proxy_set_header  X-Real-IP         $remote_addr; # pass on real client's IP
      proxy_set_header  X-Forwarded-For   $proxy_add_x_forwarded_for;
      proxy_set_header  X-Forwarded-Proto $scheme;
      proxy_read_timeout                  900;
    }
}
  | 
查看仓库镜像
1
2
3
4
  | # 镜像列表
curl https://registry.wiloon.com/v2/_catalog | jq .
# 查询镜像 tag(版本)
curl https://registry.wiloon.com/v2/rssx-api/tags/list
  | 
删除镜像与空间回收
1
2
  | podman inspect rssx-api|grep sha256
curl -I -X DELETE https://registry.wiloon.com/v2/rssx-api/manifests/sha256:5b367dbc03f141bb5246b0dff6d5fc9c83d8b8d363d0962f3b7d344340e458f6
  | 
https://zhuanlan.zhihu.com/p/33324217
https://docs.docker.com/registry/
https://docs.docker.com/registry/recipes/nginx/
podman registry config
1
2
3
4
5
6
7
8
  | vim /etc/containers/registries.conf
# content
unqualified-search-registries = ["docker.io"]
[[registry]]
prefix = "docker.io"
location = "registry-1.docker.io"
  | 
docker registry list