20200107笔记

25.6 容器管理
25.7 仓库管理
25.8 数据管理
25.9 数据卷备份恢复

一、容器管理

docker create -it centos6 bash //这样可以创建一个容器,但该容器并没有启动

docker start container_id //启动容器后,可以使用 docker ps 查看到,有start 就有stop,和restart

之前我们使用的docker run 相当于先create再start

docker run -it centos bash

这样进入了一个虚拟终端里面,我们可以运行一些命令,使用命令exit或者ctrl d 退出该bash,当退出后这个容器也会停止。

docker run -d 可以让容器在后台运行

比如:docker run -d centos bash -c “while :; do echo “123”; sleep 2; done”

docker run --name web -itd centos bash // --name 给容器自定义名字

docker run --rm -it centos bash -c “sleep 30” //–rm 可以让容器退出后直接删除,在这里命令执行完容器就会退出

docker logs 可以获取到容器的运行历史信息,用法如下

docker logs container_id

docker attach 可以进入一个后台运行的容器,比如

docker attach container_id //但是attach命令不算好用,比如我们想要退出终端,就得exit了,这样容器也就退出了,还有一种方法

docker exec -it container_id bash //可以临时打开一个虚拟终端,并且exit后,容器依然运行着

docker rm container_id //container_id是ps的时候查看到的,这样就可以把container删除,如果是运行的容器,可以加-f

docker export container_id > file.tar // 导出容器,可以迁移到其他机器上,需要导入

cat file.tar |docker import - aming_test //这样会生成aming_test的镜像

二、仓库管理

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

docker run -d -p 5000:5000 registry //以registry镜像启动容器,-p会把容器的端口映射到宿主机上,:左边为宿主机监听端口,:右边为容器监听端口

curl 127.0.0.1:5000/v2/_catalog //可以访问它

下面我们来把其中一个镜像上传到私有仓库

docker tag aming_test 172.7.15.113:5000/centos //标记一下tag,必须要带有私有仓库的ip:port

docker push 172.7.15.113:5000/centos //把标记的镜像给推送到私有仓库

此时并不会成功,Get https://172.7.15.113:5000/v2/: http: server gave HTTP response to HTTPS client

更改配置文件,vi /etc/docker/daemon.json//更改为
{ “insecure-registries”:[“172.7.15.113:5000”] }

systemctl restart docker

docker ps -a //查看容器已经关闭,还需要启动

docker start id //这里的id为registry容器id

再次push

docker push 172.7.15.113:5000/centos

curl 127.0.0.1:5001/v2/_catalog //可以查看到推送上来的镜像

三、数据管理

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

2.挂载数据卷
其实我们挂载目录的时候,可以指定容器name,如果不指定就随机定义了。比如上面我们没有指定,它就生成了一个名字为relaxed_franklin,这个名字可以使用命令 docker ps 看最右侧一列

docker run -itd --volumes-from relaxed_franklin aming123 bash

这样,我们使用aming123镜像创建了新的容器,并且使用了 relaxed_franklin 容器的数据卷

3 定义数据卷容器
有时候,我们需要多个容器之间相互共享数据,类似于linux里面的NFS,所以就可以搭建一个专门的数据卷容器,然后其他容器直接挂载该数据卷。

首先建立数据卷容器
docker run -itd -v /data/ --name testvol centos bash //注意这里的/data/是容器的/data目录,并非本地的/data/目录。

然后让其他容器挂载该数据卷

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

四、数据卷备份恢复

备份

mkdir /data/backup

docker run --volumes-from testvol -v /data/backup/:/backup centos tar cvf /backup/data.tar /data/

说明:首先我们需要使用testvol数据卷新开一个容器,同时我们还需要把本地的/vol_data_backup/目录挂载到该容器的/backup下,这样在容器中/backup目录里面新建的文件,我们就可以直接在/data/backup/目录中看到了。 然后再把/data/目录下面的文件打包到成data.tar文件放到/backup目录下面。

恢复

思路: 先新建一个数据卷容器,再建一个新的容器并挂载该数据卷容器,然后再把tar包解包。

新建数据卷容器:docker run -itd -v /data/ --name testvol2 centos bash

挂载数据卷新建容器,并解包:docker run --volumes-from testvol2 -v /data/backup/:/backup centos tar xf /backup/data.tar
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值