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

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

管理Docker 容器中数据主要有两种方式:数据卷(Data Volumes)和数据卷容器( DataVolumes Containers) 。
二.数据卷
2.1数据卷原理
- 数据卷是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于Linux下对目录进行的mount操作。
docker pull centos:7
- 宿主机目录/var/www挂载到容器中的/data1。
- 注意:宿主机本地目录的路径必须是使用绝对路径。如果路径不存在,Docker会自动创建相应的路径。
2.2数据卷作用
- 数据卷是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于Linux下对目录进行的 mount操作。
2.3数据卷案例
  
   - 
    
     
    
    
     
      docker run -v /var/www:/data1 --name web1 -it centos:7     
      #-v选项可以在容器内创建数据卷
     
    
- 
    
     
    
    
     
      ls
     
    
- 
    
     
    
    
     
      echo 
      "this is hehe" > /data1/abc.txt
     
    
- 
    
     
    
    
     
      exit
     
    
- 
    
     
    
    
      
     
    
- 
    
     
    
    
     
      #返回宿主机进行查看
     
    
- 
    
     
    
    
     
      cat /var/www/1.txt
     
    

三.数据卷容器
3.1数据卷容器的作用
- 让两个容器实现数据共享
- 如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。
- php ---->mysql之间想要通讯,通过socket
  
   - 
    
     
    
    
     
      #创建一个容器作为数据卷容器
     
    
- 
    
     
    
    
     
      docker run -it --name hehe1 -v /data1 -v /data2 centos:7 bash 
      #创建并进入容器
     
    
- 
    
     
    
    
     
      echo 
      "this is hehe" > /data1/1.txt 
      #容器内创建测试文件1
     
    
- 
    
     
    
    
     
      echo 
      "THIS IS jiajia" > /data2/2.txt 
      #容器内创建测试文件1
     
    
- 
    
     
    
    
      
     
    
- 
    
     
    
    
     
      #使用--volumes-from来挂载test2容器中的数据卷到新的容器
     
    
- 
    
     
    
    
     
      docker run -it --name hehe3 --volumes-from hehe1 centos:7 bash 
      #创建并进入容器
     
    
- 
    
     
    
    
     
      cat data1/1.txt 
      #查看测试数据是否同步
     
    
- 
    
     
    
    
     
      cat data2/2.txt
     
    

3.2端口映射
- 在启动容器的时候,如果不指定对应的端口,在容器外是无法通过网络来访问容器内的服务。端口映射机制将容器内的服务提供给外部网络访问,实质上就是将宿主机的端口映射到容器中,使得外部网络访问宿主机的端口便可访问容器内的服务。
  
   - 
    
     
    
    
     
      docker run -d 
      --name test1 -P nginx #随机映射端口(从32768开始)
     
    
- 
    
     
    
    
     
      docker run -d 
      --name test2 -p 43000:80 nginx #指定映射端口
     
    
- 
    
     
    
    
     
      docker ps -a
     
    
- 
    
     
    
    
     
      CONTAINER 
      ID   
      IMAGE      
      COMMAND                  
      CREATED          
      STATUS                          
      PORTS                                     
      NAMES
     
    
- 
    
     
    
    
     
      b184b7cde489   nginx      
      "/docker-entrypoint.…"   
      38 seconds ago   
      Up 
      38 seconds                   
      0.0.
      0.0:
      43000->
      80/tcp, :::
      43000->
      80/tcp   test2
     
    
- 
    
     
    
    
     
      ae1bc1705d3d   nginx      
      "/docker-entrypoint.…"   
      58 seconds ago   
      Up 
      56 seconds                   
      0.0.
      0.0:
      49153->
      80/tcp, :::
      49153->
      80/tcp   test1
     
    
- 
    
     
    
    
      
     
    
- 
    
     
    
    
     
      浏览器访问: http://
      192.168.
      226.60:
      43000. http://
      192.168.
      226.60:
      49153
     
    


