Docker中通过模板创建镜像,Docker容器仓库及数据管理
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Docker中通过模板创建镜像,Docker容器仓库及数据管理相关的知识,希望对你有一定的参考价值。
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
我们还可以用该文件恢复本地镜像:
(5)删除本地镜像
(6)导入镜像
docker load --input aming-centos.tar 或者
docker load < aming-centos.tar
docker push image_name //可以把自己的镜像传到dockerhub官方网站上去,但前提是需要先注册一个用户,后续如果有需求再研究吧
2.容器管理
docker create -it centos6 bash
//这样可以创建一个容器,但该容器并没有启动
docker start a0fa08fb3a76 //启动容器后,可以使用 docker ps 查看到,有start 就有stop,和restart
之前我们使用的docker run 相当于先create再start
(1)创建容器
docker run -it centos bash
这样进入了一个虚拟终端里面,我们可以运行一些命令,使用命令exit或者ctrl d 退出该bash,当退出后这个容器也会停止。
(2)让容器在后台运行
docker run -d 可以让容器在后台运行
比如:docker run -d centos bash -c "while :; do echo "123"; sleep 2; done"
(3)给容器自定义名字
docker run --name web -itd centos bash // --name 给容器自定义名字
(4)让容器退出后直接删除
docker run --rm -it centos bash -c "sleep 30" //--rm 可以让容器退出后直接删除,在这里命令执行完容器就会退出
(5)获取到容器的运行历史信息
docker logs 可以获取到容器的运行历史信息,用法如下
docker logs a0fa08fb3a76
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私有仓库。
(2)以registry镜像启动容器
docker run -d -p 5000:5000 registry
#以registry镜像启动容器,-p会把容器的端口映射到宿主机上,:左边为宿主机监听端口,:右边为容器监听端口
curl 127.0.0.1:5000/v2/_catalog //可以访问它
下面我们来把其中一个镜像上传到私有仓库
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
//更改为
{ "insecure-registries":["192.168.1.169:5000"] }
(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
//更改为
{ "insecure-registries":["192.168.1.169:5000"] }
重启服务
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了
以上是关于Docker中通过模板创建镜像,Docker容器仓库及数据管理的主要内容,如果未能解决你的问题,请参考以下文章