【docker实战】如何登陆到自己的私有仓库?

docker用不了了,但工作还要继续。以前从公共仓库(Docker Hub)下载的镜像,需要推送到自己的私有仓库,之后再从私有仓库中拉取。

私有仓库我们一般使用Harbor,github地址为Harbor (github.com)。具体的安装方式请访问Docker 安装 Harbor (踩坑完毕)_m1 使用docker 安装 harbor-CSDN博客。由于时间关系,上面安装harbor的方式我并没验证。大家也可以网上自己寻找其它安装方法。

下面我直接进入主题,讲解如何登陆自己的私有仓库。

首先,我在阿里云上的地址http://41.68.153.178:6114搭建了一个harbor私有仓库。请不要试图访问这个地址,这是我在原有的基础上,随便改了几个数字,防止被攻击。这里给出一个这样的地址,是为了帮助大家更好的理解,至少我认为比"IP地址:端口号"的方式好多了。

要访问私有仓库,需要使用docker login的方式访问,不通过login是无法访问私有仓库的。下面是我首次使用的命令

复制代码
docker login --username=admin --password=41nccq827afbcb5i http://41.68.153.178:6114

回车后,服务器反馈给我一个错误。

复制代码
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
Error response from daemon: Get "https://41.68.153.178:6114": http: server gave HTTP response to HTTPS client

意思是说,使用--password选项的方式不安全,建议使用--password-stdin,并且说明我应该访问https,而不是访问http的地址。

因为docker默认会以https的方式访问,想要访问http需要修改docker的配置文件。

windows下配置文件路径为:C:/Users/你的用户名/.docker/daemon.json

linux下配置文件路径为:/etc/docker/daemon.json

在其中需要加入以下内容:

复制代码
"insecure-registries": ["41.68.153.178:6114"]

然后重启docker

复制代码
systemctl restart docker

这个地址就被设置为受信任列表,之后就可以访问了。

于是我再次输入

复制代码
docker login --username=admin --password-stdin http://41.68.153.178:6114

之后在光标处输入密码,不起作用。看了下官网,官网的解决思路是这样的:

复制代码
cat ~/my_password.txt | docker login --username foo --password-stdin

也就是说,需要一个文件,将密码传给这个stdin。

所以我在一个文件夹下建立了这个文件,并将密码粘贴进入。再次输入,登陆成功。

复制代码
cat ./my_password.txt | docker login --username admin --password-stdin  http://41.68.153.178:6114
Login Succeeded
相关推荐
对你无可奈何1 分钟前
高可用环境下Nginx服务管理脚本优化实践
linux·运维·nginx
张敬之、10 分钟前
k8s-dashboard
云原生·容器·kubernetes
云上艺旅10 分钟前
K8S学习之基础二十九:K8S中的secret
学习·云原生·容器·kubernetes
Justice link17 分钟前
K8S的搭建
云原生·容器·kubernetes
前端白袍28 分钟前
性能优化:服务器性能影响网站加载速度分析
运维·服务器·性能优化
stone08231 小时前
ABAP语言的动态编程(4) - 综合案例:管理费用明细表
linux·运维·服务器
厂里英才1 小时前
docker无法正常拉取镜像问题的解决
linux·docker
ღ星ღ2 小时前
网络编程基础
运维·服务器·网络
过客WZX2 小时前
Ubuntu24.04下管理自己的ssh连接
运维·服务器·ssh
RedCong3 小时前
K8S之QoS详解
云原生·容器·kubernetes