docker的数据管理

目录

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

二.数据卷

2.1数据卷原理

2.2数据卷作用

2.3数据卷案例

三.数据卷容器

3.1数据卷容器的作用

3.2端口映射

一.如何管理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 niuma3 -v /data1 -v /data2 centos:7 bash #创建并进入容器
    echo "this is niuma" > /data1/1.txt #容器内创建测试文件1
    echo "THIS IS niuma2" > /data2/2.txt #容器内创建测试文件1

    #使用--volumes-from来挂载test2容器中的数据卷到新的容器
    docker run -it --name niuma4 --volumes-from niuma3 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 #指定映射端口
    [root@localhost containers]# docker ps -a
    CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
    ad869aa1016a nginx "/docker-entrypoint...." 19 seconds ago Up 18 seconds 0.0.0.0:43000->80/tcp, :::43000->80/tcp test2
    0afa76acdc9b nginx "/docker-entrypoint...." 34 seconds ago Up 33 seconds 0.0.0.0:32768->80/tcp, :::32768->80/tcp test1

    浏览器访问: http://192.168.40.23:43000. http://192.168.40.23:32768

相关推荐
D-海漠15 分钟前
基础自动化系统的特点
运维·自动化
我言秋日胜春朝★23 分钟前
【Linux】进程地址空间
linux·运维·服务器
C-cat.1 小时前
Linux|环境变量
linux·运维·服务器
wenyue11211 小时前
Revolutionize Your Kubernetes Experience with Easegress: Kubernetes Gateway API
容器·kubernetes·gateway
yunfanleo1 小时前
docker run m3e 配置网络,自动重启,GPU等 配置渠道要点
linux·运维·docker
烦躁的大鼻嘎2 小时前
【Linux】深入理解GCC/G++编译流程及库文件管理
linux·运维·服务器
乐大师2 小时前
Deepin登录后提示“解锁登陆密钥环里的密码不匹配”
运维·服务器
ac.char2 小时前
在 Ubuntu 上安装 Yarn 环境
linux·运维·服务器·ubuntu
敲上瘾2 小时前
操作系统的理解
linux·运维·服务器·c++·大模型·操作系统·aigc
梅见十柒3 小时前
wsl2中kali linux下的docker使用教程(教程总结)
linux·经验分享·docker·云原生