【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
相关推荐
2301_7679026423 分钟前
Zabbix
运维·zabbix
weixin_46686 小时前
K8S-特殊容器
云原生·容器·kubernetes
半夏知半秋6 小时前
docker常用指令整理
运维·笔记·后端·学习·docker·容器
逆风水手6 小时前
Ansible自动化运维入门指南
linux·运维·自动化·ansible
tianyuanwo7 小时前
SSH会话管理实战:识别与清理非法连接的完整指南
运维·ssh
小豆子范德萨7 小时前
两台window配置SSH免密登录
运维·ssh
小北方城市网7 小时前
第 6 课:Vue 3 工程化与项目部署实战 —— 从本地开发到线上发布
大数据·运维·前端·ai
没有bug.的程序员8 小时前
Nacos vs Eureka 服务发现深度对比
jvm·微服务·云原生·容器·eureka·服务发现
记得记得就1519 小时前
docker作业
运维·docker·容器
运维行者_9 小时前
OPM 与传统管理工具的区别,在网络修复与自动化运维方面的优势在哪里?
运维·服务器·开发语言·网络·自动化·php·ssl