四.容器互联(使用centos镜像)
- 容器互联是通过容器的名称在容器间建立一条专门的网络通信隧道。简单点说,就是会在源容器和接收容器之间建立一条隧道,接收容器可以看到源容器指定的信息。
  
   - 
    
     
    
    
     
      #查看容器
     
    
- 
    
     
    
    
     
      [root@zhang ~]
      # docker ps -a
     
    
- 
    
     
    
    
     
      CONTAINER ID   IMAGE          COMMAND                  CREATED        STATUS              
     
    
- 
    
     
    
    
     
      158957809fc2   centos:
      7       
      "bash"                   
      13 minutes ago   Up 
      12 minutes             c1
     
    
- 
    
     
    
    
     
      4523b97e73ad   centos:
      7       
      "/bin/bash"              
      42 minutes ago   Up 
      13 minutes             c2
     
    
- 
    
     
    
    
     
      b5bee0279cad   nginx:latest   
      "/docker-entrypoint.…"   
      51 minutes ago   Created                   admiring_golick
     
    
- 
    
     
    
    
      
     
    
- 
    
     
    
    
      
     
    
- 
    
     
    
    
     
      #进入c1,ping c2发现ping不通
     
    
- 
    
     
    
    
     
      [root@zhang ~]
      # docker exec -it c1 bash
     
    
- 
    
     
    
    
     
      [root@ce7ebeacc41d /]
      # ping c2
     
    
- 
    
     
    
    
     
      ping: c2: Name 
      or service 
      not known
     
    
- 
    
     
    
    
     
      [root@ce7ebeacc41d /]
      # exit
     
    
- 
    
     
    
    
     
      exit
     
    
- 
    
     
    
    
      
     
    
- 
    
     
    
    
     
      #创建并运行接收容器取名c3,使用--1ink选项指定连接容器以实现容器互联
     
    
- 
    
     
    
    
     
      #--1ink容器名:连接的别名
     
    
- 
    
     
    
    
     
      [root@zhang ~]
      # docker run -itd -P --name c3 --link c2:c2 centos:7 /bin/bash
     
    
- 
    
     
    
    
     
      c4adb8c6e0e802f5119bccebfb1a95b1ca344644aaf54b8501bd98350617ee46
     
    
- 
    
     
    
    
      
     
    
- 
    
     
    
    
     
      #进入c3,ping c2 可以ping通
     
    
- 
    
     
    
    
     
      [root@zhang ~]
      # docker exec -it c3 bash
     
    
- 
    
     
    
    
     
      [root@c4adb8c6e0e8 /]
      # ping c2
     
    
- 
    
     
    
    
     
      PING c2 (
      172.17.
      0.
      3) 
      56(
      84) bytes of data.
     
    
- 
    
     
    
    
     
      64 bytes from c2 (
      172.17.
      0.
      3): icmp_seq=
      1 ttl=
      64 
      time=
      0.
      074 ms
     
    
- 
    
     
    
    
     
      64 bytes from c2 (
      172.17.
      0.
      3): icmp_seq=
      2 ttl=
      64 
      time=
      0.
      246 ms
     
    
- 
    
     
    
    
     
      64 bytes from c2 (
      172.17.
      0.
      3): icmp_seq=
      3 ttl=
      64 
      time=
      0.
      167 ms
     
    
- 
    
     
    
    
     
      ^C
     
    
- 
    
     
    
    
     
      --- c2 ping statistics ---
     
    
- 
    
     
    
    
     
      3 packets transmitted, 
      3 received, 
      0% packet loss, 
      time 
      2000ms
     
    
- 
    
     
    
    
     
      rtt min/avg/max/mdev = 
      0.
      074/
      0.
      162/
      0.
      246/
      0.
      071 ms
     
    
- 
    
     
    
    
     
      [root@c4adb8c6e0e8 /]
      # exit
     
    
- 
    
     
    
    
     
      exit
     
    
