Docker迁移与备份
迁移与备份容器保存为镜像我们可以通过以下命令将容器保存为镜像docker commit 容器名 镜像名docker commit mytomcat mytomcat_i演示:[root@VM_0_8_centos ~]# docker imagesREPOSITORYTAGIMAGE IDCR...
迁移与备份
容器保存为镜像
我们可以通过以下命令将容器保存为镜像
docker commit 容器名 镜像名
docker commit mytomcat mytomcat_i
演示:
[root@VM_0_8_centos ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
nginx latest 5a9061639d0a 11 hours ago 126MB
redis latest de25a81a5a0b 12 hours ago 98.2MB
centos/mysql-57-centos7 latest f83a2938370c 7 days ago 452MB
tomcat 8-jre8 3639174793ba 5 months ago 463MB
hello-world latest fce289e99eb9 9 months ago 1.84kB
[root@VM_0_8_centos ~]# docker commit mytomcat mytomcat_i
sha256:5e4d24d4cc924faeeb1da6660edf7a767cc1ee13d8245f4db31749518a00e8ed
[root@VM_0_8_centos ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
mytomcat_i latest 5e4d24d4cc92 10 seconds ago 463MB
nginx latest 5a9061639d0a 11 hours ago 126MB
redis latest de25a81a5a0b 12 hours ago 98.2MB
centos/mysql-57-centos7 latest f83a2938370c 7 days ago 452MB
tomcat 8-jre8 3639174793ba 5 months ago 463MB
hello-world latest fce289e99eb9 9 months ago 1.84kB
[root@VM_0_8_centos ~]#
镜像备份
我们可以通过以下命令将镜像保存为tar 文件
docker save -o mytomcat.tar mytomcat_i
镜像恢复与迁移
首先我们先删除掉mytomcat_i镜像 然后执行此命令进行恢复
docker load -i mytomcat.tar
演示:
[root@VM_0_8_centos ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
mytomcat_i latest 5e4d24d4cc92 10 seconds ago 463MB
nginx latest 5a9061639d0a 11 hours ago 126MB
redis latest de25a81a5a0b 12 hours ago 98.2MB
centos/mysql-57-centos7 latest f83a2938370c 7 days ago 452MB
tomcat 8-jre8 3639174793ba 5 months ago 463MB
hello-world latest fce289e99eb9 9 months ago 1.84kB
[root@VM_0_8_centos ~]# docker save -o mytomcat.tar mytomcat_i
[root@VM_0_8_centos ~]# docker rmi 5e4d24d4cc92
Untagged: mytomcat_i:latest
Deleted: sha256:5e4d24d4cc924faeeb1da6660edf7a767cc1ee13d8245f4db31749518a00e8ed
Deleted: sha256:86e8ce417d31173f8426474142962be0dc68e65c91accd8e35e0dd095dacaca5
[root@VM_0_8_centos ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
nginx latest 5a9061639d0a 11 hours ago 126MB
redis latest de25a81a5a0b 12 hours ago 98.2MB
centos/mysql-57-centos7 latest f83a2938370c 7 days ago 452MB
tomcat 8-jre8 3639174793ba 5 months ago 463MB
hello-world latest fce289e99eb9 9 months ago 1.84kB
[root@VM_0_8_centos ~]# docker load -i mytomcat.tar
6c1f036db5d4: Loading layer [==================================================>] 199.7kB/199.7kB
Loaded image: mytomcat_i:latest
[root@VM_0_8_centos ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
mytomcat_i latest 5e4d24d4cc92 8 minutes ago 463MB
nginx latest 5a9061639d0a 11 hours ago 126MB
redis latest de25a81a5a0b 12 hours ago 98.2MB
centos/mysql-57-centos7 latest f83a2938370c 7 days ago 452MB
tomcat 8-jre8 3639174793ba 5 months ago 463MB
hello-world latest fce289e99eb9 9 months ago 1.84kB
[root@VM_0_8_centos ~]#
-i 输入的文件
执行后再次查看镜像,可以看到镜像已经恢复
Dockerfile
什么是Dockerfile
Dockerfile是由一系列命令和参数构成的脚本,这些命令应用于基础镜像并最终创建一个新的镜像。
1、对于开发人员:可以为开发团队提供一个完全一致的开发环境;
2、对于测试人员:可以直接拿开发时所构建的镜像或者通过Dockerfile文件构建一个新的镜像开始工作了;
3、对于运维人员:在部署时,可以实现应用的无缝移植。
常用命令
命令 | 作用 |
---|---|
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 | 设置工作目录 |
使用脚本创建镜像
步骤:
(1)创建目录
mkdir –p /usr/local/dockerjdk8
(2)下载jdk-8u171-linux-x64.tar.gz并上传到服务器(虚拟机)中的/usr/local/dockerjdk8目录
(3)进去到/usr/local/dockerjdk8下创建文件Dockerfile vi Dockerfile
#依赖镜像名称和ID
FROM centos:7
#指定镜像创建者信息
MAINTAINER ITCAST
#切换工作目录
WORKDIR /usr
RUN mkdir /usr/local/java
#ADD 是相对路径jar,把java添加到容器中
ADD jdk-8u171-linux-x64.tar.gz /usr/local/java/
#配置java环境变量
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
(4)在/usr/local/dockerjdk8下执行命令构建镜像
就是在有Dockerfile文件的目录下构建
docker build -t='jdk1.8' .
注意后边的空格和点,不要省略
(5)查看镜像是否建立完成
docker images
Docker私有仓库
私有仓库可以用来存放一些企业内部应用
私有仓库搭建与配置
(1)拉取私有仓库镜像
docker pull registry
(2)启动私有仓库容器
docker run -di --name=registry -p 5000:5000 registry
(3)打开浏览器 输入地址http://192.168.184.141:5000/v2/_catalog看到{"repositories":[]}
表示私有仓库搭建成功并且内容为空
(4)修改daemon.json,让docker信任私有仓库
vi /etc/docker/daemon.json
添加以下内容,保存退出。
{"insecure-registries":["192.168.184.141:5000"]}
添加后是下面这样:
此步用于让 docker信任私有仓库地址
(5)重启docker 服务
systemctl restart docker
镜像上传至私有仓库
(1)标记此镜像为私有仓库的镜像
docker tag jdk1.8 192.168.184.141:5000/jdk1.8
(2)再次启动私服容器
docker start registry
(3)上传标记的镜像
docker push 192.168.184.141:5000/jdk1.8
更多推荐
所有评论(0)