19-数据持久化-Bind Mounting

19-数据持久化-Bind Mounting

Bind Mounting 与 Data Volume区别

Data Volume 需要在 Dockerfile 内声明需要创建的 volume 目录。

Bind Mounting 则不需要在 Dockerfile 声明 volume,只需要在创建容器的时候,也就是 run 的时候声明即可。

如:

docker run -v /home/aaa:/root/aaa demo

上一节中 -v 参数是 mysql:/var/lib/mysql,冒号 “:” 左边是对 /var/lib/mysql 这个目录产生的volume起一个别名。

而在 Bind Mounting 中,-v 参数冒号 “:” 左边是本地的目录路径,右边是创建容器内的路径,做一个映射。

Bind Mounting

通过 Bind Mounting 创建的 volume,在我们修改本地的目录时,容器内对应的目录也会跟着修改,因为是同一个volume。

接下来我们通过一个实验来查看。

  1. 创建一个docker-nginx文件夹,并进入

    mkdir docker-nginx
    cd docker-nginx
    
  2. 创建Dockerfiile和index.html两个文件

    touch Dockerfile index.html
    

    修改Dockerfile文件如下:

    FROM nginx:latestWORKDIR /usr/share/nginx/htmlCOPY index.html index.html
    

    修改index.html文件如下:

    <html>
    <body><h1>Bind Mounting</h1><p>This is a demo.</p></body>
    </html>
    
  3. 创建镜像

    docker build -t vincent/my-nginx .
    
  4. 创建容器

    docker run -d -p 80:80 --name web vincent/my-nginx
    

    查看运行状态

    [vagrant@10 docker-nginx]$ docker ps
    CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                NAMES
    190b2e296c54        vincent/my-nginx    "nginx -g 'daemon of…"   2 seconds ago       Up 1 second         0.0.0.0:80->80/tcp   web
    

    可以看到web容器是up的。

  5. 访问本机80端口获取web容器的内容

    [vagrant@10 docker-nginx]$ curl 127.0.0.1
    <html>
    <body><h1>Bind Mounting</h1><p>This is a demo.</p></body>
    </html>
    

    curl使用http协议的时候默认是80端口,https默认是443,我们是可以不需要加端口号的。

    我们也可以在笔记本中去访问这台虚拟机的80端口服务

     vincent@dell-Inspiron-7559$: curl http://192.168.2.32
    <html>
    <body><h1>Bind Mounting</h1><p>This is a demo.</p></body>
    </html>
    

    也可以通过浏览器访问查看,ip首先要在虚拟机内通过ip a获取。

  6. 重新创建web容器并指定volume

    删除web容器

    docker rm -f web
    

    这条命令会强制删除一个正在运行的容器,不推荐使用。

    重新创建容器,并指定挂载 /home/vagrant/docker-nginx/ 目录。

    docker run -d -p 80:80 -v /home/vagrant/docker-nginx/:/usr/share/nginx/html --name web vincent/my-nginx
    
  7. 查看被挂载的目录在容器内情况

    进入web容器

    docker exec -it web /bin/bash
    

    查看 /usr/share/nginx/html 目录下有哪些内容

    root@cb7e310d02fd:/usr/share/nginx/html# ls /usr/share/nginx/html
    Dockerfile  index.html
    

    我们发现在 /home/vagrant/docker-nginx/ 文件夹内的Dockerfile文件被映射进来了。

    那我们在 /usr/share/nginx/html 文件夹内创建一个 test.txt 文件,看看是否在 外部也能看到

    touch test.txt
    

    创建好之后退出web容器,进入/home/vagrant/docker-nginx/目录下查看

    exit
    [vagrant@10 docker-nginx]$ ls
    Dockerfile  index.html  test.txt
    

    我们发现同样被映射到了外面 docker-nginx 目录下。同样我们可以测试在容器内修改 test.txt 文件看看里外是否同步。

    进入web容器

    docker exec -it web /bin/bash
    

    修改test.txt文件

    root@cb7e310d02fd:/usr/share/nginx/html# echo "1234" >> test.txt 
    root@cb7e310d02fd:/usr/share/nginx/html# cat test.txt 
    1234
    

    完成后我们退出容器并查看这个文件是否同步了

    exit
    [vagrant@10 docker-nginx]$ cat test.txt 
    1234
    

    结果是同样发生了同步。因为我们修改的其实是同一个文件。

