飞道的博客

带拐友们认识docker的数据管理

416人阅读  评论(0)

前言:这段时间没有前言哦

目录

一.如何管理docker容器中的数据

二.数据卷

2.1数据卷原理

2.2数据卷作用

2.3数据卷案例

三.数据卷容器​

3.1数据卷容器的作用

3.2端口映射

四.容器互联(使用centos镜像)​

 五.总结


一.如何管理docker容器中的数据

 管理Docker 容器中数据主要有两种方式:数据卷(Data Volumes)和数据卷容器( DataVolumes Containers) 。

二.数据卷

2.1数据卷原理

  • 数据卷是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于​​​Linux下对目录进行的mount操作​​​。
docker pull centos:7
  • 宿主机目录/var/www挂载到容器中的/data1。​​
  • 注意:宿主机本地目录的路径必须是使用绝对路径​​​。如果路径不存在,Docker会自动创建相应的路径。

2.2数据卷作用

  • 数据卷是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于Linux下对目录进行的 mount操作。

2.3数据卷案例


  
  1. docker run -v /var/www:/data1 --name web1 -it centos:7 #-v选项可以在容器内创建数据卷
  2. ls
  3. echo "this is hehe" > /data1/abc.txt
  4. exit
  5. #返回宿主机进行查看
  6. cat /var/www/1.txt

三.数据卷容器​

3.1数据卷容器的作用

  • 让两个容器实现数据共享
  • 如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。
  • php ---->mysql之间想要通讯,通过socket

  
  1. #创建一个容器作为数据卷容器
  2. docker run -it --name hehe1 -v /data1 -v /data2 centos:7 bash #创建并进入容器
  3. echo "this is hehe" > /data1/1.txt #容器内创建测试文件1
  4. echo "THIS IS jiajia" > /data2/2.txt #容器内创建测试文件1
  5. #使用--volumes-from来挂载test2容器中的数据卷到新的容器
  6. docker run -it --name hehe3 --volumes-from hehe1 centos:7 bash #创建并进入容器
  7. cat data1/1.txt #查看测试数据是否同步
  8. cat data2/2.txt

3.2端口映射

  • 在启动容器的时候,如果不指定对应的端口,在容器外是无法通过网络来访问容器内的服务。端口映射机制将容器内的服务提供给外部网络访问,实质上就是​​​将宿主机的端口映射到容器中​​​,使得外部网络访问宿主机的端口便可访问容器内的服务。

  
  1. docker run -d --name test1 -P nginx #随机映射端口(从32768开始)
  2. docker run -d --name test2 -p 43000:80 nginx #指定映射端口
  3. docker ps -a
  4. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  5. b184b7cde489 nginx "/docker-entrypoint.…" 38 seconds ago Up 38 seconds 0.0. 0.0: 43000-> 80/tcp, ::: 43000-> 80/tcp test2
  6. ae1bc1705d3d nginx "/docker-entrypoint.…" 58 seconds ago Up 56 seconds 0.0. 0.0: 49153-> 80/tcp, ::: 49153-> 80/tcp test1
  7. 浏览器访问: http:// 192.168. 226.60: 43000. http:// 192.168. 226.60: 49153

