目录:
1、Dockerfile
1.1、什么是Dockerfile
1.2、常用命令
1.3、使用脚本创建镜像
2、Docker私有仓库
2.1、私有仓库搭建与配置
2.2、镜像上传至私有仓库
1、Dockerfile
1.1、什么是Dockerfile
Dockerfile是由一系列命令和参数构成的脚本,这些命令应用于基础镜像并最终创建一个新的镜像。
- 1、对于开发人员:可以为开发团队提供一个完全一致的开发环境;
- 2、对于测试人员:可以直接拿开发时所构建的镜像或者通过Dockerfile文件构建一个新的镜像开始工作了;
- 3、对于运维人员:在部署时,可以实现应用的无缝移植。
1.2、常用命令
命令 | 作用 |
FROM | 定义了使用哪个基础镜像启动构建流程 |
MAINTAINER user_name | 声明镜像的创建者 |
ENV | 设置环境变量 (可以写多条) |
RUN | 是Dockerfile的核心部分(可以写多条) |
ADD | 将宿主机的文件复制到容器内,如果是一个压缩文件,将会在复制后自动解压 |
COPY source_dir/file dest_dir/file | 和ADD相似,但是如果有压缩文件并不能解压 |
WORKDIR path_dir | 设置工作目录 |
EXPOSE | 用来指定端口,使容器内的应用可以通过端口与外界进行交互 |
CMD argument | 在构件内容器时使用,会被docker run后argument覆盖 |
ENTRYPOINT argument | 和CMD相似,但是并不会被docker run指定的参数覆盖 |
VOLUME | 将本地文件夹或者其他容器的文件挂载到容器中 |
1.3、使用脚本创建镜像
1.3.1、创建jdk1.8镜像
步骤:
(1)创建目录
mkdir –p /usr/local/dockerjdk8
(2)下载jdk-8u171-linux-x64.tar.gz并上传到服务器(虚拟机)中的/usr/local/dockerjdk8目录
(3)创建文件Dockerfile vi Dockerfile
#依赖镜像名称和ID
FROM centos:7
#指定镜像创建者信息
MAINTAINER testing <testing@tech.com>
#切换工作目录
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)执行命令构建镜像
docker build -t='jdk1.8' .
注意后边的空格和点,不要省略
(5)查看镜像是否建立完成
docker images
(6)创建容器
docker run -it --name=myjdk8 jdk1.8 /bin/bash
1.3.2、创建Eureka镜像
(1)进入控制台,eureka工程的目录下,执行maven命令
mvn clean package
(2)服务器创建/usr/local/dockereureka目录,将生成的eureka.jar上传到服务器的此目录
(3)创建文件Dockerfile
FROM jdk1.8
VOLUME /tmp
ADD eureka.jar /usr/local
ENTRYPOINT ["java","-jar","/usr/local/eureka.jar"]
(4)创建镜像
docker build -t='eureka'
(5)创建容器
docker run -di --name=myeureka -p 6868:6868 eureka
2、Docker私有仓库
2.1、私有仓库搭建与配置
(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
vi /etc/docker/daemon.json
添加以下内容,保存退出。
{"insecure-registries":["192.168.184.141:5000"]}
此步用于让 docker信任私有仓库地址
(5)重启docker 服务
systemctl restart docker
2.2、镜像上传至私有仓库
(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