Docker总结3/3---备份迁移和仓库

目录

  • 迁移与备份
    • 1. 容器保存为镜像
    • 2. 镜像备份
    • 3. 镜像恢复与迁移
  • Dockerfile
    • 1. 什么是Dockerfile
    • 2. 常用命令
    • 3. 使用脚本创建镜像步骤
  • Docker私有仓库
    • 1. 私有仓库搭建与配置
    • 2. 镜像上传至私有仓库
  • 总结

相关文章
Docker总结1/3—理论篇
Docker总结2/3—常用命令和应用部署

迁移与备份

1. 容器保存为镜像

我们可以通过以下命令将容器保存为镜像

  • 基础此镜像创建的容器,包含镜像中部署的静态页面等内容
docker commit mynginx mynginx_i

2. 镜像备份

我们可以通过以下命令将镜像保存为tar 文件

docker  save -o mynginx.tar mynginx_i

3. 镜像恢复与迁移

首先我们先删除掉mynginx_img镜像 然后执行此命令进行恢复

  • 一个服务器上测试,可以先删除之前的mynginx_i镜像(先删除此镜像创建的容器),再导入mynginx.tar恢复为mynginx_i镜像
docker load -i mynginx.tar

-i 输入的文件

执行后再次查看镜像,可以看到镜像已经恢复

Dockerfile

1. 什么是Dockerfile

Dockerfile是由一系列命令和参数构成的脚本,这些命令应用于基础镜像(操作系统级别的镜像并最终创建一个新的镜像。

  • 基础镜像 :例如Centos 上创建了JKD,Centos 就是JDK的基础镜像;JKD基础上创建了微服务,JKD就是微服务的基础镜像。

Dockerfile的好处

人员 含义
开发人员 可以为开发团队提供一个完全一致的开发环境。
测试人员 可以直接拿开发时所构建的镜像或者通过Dockerfile文件构建一个新的镜像开始工作了。
运维人员 在部署时,可以实现应用的无缝移植。

2. 常用命令

命令 作用
FROM image_name:tag 定义了使用哪个基础镜像启动构建流程
MAINTAINER user_name 声明镜像的创建者
ENV key value 设置环境变量 (可以写多条)
RUN command 是Dockerfile的核心部分(可以写多条)
ADD source_dir/file dest_dir/file 将宿主机的文件复制到容器内,如果是一个压缩文件,将会在复制后自动解压
COPY source_dir/file dest_dir/file 和ADD相似,但是如果有压缩文件并不能解压
WORKDIR path_dir 设置工作目录

3. 使用脚本创建镜像步骤

(1)创建目录

mkdir –p /usr/local/dockerjdk8

(2)下载压缩包

下载jdk-8u171-linux-x64.tar.gz并上传到服务器(虚拟机)中的/usr/local/dockerjdk8(第一步创建的)目录

mv jdk-8u171-linux-x64.tar.gz /usr/local/dockerjdk8

(3)创建文件Dockerfile vi Dockerfile

进入刚才创建的目录:

cd /usr/local/dockerjdk8
vi Dockerfile

进入编辑页面,输入命令:

#依赖镜像名称和ID(基础镜像)
FROM centos:7
#指定镜像创建者信息
MAINTAINER Stephanie
#切换工作目录
WORKDIR /usr
RUN mkdir  /usr/local/java
#ADD 是相对路径jar,把java添加到容器中(上传并自动解压)
ADD jdk-8u171-linux-x64.tar.gz /usr/local/java/

配置java环境变量

#jdk1.8.0_171为解压后的名字,不清楚名字,可以先在宿主机解压,确定名字
ENV JAVA_HOME /usr/local/java/jdk1.8.0_171
ENV JRE_HOME $JAVA_HOME/jre
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib:$CLASSPATH
ENV PATH $JAVA_HOME/bin:$PATH

wq保存之后,可以输入dir查看目录内容

(4)执行命令构建镜像

#-t:镜像的名称; . 指定当前目录
docker build -t='jdk1.8' .

注意后边的空格和点,不要省略

(5)查看镜像是否建立完成

docker images

Docker私有仓库

1. 私有仓库搭建与配置

  • Docker私有仓库其实也是一个镜像
    (1)拉取私有仓库镜像
docker pull registry

(2)启动私有仓库容器

docker run -di --name=registry -p 5000:5000 registry

(3)打开浏览器测试

输入地址 端口号:5000/v2/_catalog看到

{"repositories":[]} 

表示私有仓库搭建成功并且内容为空

(4)修改daemon.json

vi /etc/docker/daemon.json

添加以下内容,保存退出。

{"insecure-registries":["192.168.11.129:5000"]} 

此步用于让 docker信任私有仓库地址

(5)重启docker 服务

systemctl restart docker

2. 镜像上传至私有仓库

(1)标记此镜像为私有仓库的镜像

docker tag jdk1.8 192.168.11.129:5000/jdk1.8

(2)再次启动私服容器

docker start registry

(3)上传标记的镜像

docker push 192.168.11.129:5000/jdk1.8
  • 其他服务器上下载镜像需要:
    Ⅰ安装Docker
    Ⅱ操作:(4)修改daemon.json
    Ⅲ重启Docker服务,输入命令docker pull 要下载镜像的私服地址:端口号/下载镜像名称

总结

到这里Docker实现镜像备份和迁移,私有仓库的搭建、上传下载镜像就完成了。更多内容可以关注Docker系列博客。

你可能感兴趣的:(#,容器)