四.容器互联(使用centos镜像)​

  • 容器互联是通过容器的名称在容器间建立一条专门的网络通信隧道。简单点说,就是会在​​​源容器和接收容器之间建立一条隧道​​​,接收容器可以看到源容器指定的信息。

  
  1. #查看容器
  2. [root@zhang ~] # docker ps -a
  3. CONTAINER ID IMAGE COMMAND CREATED STATUS
  4. 158957809fc2 centos: 7 "bash" 13 minutes ago Up 12 minutes c1
  5. 4523b97e73ad centos: 7 "/bin/bash" 42 minutes ago Up 13 minutes c2
  6. b5bee0279cad nginx:latest "/docker-entrypoint.…" 51 minutes ago Created admiring_golick
  7. #进入c1,ping c2发现ping不通
  8. [root@zhang ~] # docker exec -it c1 bash
  9. [root@ce7ebeacc41d /] # ping c2
  10. ping: c2: Name or service not known
  11. [root@ce7ebeacc41d /] # exit
  12. exit
  13. #创建并运行接收容器取名c3,使用--1ink选项指定连接容器以实现容器互联
  14. #--1ink容器名:连接的别名
  15. [root@zhang ~] # docker run -itd -P --name c3 --link c2:c2 centos:7 /bin/bash
  16. c4adb8c6e0e802f5119bccebfb1a95b1ca344644aaf54b8501bd98350617ee46
  17. #进入c3,ping c2 可以ping通
  18. [root@zhang ~] # docker exec -it c3 bash
  19. [root@c4adb8c6e0e8 /] # ping c2
  20. PING c2 ( 172.17. 0. 3) 56( 84) bytes of data.
  21. 64 bytes from c2 ( 172.17. 0. 3): icmp_seq= 1 ttl= 64 time= 0. 074 ms
  22. 64 bytes from c2 ( 172.17. 0. 3): icmp_seq= 2 ttl= 64 time= 0. 246 ms
  23. 64 bytes from c2 ( 172.17. 0. 3): icmp_seq= 3 ttl= 64 time= 0. 167 ms
  24. ^C
  25. --- c2 ping statistics ---
  26. 3 packets transmitted, 3 received, 0% packet loss, time 2000ms
  27. rtt min/avg/max/mdev = 0. 074/ 0. 162/ 0. 246/ 0. 071 ms
  28. [root@c4adb8c6e0e8 /] # exit
  29. exit
  30. #进入c3容器,查看ip
  31. [root@zhang ~] # docker exec -it c3 bash
  32. [root@c4adb8c6e0e8 /] # ping 172.17.0.3
  33. PING 172.17. 0. 3 ( 172.17. 0. 3) 56( 84) bytes of data.
  34. 64 bytes from 172.17. 0. 3: icmp_seq= 1 ttl= 64 time= 0. 050 ms
  35. 64 bytes from 172.17. 0. 3: icmp_seq= 2 ttl= 64 time= 0. 120 ms
  36. 64 bytes from 172.17. 0. 3: icmp_seq= 3 ttl= 64 time= 0. 116 ms
  37. ^C
  38. --- 172.17. 0. 3 ping statistics ---
  39. 3 packets transmitted, 3 received, 0% packet loss, time 2000ms
  40. rtt min/avg/max/mdev = 0. 050/ 0.095/ 0. 120/ 0. 033 ms
  41. [root@c4adb8c6e0e8 /] # exit
  42. exit
  43. [root@zhang ~] # docker exec -it c2 bash
  44. [root@48f1749e6be4 /] # yum install -y net-tools
  45. ...........
  46. [root@48f1749e6be4 /] # ifconfig
  47. eth 0: flags= 4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
  48. inet 172.17. 0. 2 netmask 255.255. 0. 0 broadcast 172.17. 255.255
  49. ether 02: 42:ac: 11: 00: 03 txqueuelen 0 (Ethernet)
  50. RX packets 4468 bytes 24538555 ( 23.4 MiB)
  51. RX errors 0 dropped 0 overruns 0 frame 0
  52. TX packets 3297 bytes 181507 ( 177.2 KiB)
  53. TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
  54. lo: flags= 73<UP,LOOPBACK,RUNNING> mtu 65536
  55. inet 127.0. 0. 1 netmask 255.0. 0. 0
  56. loop txqueuelen 1000 (Local Loopback)
  57. RX packets 0 bytes 0 ( 0. 0 B)
  58. RX errors 0 dropped 0 overruns 0 frame 0
  59. TX packets 0 bytes 0 ( 0. 0 B)
  60. TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

 五.总结

本文介绍了通过数据卷和数据卷容器对容器内数据进行共享、备份和恢复等操作,通过这些机制,即使容器在运行中出现故障,用户也不必担心数据发生丢失,只需要快速地重新创建容器即可。在生成容器的同时,加上-v选项,指定把当前服务器的目录映射到容器中。

命令 说明
docker run -v 数据卷 创建数据卷
docker run -v 宿主机目录:数据卷 挂载宿主机目录
docker run --volumes-from 数据卷容器 挂载数据卷容器(挂载点路径不变)
docker run --link 源容器名:别名 容器互联


转载:https://blog.csdn.net/weixin_67474417/article/details/125827088
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场