目录:

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