docker私有仓库搭建完整记录(直接pull方式)

1.安装docker-registry


#直接从官网pull镜像registry,简单粗暴。国内可能速度较慢,考虑挂VPN

docker pull registry


按照上一篇中的方式修改--insecure-registry设置及config.yml文件


2.运行docker-registry


#后台启动registry,其中/home/alvin/registry为我本地仓库的存储路径

docker run -d -v /home/alvin/registry:/tmp/registry -p 5000:5000 -e  DOCKER_REGISTRY_CONFIG=/tmp/registry/config.yml registry


问题记录:每次重新运行时镜像丢失

解决方法:修改仓库路径到本地

docker run -d -e SETTINGS_FLAVOR=dev -e STORAGE_PATH=/tmp/registry -v /home/alvin/registry:/tmp/registry -p 5000:5000 registry


至此已经可以正常的push/pull操作了


3.nginx代理认证


#安装nginx

sudo apt-get install -y nginx apache2-utils

#创建用户名及密码

sudo htpasswd -c /etc/nginx/docker-registry.htpasswd [USERNAME]


#配置nginx认证文件

sudo vim /etc/nginx/sites-available/docker-registry

#文件中写入下面内容:

# For versions of Nginx > 1.3.9 that include chunked transfer encoding support
# Replace with appropriate values where necessary
 
upstream docker-registry {
 server localhost:5000;
}
 
server {
 listen 8080;
 server_name 192.168.32.139;
 
 # ssl on;
 # ssl_certificate /etc/ssl/certs/docker-registry;
 # ssl_certificate_key /etc/ssl/private/docker-registry;
 
 proxy_set_header Host       $http_host;   # required for Docker client sake
 proxy_set_header X-Real-IP  $remote_addr; # pass on real client IP
 
 client_max_body_size 0; # disable any limits to avoid HTTP 413 for large image uploads
 
 # required to avoid HTTP 411: see Issue #1486 (https://github.com/dotcloud/docker/issues/1486)
 chunked_transfer_encoding on;
 
 location / {
     # let Nginx know about our auth file
     auth_basic              "Restricted";
     auth_basic_user_file    docker-registry.htpasswd;
 
     proxy_pass http://docker-registry;
 }
 location /_ping {
     auth_basic off;
     proxy_pass http://docker-registry;
 } 
 location /v1/_ping {
     auth_basic off;
     proxy_pass http://docker-registry;
 }
 
}
其中server_name改为主机的ip或域名


#链接配置文件到nginx

sudo ln -s /etc/nginx/sites-available/docker-registry /etc/nginx/sites-enabled/docker-registry 

#重启nginx服务

sudo service nginx restart


可以通过ip:8080来访问私有仓库了,并且有用户认证功能



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值