设为首页 收藏本站
查看: 1162|回复: 0

[经验分享] Docker中通过模板创建镜像,Docker容器、仓库及数据管理

[复制链接]

尚未签到

发表于 2018-5-26 10:07:54 | 显示全部楼层 |阅读模式
  1.通过模板创建镜像
  

  (1)首先去下载一个模板
       http://openvz.org/Download/templates/precreated //下载速度不快,下载了一个centos6的模板centos-6-x86-minimal.tar.gz
  (2)导入该镜像的命令为:
       cat centos-6-x86-minimal.tar.gz|docker import - centos6
  (3)查看导入的镜像
       docker images
  (4)导出镜像:
  把现有镜像,导出为一个文件:
  docker save -o centos-net.tar centos-net
  我们还可以用该文件恢复本地镜像:
DSC0000.jpg     DSC0001.jpg

  (5)删除本地镜像
DSC0002.jpg     DSC0003.jpg

  (6)导入镜像
  docker load --input aming-centos.tar  或者
  docker load < aming-centos.tar
DSC0004.jpg DSC0005.jpg


  docker push image_name  //可以把自己的镜像传到dockerhub官方网站上去,但前提是需要先注册一个用户,后续如果有需求再研究吧
  2.容器管理
   docker create  -it  centos6   bash
  //这样可以创建一个容器,但该容器并没有启动
DSC0006.jpg DSC0007.jpg

   docker start   a0fa08fb3a76   //启动容器后,可以使用 docker ps  查看到,有start 就有stop,和restart
  之前我们使用的docker run 相当于先create再start
  (1)创建容器
   docker run -it centos bash  
DSC0008.jpg DSC0009.jpg

  这样进入了一个虚拟终端里面,我们可以运行一些命令,使用命令exit或者ctrl d 退出该bash,当退出后这个容器也会停止。
  (2)让容器在后台运行
  docker run -d  可以让容器在后台运行
  比如:docker run -d centos bash -c &quot;while :; do echo &quot;123&quot;; sleep 2; done&quot;
DSC00010.jpg DSC00011.jpg

  (3)给容器自定义名字
   docker run --name web -itd centos bash // --name 给容器自定义名字
DSC00012.jpg DSC00013.jpg

  (4)让容器退出后直接删除
  docker run --rm -it centos bash -c &quot;sleep 30&quot; //--rm 可以让容器退出后直接删除,在这里命令执行完容器就会退出
DSC00014.jpg DSC00015.jpg

DSC00016.jpg DSC00017.jpg

  (5)获取到容器的运行历史信息
  docker logs 可以获取到容器的运行历史信息,用法如下
  docker logs a0fa08fb3a76
DSC00018.jpg DSC00019.jpg

  docker attach 可以进入一个后台运行的容器,比如
  docker attach  container_id    //但是attach命令不算好用,比如我们想要退出终端,就得exit了,这样容器也就退出了,还有一种方法
  (6)进入容器
       docker exec -it a0fa08fb3a76 bash  //可以临时打开一个虚拟终端,并且exit后,容器依然运行着
  
  (7)删除容器
      docker rm  a0fa08fb3a76 //container_id是ps的时候查看到的,这样就可以把container删除,如果是运行的容器,可以加-f
  (8)迁移容器
       docker  export  a0fa08fb3a76  > file.tar // 导出容器,可以迁移到其他机器上,需要导入
  (9)导入容器生成镜像
       cat file.tar |docker import - fxq_testos   //这样会生成fxq_tesos的镜像
  

  3.仓库管理
  (1)下载registry 镜像

  docker pull registry
  #下载registry 镜像,registy为docker官方提供的一个镜像,我们可以用它来创建本地的docker私有仓库。
DSC00020.jpg DSC00021.jpg

  (2)以registry镜像启动容器
  docker run -d -p 5000:5000 registry  
  #以registry镜像启动容器,-p会把容器的端口映射到宿主机上,:左边为宿主机监听端口,:右边为容器监听端口
DSC00022.jpg DSC00023.jpg

  curl 127.0.0.1:5000/v2/_catalog //可以访问它
  下面我们来把其中一个镜像上传到私有仓库
DSC00024.jpg DSC00025.jpg

   docker tag centos 192.168.1.169:5000/centos
  //标记一下tag,必须要带有私有仓库的ip:port
  (3)标记的镜像给推送到私有仓库
   docker push 192.168.1.169:5000/centos
  //把标记的镜像给推送到私有仓库

  此时并不会成功,Get https://192.168.1.169:5000/v2/: http: server gave HTTP response to HTTPS client
  更改配置文件,vi /etc/docker/daemon.json
  //更改为
  { &quot;insecure-registries&quot;:[&quot;192.168.1.169:5000&quot;] }
  (4)重启服务
       systemctl restart docker
  (5)查看容器
   docker ps -a
  //查看容器已经关闭,还需要启动

   docker start e5b31b
  //这里的 e5b31b 为registry容器id
  (6)再次push
   docker push 192.168.1.169:5000/centos


  (7)查看到推送上来的镜像
   curl 127.0.0.1:5000/v2/_catalog
  //可以查看到推送上来的镜像

  (8)客户端下载镜像:
   前提:
  安装好docker-ce ,
  更改配置文件,vi /etc/docker/daemon.json
  //更改为
  { &quot;insecure-registries&quot;:[&quot;192.168.1.169:5000&quot;] }
  重启服务
   systemctl restart docker
  (9)拉取镜像:
   docker pull 192.168.1.169:5000/centos


  

  4.数据管理
  (1)挂载本地的目录到容器里
   docker run -tid -v /data/:/data centos bash
  //-v 用来指定挂载目录,:前面的/data/为宿主机本地目录,:后面的/data/为容器里的目录,会在容器中自动创建

  (2)挂载数据卷
  其实我们挂载目录的时候,可以指定容器name,如果不指定就随机定义了。比如上面我们没有指定,它就生成了一个名字为angry_shirley,这个名字可以使用命令 docker ps  看最右侧一列
   docker run -itd --volumes-from angry_shirley centos bash
  这样,我们使用centos镜像创建了新的容器,并且使用了 angry_shirley 容器的数据卷

  (3)定义数据卷容器
  有时候,我们需要多个容器之间相互共享数据,类似于linux里面的NFS,所以就可以搭建一个专门的数据卷容器,然后其他容器直接挂载该数据卷。
  首先建立数据卷容器
   docker run -itd -v /data/ --name testvol centos  bash
  //注意这里的/data/是容器的/data目录,并非本地的/data/目录。
  然后让其他容器挂载该数据卷

  
  docker run -itd  --volumes-from testvol centos bash

  在新容器中新建1.txt

  看原有testvol主机上的/data目录里就是有1.txt了

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-481247-1-1.html 上篇帖子: Docker可视化界面(Consul+Shipyard+Swarm+Service Discover 下篇帖子: docker compose的简单使用
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表