热更新

  1. 我们再次执行一次curl获取web内容

    [vagrant@10 flask-app]$ curl 127.0.0.1
    <html>
    <body><h1>Bind Mounting</h1><p>This is a demo.</p></body>
    </html>
    
  2. 此时我们手动修改本机目录下的index.html文件

    nano docker-nginx/index.html
    

    修改如下:

    <html>
    <body><h1>Bind Mounting</h1><p>This is a app.</p></body>
    </html>
    
  3. 验证在不重启nginx服务器的情况下是否web内容发生变化

    [vagrant@10 docker-nginx]$ curl 127.0.0.1
    <html>
    <body><h1>Bind Mounting</h1><p>This is a app.</p></body>
    </html>
    

    我们可以看到web内容已经发生了变化。

这对于开发或后续更新来说是很好的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/536027.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

go自定义包教程

go自定义包教程 而是环境为 go version go1.11 linux/amd64linux mint 19 创建一个自定义的包 切换到src目录下&#xff0c;创建demo目录 cd src mkdir demo再创建smap 文件夹 cd demo mkdir smap创建包文件 cd smap touch map.gomap.go文件内容 package smapimport "…

在Linux中对硬盘进行分区、格式化和挂载

在Linux中对硬盘进行分区、格式化和挂载 我最近有一个全新的4-TB硬盘加入我的电脑。所以我需要在Linux中安装它。为此&#xff0c;我需要执行以下操作&#xff1a; 分区格式化挂载检查是否已安装硬盘驱动器 分区 首先&#xff0c;在通过SATA和电源线将硬盘连接到计算机后&am…

Angular gitlab持续集成之runner配置

gitlab持续集成 安装Runner 正常安装 sudo wget -O /usr/local/bin/gitlab-runner https://gitlab-runner-downloads.s3.amazonaws.com/latest/binaries/gitlab-runner-linux-amd64sudo chmod x /usr/local/bin/gitlab-runner sudo useradd --comment GitLab Runner --creat…

javascript编译压缩

javascript编译 js是JavaScript 源码文件&#xff0c; .min.js是压缩版的js文件。 .min.js文件经过压缩&#xff0c;相对编译前的js文件体积较小&#xff0c;传输效率快。经过编码将变量和函数原命名改为毫无意义的命名&#xff0c;以防止他人窥视和窃取 js 源代码 在线版 g…

vscode设置中文

vscode设置中文 当我们安装完成vscode后&#xff0c;会发现它是中文的&#xff0c;因为默认情况下&#xff0c;vscode使用的语言为英文(us)。 那很多同学是不喜欢英文的&#xff0c;不是看不懂&#xff0c;而是不方便哈。 修改语言配置文件 使用快捷键组合【CtrlShiftp】 在…

linux下编译boost

linux下编译boost 下载boot库 官方下载地址 下载完成会解压。 编译 1.进入解压后的文件夹内 cd boost_1_69_0 执行下面的语句 ./bootstrap.sh --with-librariesall --with-toolsetgcc–with-libraries 指定编译哪些boost库&#xff0c;all的话就是全部编译&#xff0c;只想…

C++通过原子变量代替互斥量

C通过原子变量代替互斥量 废话不多说&#xff0c;直接上代码。 实现类似lock_guard功能 #include <atomic> #include <thread>class ClockGuard { public:ClockGuard(std::atomic_flag & atomic):m_lockedFlag(atomic){lock();}~ClockGuard(){unlock();}voi…

conky安装配置

conky安装配置 安装conky sudo apt-get install conky-all修改配置 在主目录下创建’.conkyrc’ 文件内容&#xff1a; # set to yes if you want Conky to be forked in the background background no cpu_avg_samples 2 net_avg_samples 2 out_to_console no # X font w…

Windows子系统安装图形界面

Windows子系统安装图形界面 有很多同学需要使用 linux 系统,但是又不想真正安装一个 linux 系统。于是微软大哥就把 ubuntu 系统集成到 windows 内了&#xff0c;你说 微软 屌不屌&#xff1f; 言归正传。 安装Xlaunch 因为这个是最靠谱的图形化界面了&#xff0c;所以不解…

C++ 判断类是否有某变量

