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

相关推荐
java叶新东老师1 小时前
git stash 命令详解
linux·运维·flink
写bug的羊羊2 小时前
CentOS 9 配置国内 YUM 源
linux·运维·centos
国科安芯4 小时前
抗辐照芯片在低轨卫星星座CAN总线通讯及供电系统的应用探讨
运维·网络·人工智能·单片机·自动化
gx23484 小时前
HCLP--MGER综合实验
运维·服务器·网络
angushine4 小时前
鲲鹏服务器部署Kafka2.8.1
运维·服务器
一个网络学徒6 小时前
MGRE综合实验
运维·服务器·网络
C++ 老炮儿的技术栈6 小时前
在 Scintilla 中为 Squirrel 语言设置语法解析器的方法
linux·运维·c++·git·ubuntu·github·visual studio
ldj20206 小时前
Docker的docker-compose类比Spring的ApplicationContext
spring·docker
白鹭6 小时前
基于LNMP架构的分布式个人博客搭建
linux·运维·服务器·网络·分布式·apache
ldj20207 小时前
docker 自定义网桥作用
docker·容器