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


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

    目录

    一.如何管理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. eth0: flags=4163 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 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 源容器名:别名容器互联

  • 相关阅读:
    连续数字阶乘求和
    Mybatis懒加载
    4.1 继承性
    Java项目:SSM网上超市购物商城管理系统
    【Kafka二】架构深入
    贺同学 9 月总结
    【Python 千题 —— 基础篇】列表的最大值与最小值(for 循环版)
    面试中的常问的C++ STL 概念和函数
    Stable Diffusion文生图模型训练入门实战(完整代码)
    基于springboot实现校友社交平台管理系统项目【项目源码+论文说明】
  • 原文地址:https://blog.csdn.net/weixin_67474417/article/details/125827088