C 判断类是否有某变量 话不多说上代码。 #define HAS_MEMBER(member)\template<typename T, typename... Args>struct has_member_##member\ {\private:\template<typename U> static auto Check(int) -> decltype(std::declval<U>().member(std::declv…

C++将地址转换为字符串

C将地址转换为字符串 有时候在做程序设计的时候&#xff0c;有可能需要做一个类似messageBus的功能&#xff0c;并且需要一个key保证唯一&#xff0c;那么如何实现这个key的唯一呢&#xff1f;大致两种思路: 使用函数签名&#xff0c;因为messagebus绑定的是一个函数&#xf…

Angular 8之升级和新功能摘要

Angular 8之升级和新功能摘要 Angular 8已经到来,并带来了大量的工作流程和性能改进。就像我们之前发布的几个版本一样,让我们回顾一下Angular 8的新功能,以及如何将Angular 7应用程序升级到Angular 8。 Angular 8中明显的新功能数量有限,但确实还有一些好东西: Differen…

Linux下查看显卡PCIE速率x16x8x4及设定

Linux下查看显卡PCIE速率x16x8x4 由于linux软件并不是很齐全所以查看显卡占用PCIE的带宽并不直观&#xff0c;所以本文介绍如何查看。 Windows下使用GPU-Z即可查看 Linux 确定当前显卡型号 lspci | grep NVIDIA返回 02:00.0 3D controller: NVIDIA Corporation GM107M [GeFor…

Deepin安装最新显卡RTX2080Ti及CUDA10.1

Deepin安装最新显卡RTX2080Ti及CUDA10.1 废话不多说直接上教程。 本系统为Deepin 15.10.2&#xff0c;是基于debian 9发布的&#xff0c;不排除后续deepin升级为debian 10&#xff0c;就目前来看是和ubuntu 16.04一样&#xff0c;使用的是debian 9&#xff0c;所以下载安装包等…

Anaconda安装Tensorflow环境

Anaconda安装Tensorflow环境 Anaconda安装 下载安装包&#xff0c;请到这个地址下载 安装 打开终端执行&#xff1a; bash Anaconda3-5.3.1-Linux-x86_64.sh安装过程全部yes即可。 然后重新启动。 验证是否安装成功 conda --version如果没有报错&#xff0c;并且输出下面内容…

Windows下Qt Creator设置IDE菜单字体样式

Windows下Qt Creator设置IDE菜单字体样式 本文为解决以下问题&#xff1a; IDE的菜单字体太小IDE的菜单字体样式&#xff0c;可以更换为微软雅黑 创建样式文件 在Qt Creator目录下C:\Qt\Qt5.12.2创建 custom-style.css 文件&#xff0c;内容如下&#xff1a; QWidget { fo…

Clonezilla再生龙备份与还原linux系统

文章目录Clonezilla再生龙备份与还原linux系统简介功能与要求一、制作再生龙启动盘1.下载镜像2.制作启动盘二、系统分区三、备份系统四、还原系统注意事项Clonezilla再生龙备份与还原linux系统 简介 再生龙&#xff08;Clonezilla&#xff09;是一个免费的灾难恢复、硬盘克隆…

ubuntu Qt Creator不能输入中文

ubuntu Qt Creator不能输入中文 解决方式为下面的脚本&#xff0c;如果你的Qt是安装在根目录下&#xff0c;那么需要加sudo&#xff0c;如果不是&#xff0c;直接运行即可 sudo bash ChineseInputForQt-v1.1.sh# 或者bash ChineseInputForQt-v1.1.sh脚本内容为&#xff1a; …

修改gitlab数据卷的位置

修改gitlab数据卷的位置 在使用docker安装gitlab的时候&#xff0c;一开始没有考虑其他事情&#xff0c;直接在本地创建了一个数据卷就挂载到容器上了&#xff0c;导致后续数据越来越多&#xff0c;想将数据放到其他盘&#xff0c;大致可以这样操作。 1.停止容器 docker sto…

Angular安装教程

Angular安装 安装node和npm 参考这篇文章安装 https://blog.csdn.net/wf19930209/article/details/84226365 正式安装 当然&#xff0c;在安装 angular/cli 之前需要先把 Node.js 安装好&#xff0c;请到官方网站下载安装包 &#xff0c;安装过程和普通软件没有区别。装好…