34

docker数据持久化

 6 years ago
source link: http://liaowo.me/articles/2018/09/16/1537071415328.html?amp%3Butm_medium=referral
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
neoserver,ios ssh client

方式一

bind moumting

Nginx dockerfile

FROM nginx
WORKDIR /usr/nginx/html
COPY index.html index.html

我们想吧容器里的工作目录挂载到我们服务器的数据卷上,以免容器删除后数据丢失。

  • 首先我们build dockerfile成一个image 取名为 saniii/my-nginx-mount

    docker build -t saniii/my-nginx-mount .

eMNjUja.png!web

  • 运行容器
    docker run -d -p 3331:80 -v $(pwd):/usr/nginx/html --name nginx1 saniii/my-nginx-mount
    
    -d 后台运行
    
    -p 绑定主机端口到容器端口 3331:表示服务器的端口 :80 表示容器里的端口
    
    
    -v 数据绑定 $(pwd) 代表当前路径 :/usr/nginx/html 为要绑定的容器里的路径 
    
     --name  容器命名为nginx1 
    
     saniii/my-nginx-mount 运行的容器名

    zaqiIrE.png!web

    jQbeyeJ.png!web

    • 看下数据有没有绑定成功
      docker exec -it nginx1 /bin/bash
      
      交互式运行容器
      
      我们在容器里创建一个文件,退出

    biqquen.png!web

    当我们回到主机后,发现主机绑定的目录也多了这个文件

    JJrY73e.png!web

方式二

Volume

我们可以在dockerfile中定义我们数据的在容器中的持久化路径

https://github.com/docker-library/mysql/blob/9d1f62552b5dcf25d3102f14eb82b579ce9f4a26/5.7/Dockerfile

上面是mysql官方dockerfile中的最佳实践 mysql在容器中运行的时候数据持久化在以下的路径

….

VOLUME /var/lib/mysql

iimEJjj.png!web

命令
  
  sudo docker run -d -v mysql:/var/lib/mysql --name mysql1 -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql:5.7


-v 数据绑定 将我们数据volume命名为mysql   /var/lib/mysql容器中数据卷的路径  -e MYSQL_ALLOW_EMPTY_PASSWORD=true 设置mysql无密码

JbIviiY.png!web

正在运行的Volume
  
  docker volume ls

uEvum2f.png!web

查看Volume在主机上的持久化地址

docker volume inspect mysql

MRjA7bR.png!web

验证数据有没有成功持久化

交互式运行容器
	docker exec -it mysql1 /bin/bash

登录mysql 查看数据库 mysql -uroot -hlocalhost -p

zY3M7b7.png!web

我们创建一个数据库

nA7RjaV.png!web

退出容器并删除。

docker rm -f mysql1
	 -f 强制删除正在运行的容器

raaAZfa.png!web

我们再启动一个mysql容器,使用之前的Volume mysql

sudo docker run -d -v mysql:/var/lib/mysql --name mysql2 -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql:5.7

BBn6reF.png!web

我们发现数据还是存在的。

maYv2iJ.png!web

这样我们就可以做到数据的持久化了。


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK