目录
迁移与备份
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系列博客。
来源:oschina
链接:https://my.oschina.net/u/4390731/blog/4335808