容器卷操作
在Docker中,要想实现数据的持久化(所谓Docker的数据持久化即 数据不随着 Container的结束而结束 ),需要将数据从宿主机挂载到容器中。
目前Docker提供了三种不同的方式将数据从宿主机挂载到容器中;
(1)volumes:Docker管理宿主机文件系统的一部分,默认位于 /var/lib/docker/Volumes目录中;(最常用的方式)
(2)bind mounts:意味着可以存储在宿主机系统的任意位置;(比较常用的方式)
(3)tmpfs:挂载存储在宿主机系统的内存中,而不会写入宿主机的文件系统;(一般不会用的方式)
新卷只能在容器创建过程当中挂载
# docker run -it --name="voltest" -v /tmp:/test daocloud.io/library/centos:7 /bin/bash
共享其他容器的卷
# docker run -it --volumes-from bc4181 daocloud.io/library/centos:7 /bin/bash
实际应用中可以利用多个-v选项把宿主机上的多个目录同时共享给新建容器
比如:
# docker run -it -v /abc:/abc -v /def:/def lae9
访问容器应用-端口转发
使用端口转发解决容器端口访问问题
-p:
创建应用容器的时候,一般会做端口映射,这样是为了让外部能够访问这些容器里的应用。可以用多个-p指定多个端口映射关系。
mysql应用端口转发:
查看本地地址:
# ip a
ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
link/ether 00:0c:29:24:ef:d3 brd ff:ff:ff:ff:ff:ff
inet 192.168.160.15/24 brd 192.168.160.255 scope global ens33
valid_lft forever preferred_lft forever
运行容器:使用-p作端口转发,把本地3307转发到容器的3306,其他参数需要查看发布容器的页面提示
# docker run --name mysql1 -p 3307:3306 -e MYSQL_ROOT_PASSWORD=12 daocloud.io/library/mysql:5.7
查看IP地址:
[root@docker tmp]# docker inspect nginx1 | grep IPAddress
"SecondaryIPAddresses": null,
"IPAddress": "172.17.0.3",
"IPAMConfig": null,
"IPAddress": "172.17.0.3",
通过本地IP:192.168.160.15的3307端口访问容器mysql内的数据库,出现如下提示恭喜你
[root@docker ~]# mysql -uroot -p -h 192.168.160.15 -P3307
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 24144
Server version: 5.7.29 MySQL Community Server (GPL)
Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>
-P:
当使用-P标记时,Docker会随机映射一个49000~49900的端口到内部容器开放的网络端口。如下:
[root@docker ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
tiger/mynginx v1 9c18f18948a3 2 days ago 367MB
daocloud.io/library/centos 7 b5b4d78bc90c 3 months ago 203MB
[root@docker ~]# docker run --name myredis -P -d docker.io/redis
88bf84df36a9777d2a2127036103ab2e88d67b3959885bd3d560efd4062b9478
[root@docker ~]# docker ps
88bf84df36a9 docker.io/redis "docker-entrypoint.sh" 4 seconds ago UP 3 seconds 0.0.0.0:32768->6379/tcp myredis
从上面的结果中可以看到,本地主机的32768端口被映射到了redis容器的6379端口上,也就是说访问本机的32768端口即可访问容器内redis端口
测试看下,登录redis容器,随意写个数据
[root@docker ~]# docker run --rm -it --name myredis2 --link myredis:redisdb docker.io/redis /bin/bash
root@be33d955d6f4:/data# redis-cli -h redisdb -p 6379
redisdb:6379> set tiger 123
OK
redisdb:6379>
在别的机器上通过上面映射的端口32768连接这个容器的redis
# redis-cli -h 192.168.160.15 -p 32768
192.168.160.15:32768> get tiger
"123"
评论区