当有容器在运行时,我们可以查看运行中的容器
docker ps
查看所有运行过的容器
docker ps -a
查看容器的运行日志
docker logs -tf --tail 10 容器id
查看容器内进程信息
docker top 容器id
查看容器内元数据
docker inspect 容器id
我们的容器运行一般都是运行在后台的,所以,当我们需要进入容器内修改容器需要以下命令
1、第一种
docker exec -it 容器id bashshell
-it表示已交互的模式进入到容器内
2、
docker attach 容器id
从容器内拷贝文件到主机
docker cp 容器id:容器内路径 目的地主机路径
当出现容器名已经被使用时,如下如
我们需要使用命令,查出当前容器名的容器id
docker ps -a|grep portainer_agent
通过容器id,删除该容器。
docker rm 容器id
docker commit 提交容器成为一个新的副本
docker commit -m =“提交的描述信息” -a=“作者” 容器id 目标镜像名:【TAG】(tag版本信息,选填)
#docker run -it -v 主机目录:容器内目录 镜像名 /bin/bash
docker run -it -v /home/ceshi:/home centos /bin/bash
使用docker
容器快速启动mysql
,并且使用数据卷技术实现文件映射,文件保存在本地。
docker run -d --name mysql01 -p 3310:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=13456979826a mysql:5.7
在使用数据卷volumed的时候如果没有指定本地的映射目录。默认会存在
/var/lib/docker/volumes
目录下,当前目录下会有多个数据卷。
- 首先应该启动一个容器docker01
docker run -it --name docker01 镜像id
- docker02启动
docker run -it --name docker02 --volumes-from docker01(父容器) 镜像id
通过以上,docker01容器内的文件,会同步到docker02
- 当有docker03使用命令
--volumes-from docker01
的时候,docker03也会与docker01文件数据保持同步。
只要有一个容器在使用文件。其他容器停止的话,文件也是不受影响的
通过以上,我们知道了通过数据卷容器之间的文件数据是可以互通的。
当我们想使用mysql共享数据时,我们只需要使用数据卷,将文件共享。。当有多个mysql启动,我们都使用--volumes-from
(继承)到我们需要同步文件的容器
docker run -d --name mysql01 -p 3310:3306 -v /etc/mysql/conf.d -v /var/lib/mysql -e MYSQL_ROOT_PASSWORD=13456979826a mysql:5.7
以上命令表示将/etc/mysql/conf.d
和/var/lib/mysql
两个文件或文件夹通过数据卷共享出去。当有其他的mysql启动,使用--volume-from mysql:5.7
,便可以与mysql01共享数据
docker run -d --name mysql02 -p 3310:3306 --volumes-from mysql01 -e MYSQL_ROOT_PASSWORD=13456979826a mysql:5.7
这样mysql01与mysql02便可以数据共享
#docker network create 网络模式 IP地址/子网掩码 网关地址
docker network create --driver bridge --subnet 192.168.0.0/16 --gateway 192.168.0.1
当使用了我们自定义的网络运行了几个容器时。我们就可以通过容器名或者ip地址相互之间ping通。
如果使用的默认的网络模式。我们只能通过ip地址才能相互ping通。
如果容器重启,IP地址更换。便无法通过ip地址进行容器之间连接。我们需要使用
--link
命令进行容器之间的关联。双方容器需要互相关联。才能互相访问
当不同网络下的容器需要进行连接网络时。我们可以使用connect
命令让不同网络下的容器进行关联
- 实例:
#通过网络连接到容器
docker network connect 网络名 容器名
1、创建一个redis的专有网络
docker network create redis --subnet 172.38.0.0/16
2、使用shell命令创建6个redis的配置文件
for port in $(seq 1 6); \
do \
mkdir -p /mydata/redis/node-${port}/conf;
touch /mydata/redis/node-${port}/conf/redis.conf
cat << EOF >/mydata/redis/node-${port}/conf/redis.conf
port 6379
bind 0.0.0.0
daemonize no
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
cluster-announce-ip 172.38.0.1${port}
cluster-announce-port 6379
cluster-announce-bus-port 16379
appendonle yes
EOF
done
3.1、通过for循环一次启动六个容器
for port in $(seq 1 6); \
do \
docker run -p 637 p o r t : 6379 − p 1637 {port}:6379 -p 1637 port:6379−p1637{port}:16379 --name redis-${port} \
-v /mydata/redis/node-${port}/data:/data \
-v /mydata/redis/node-${port}/conf/redis.conf:/etc/redis/redis.conf \
-d --net redis --ip 172.38.0.1${port} redis:5.0.9-alpine3.11 redis-server /etc/redis/redis.conf
done
3.2、依次启动六个容器
docker run -p 6371:6379 -p 16371:16379 --name redis-1 \
-v /mydata/redis/node-1/data:/data \
-v /mydata/redis/node-1/conf/redis.conf:/etc/redis/redis.conf \
最后
文章中涉及到的知识点我都已经整理成了资料,录制了视频供大家下载学习,诚意满满,希望可以帮助在这个行业发展的朋友,在论坛博客等地方少花些时间找资料,把有限的时间,真正花在学习上,所以我把这些资料,分享出来。相信对于已经工作和遇到技术瓶颈的朋友们,在这份资料中一定都有你需要的内容。