『中级篇』镜像的发布(18)
2018-08-31 00:22:27
李明
  • 访问次数: 382
  • 注册日期: 2018-07-09
  • 最后登录: 2022-11-17

原创文章,欢迎转载。转载请注明:转载自 IT人故事会,谢谢!
原文链接地址: 『中级篇』镜像的发布(18)

关于image的分发,通过dockerhub来pull拉取别人的image,自己的image的分享出来,类似于github的机制,尽管现在github已经被可怕的微软收购了。

具体的dockerhub如何注册,我就不解释了。今天的任务就是把自己的image push到自己的docker push里面,请看我的表演!

  • 这是之前push的


    1240

开始dockerhub之旅

  • 查看docker里面的imagea

docker image ls

1240

  • 登录dockerhub

docker login

1240

sudo docker image push zhugemaing/hello-world-new:latest

1240

上传失败,被拒绝,为什么?因为必须名称和自己的用户名一样,改名字是试试

  • 修改下载的Image的REPOSITORY和TAG属性:docker tag <IMAGE ID> <REPOSITORY NAME>

docker images ls
docker tag a4cb86cc8d6b zhugeaming/hello-world-new

1240

  • 再进行上传

 docker image push zhugeaming/hello-world-new:latest

1240

1240

  • 可以通过下面的命令把上传的image 拉到本地

image.png

image.png

删除本地的,拉取下试试

 docker image rm zhugeaming/hello-world-new:latest

1240

 docker pull zhugeaming/hello-world-new

1240

其实上边的方式不安全

这种方式基本完成了,但是有个很麻烦的问题,如果一些别有用心的人吧镜像里面放一些『不干净』的东西,现在的社会,无害人之心,但是要防别人害己。其实这个问题dockerhub已经考虑到了,让我细细讲来。

  • 通过github和dockerhub关联通过Dockerfile文件,你是不是明白了什么?

1240

1240

1240

1240

1240

1240

image.png

image.png

1240

1240

1240

  • 点击触发


    1240

  • image正在编译中


    1240

1240

1240

成了哈哈!

对于公司而来,很多东西都需要保护,所以上传到dockerhub 感觉不安全,不稳,对于github我们可以建个私有仓库,对于dockerhub其实也可以建立一个私有仓库。

  • 在dockerhub中搜索

1240

  • 安装私服

#通过registry创建一个dockerhub的私服docker run -d -p 5000:5000 --restart always --name registry registry:2

1240

1240

  • 安装下载私服里面的镜像

我是在一台机器上创建的私服,如果是多台更改为ip地址,保证telnet另一台私服的机器互相可以通信。

docker build -t 0.0.0.0:5000/hello-world .

1240

1240

  • 如果是远程,需要加入信任

sudo vi /etc/docker/daemon.js
#ip和port根据实际的进行更改{"insecure-registries":["ip:port"]}

1240

sudo vim /lib/systemd/system/docker.service
#加入一句EnvironmentFile=/etc/docker/daemon.json

1240

sudo vim /lib/systemd/system/docker.service
  • 推送到镜像到私服

docker push  0.0.0.0:5000/hello-world
  • 如何查看是否上传成功

https://docs.docker.com/registry/ 登录这个网址,通过http的api的方式查看

1240

1240

PS:这个讲的操作性比较强,通过这个可以很轻松把自己的image发布出去。


李明 最后编辑, 2018-09-01 22:31:36