• Docker数据管理


    容器中管理数据主要有两种方式:

    • 数据卷(Data Volumes)
    • 数据卷容器(Data Volume Dontainers)

    数据卷

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

    1. docker pull centos:7
    2. #宿主机目录/var/www 挂载到容器中的/data1
    3. 注意:宿主机本地目录的路径必须是使用绝对路径。如果路径不存在,Docker会自动创建相应的路径。
    4. docker run -v /var/www:/data1 --name web1 -it centos:7 /bin/bash            
    5. #-v 选项可以在容器内创建数据卷
    6. ls
    7. echo "this is web1" > /data1/abc.txt
    8. exit
    9. #返回宿主机进行查看
    10. cat  /var/www/abc.txt

     

    数据卷容器

    如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。
     

    1. #创建一个容器作为数据卷容器
    2. docker run --name web2 -v /data1 -v /data2 -it centos:7 /bin/bash
    3. echo "this is web2" > /data1/abc.txt
    4. echo "THIS IS WEB2" > /data2/ABC.txt
    5. #使用 --volumes-from 来挂载 web2 容器中的数据卷到新的容器
    6. docker run -it --volumes-from web2 --name web3 centos:7 /bin/bash
    7. cat /data1/abc.txt
    8. cat /data2/ABC.txt


    容器互联(使用centos镜像)

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

    1. #创建并运行源容器取名web1
    2. docker run -itd -P --name web1 centos:7 /bin/bash    
    3.     
    4. #创建并运行接收容器取名web2,使用--link选项指定连接容器以实现容器互联
    5. docker run -itd -P --name web2 --link web1:web1 centos:7 /bin/bash            #--link 容器名:连接的别名
    6. #进web2 容器, ping web1
    7. docker exec -it web2 bash
    8. ping web1

     

  • 相关阅读:
    Python字典全解析:从基础到高级应用
    第 362 场 LeetCode 周赛题解
    肉苁蓉苷F与牛血清白蛋白偶联物 Cistanoside F-BSA
    ReentrantReadWriteLock读写锁实现原理详解
    React Redux 中触发异步副作用
    golang字符串转64位整数
    算法——多数相和
    PropType是一个TypeScript的类型,用于指定组件props的类型
    数据化管理洞悉零售及电子商务运营——零售密码
    能源路由器入门必读:面向能源互联网的架构和功能
  • 原文地址:https://blog.csdn.net/weixin_54959847/article/details/133696906