- 
    
     
    
    
      
     
    
- 
    
     
    
    
     
      #进入c3容器,查看ip
     
    
- 
    
     
    
    
     
      [root@zhang ~]
      # docker exec -it c3 bash
     
    
- 
    
     
    
    
     
      [root@c4adb8c6e0e8 /]
      # ping 172.17.0.3
     
    
- 
    
     
    
    
     
      PING 
      172.17.
      0.
      3 (
      172.17.
      0.
      3) 
      56(
      84) bytes of data.
     
    
- 
    
     
    
    
     
      64 bytes from 
      172.17.
      0.
      3: icmp_seq=
      1 ttl=
      64 
      time=
      0.
      050 ms
     
    
- 
    
     
    
    
     
      64 bytes from 
      172.17.
      0.
      3: icmp_seq=
      2 ttl=
      64 
      time=
      0.
      120 ms
     
    
- 
    
     
    
    
     
      64 bytes from 
      172.17.
      0.
      3: icmp_seq=
      3 ttl=
      64 
      time=
      0.
      116 ms
     
    
- 
    
     
    
    
     
      ^C
     
    
- 
    
     
    
    
     
      --- 
      172.17.
      0.
      3 ping statistics ---
     
    
- 
    
     
    
    
     
      3 packets transmitted, 
      3 received, 
      0% packet loss, 
      time 
      2000ms
     
    
- 
    
     
    
    
     
      rtt min/avg/max/mdev = 
      0.
      050/
      0.095/
      0.
      120/
      0.
      033 ms
     
    
- 
    
     
    
    
     
      [root@c4adb8c6e0e8 /]
      # exit
     
    
- 
    
     
    
    
     
      exit
     
    
- 
    
     
    
    
     
      [root@zhang ~]
      # docker exec -it c2 bash
     
    
- 
    
     
    
    
     
      [root@48f1749e6be4 /]
      # yum install -y net-tools
     
    
- 
    
     
    
    
     
      ...........
     
    
- 
    
     
    
    
      
     
    
- 
    
     
    
    
     
      [root@48f1749e6be4 /]
      # ifconfig
     
    
- 
    
     
    
    
     
      eth
      0: flags=
      4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 
      1500
     
    
- 
    
     
    
    
     
              inet 
      172.17.
      0.
      2  netmask 
      255.255.
      0.
      0  broadcast 
      172.17.
      255.255
     
    
- 
    
     
    
    
     
              ether 
      02:
      42:ac:
      11:
      00:
      03  txqueuelen 
      0  (Ethernet)
     
    
- 
    
     
    
    
     
              RX packets 
      4468  bytes 
      24538555 (
      23.4 MiB)
     
    
- 
    
     
    
    
     
              RX errors 
      0  dropped 
      0  overruns 
      0  frame 
      0
     
    
- 
    
     
    
    
     
              TX packets 
      3297  bytes 
      181507 (
      177.2 KiB)
     
    
- 
    
     
    
    
     
              TX errors 
      0  dropped 
      0 overruns 
      0  carrier 
      0  collisions 
      0
     
    
- 
    
     
    
    
      
     
    
- 
    
     
    
    
     
      lo: flags=
      73<UP,LOOPBACK,RUNNING>  mtu 
      65536
     
    
- 
    
     
    
    
     
              inet 
      127.0.
      0.
      1  netmask 
      255.0.
      0.
      0
     
    
- 
    
     
    
    
     
              loop  txqueuelen 
      1000  (Local Loopback)
     
    
- 
    
     
    
    
     
              RX packets 
      0  bytes 
      0 (
      0.
      0 B)
     
    
- 
    
     
    
    
     
              RX errors 
      0  dropped 
      0  overruns 
      0  frame 
      0
     
    
- 
    
     
    
    
     
              TX packets 
      0  bytes 
      0 (
      0.
      0 B)
     
    
- 
    
     
    
    
     
              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
查看评论
					