首页 > 其他分享 >Docker数据管理

Docker数据管理

时间:2023-02-10 17:36:45浏览次数:67  
标签:容器 -- 宿主机 数据管理 挂载 Docker 数据 docker

一.docker容器数据管理

  • 管理 Docker 容器中数据主要有两种方式:数据卷(Data Volumes)和数据卷容器(DataVolumes Containers)。

1.1 数据卷

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

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

#返回宿主机进行查看
cat  /var/www/abc.txt

1.2 数据卷容器

  •  如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。
  • 数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。
#创建一个容器作为数据卷容器
docker run --name web2 -v /data1 -v /data2 -it centos:7 /bin/bash
echo "this is web2" > /data1/abc.txt
echo "THIS IS WEB2" > /data2/ABC.txt

#使用 --volumes-from 来挂载 web2 容器中的数据卷到新的容器
docker run -it --volumes-from web2 --name web3 centos:7 /bin/bash
cat /data1/abc.txt
cat /data2/ABC.txt

二.docker容器端口映射

  • 在启动容器的时候,如果不指定对应的端口,在容器外是无法通过网络来访问容器内的服务。
  • 端口映射机制将容器内的服务提供给外部网络访问,实质上就是将宿主机的端口映射到容器中,使得外部网络访问宿主机的端口便可访问容器内的服务。
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
9d3c04f57a68   nginx     "/docker-entrypoint.…"   4 seconds ago    Up 3 seconds    0.0.0.0:43000->80/tcp   test2
b04895f870e5   nginx     "/docker-entrypoint.…"   17 seconds ago   Up 15 seconds   0.0.0.0:49170->80/tcp   test1

浏览器访问:http://192.168.61.10:43000    、http://192.168.61.10:49170

 

三.docker容器互联

  • 容器互联是通过容器的名称在容器间建立一条专门的网络通信隧道。
  • 简单点说,就是会在源容器和接收容器之间建立一条隧道,接收容器可以看到源容器指定的信息。
#创建并运行源容器取名web1
docker run -itd -P --name web1 centos:7 /bin/bash    
    
#创建并运行接收容器取名web2,使用--link选项指定连接容器以实现容器互联
docker run -itd -P --name web2 --link web1:web1 centos:7 /bin/bash            //--link 容器名:连接的别名

#进web2 容器, ping web1
docker exec -it web2 bash
ping web1

四.总结

4.1数据管理

(1)数据卷(Volume)

数据卷是一个可供一个或多个容器使用的特殊目录,它绕过 Union File System,可以提供很多有用的特性,例如:

①数据卷可以在容器之间共享和重用。

②对数据卷的修改会立马生效,而不需要重启容器。

③即使容器被删除,数据卷也依然存在。

(2)数据卷容器(Data Volume Container)

  • 这是一个特殊的容器,其专用于在其他容器中挂载数据卷。可以将数据卷容器理解为一个特殊的容器,其中的文件被挂载到它的数据卷中,然后由其他容器使用这些文件。

(3)绑定挂载(Bind Mount)

  • 绑定挂载是指将宿主机上的文件或目录挂载到容器中。绑定挂载可以让容器访问宿主机上的文件系统,可以将宿主机上的文件和容器中的文件进行共享,它可以让容器访问宿主机上的资源,同时也可以让宿主机访问容器中的资源。

4.2端口映射

  • 端口映射是指将容器中的端口映射到宿主机的端口,从而可以从宿主机访问容器中的服务。端口映射可以让容器提供一个公开的服务,可以将容器中的服务暴露给外部网络,可以让外部网络访问容器中的服务。

 

标签:容器,--,宿主机,数据管理,挂载,Docker,数据,docker
From: https://www.cnblogs.com/suoluo212/p/17093994.html

相关文章

  • mongo数据库docker环境删除数据释放空间
    整理mongo环境存入数据1、先删除部分数据db.xxx.remove({ createBy: ""})2、查询数量db.xxx.find({}).count()3、进入容器dockerexec-itid bash4、进入mongo......
  • 【Docker】部署Kibana
    本来是想使用DockerHub中提供的标签​​dockerpullkibana​​来让其默认选择最新版本的,但是在获取的过程中就出现以下报错:Errorresponsefromdaemon:manifestforkiba......
  • docker-compose 常见配置参数
    docker-compose编撰规范:https://docs.docker.com/compose/compose-file/cpus已经弃用mem_limit已经弃用1、限制系统资源文档地址:https://docs.docker.com/compo......
  • Docker Compose容器编排
    一、Docker-Compose1.1、什么是DockerComposeCompose项目是Docker官方的开源项目,负责实现Docker容器集群的快速编排,开源代码在https://github.com/docker/compo......
  • 最新面试题2021年常见Docker面试题及答案汇总
    最新面试题2021年常见Docker面试题及答案汇总全部面试题答案,更新日期:01月30日,直接下载吧!下载链接:高清500+份面试题资料及电子书,累计10000+页大厂面试题PDFDocker题......
  • Docker的初识
    一、Docker概述1、Docker的概念•Docker是一个开源的应用容器引擎,基于go语言开发并遵循了apache2.0协议开源•Docker是在Linux容器里运行应用的开源工具,是一种轻量级......
  • docker 下MySQL主从读写分离配置
    主从同步机制:同步基于耳机子机制,主服务器使用二进制来记录数据库的变动状况,从服务器通过读取和执行日志文件来保存主服务的数据一致首先要保障主从的版本一致或相近1......
  • 远程连接DOCKER
    /etc/systemd/system/docker.service.d/override.conf写入文件##AddthistothefileforthedockerdaemontousedifferentExecStartparameters(morethingsca......
  • 用docker打包一个前端项目
    思路:将dist包打包成一个镜像(要不打出的镜像特别大)Dockerfile:如下FROMnginx:latestCOPYdist/auth-centerWORKDIRauth-centerCOPYnginx.conf/etc/nginx/con......
  • docker命令学习
    一篇学会使用docker(超详细)原创 艺说IT 艺说IT 2022-11-2615:07 发表于广西收录于合集#docker1个#容器技术1个#容器命令1个一、docker介绍Docker是......