Dockerfile

FROM java:8 
EXPOSE 8080 
VOLUME /slm 
ADD boot-docker-0.0.1-SNAPSHOT.jar boot-docker.jar 
RUN sh -c 'touch /boot-docker.jar' 
ENV JAVA_OPTS="" 
ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /boot-docker.jar" ] 
FROM java:8
VOLUME /tmp
ADD clp.user.center-1.0-SNAPSHOT.jar app.jar
RUN bash -c 'touch /app.jar'
RUN /bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
EXPOSE 8130
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom",\
"-Dspring.profiles.active=test",\
"-Dspring.cloud.config.uri=http://192.168.87.34:8888",\
"-jar","/app.jar"]

FROM 基础镜像必要,代表你的项目将构建在这个基础上面

EXPOSE 允许指定端口转发

VOLUME 创建一个可以从本地主机或其他容器挂载的挂载点,一般用来存放数据库和需要保持的数据等。

ADD 将文件从路径 复制添加到容器内部路径 支持远程url 如果是远程url权限将会是600

ENV 可以用于为docker容器设置环境变量

ENTRYPOINT 指定 Docker image 运行成 instance (也就是 Docker container) 时,要执行的命令或者文件。

CMD 和 ENTRYPOINT 都能用来指定开始运行的程序,而且这两个命令都有两种不用的语法:

CMD ["ls",''-l"] CMD ls -l 

开始构建:

docker build -t boot-docker . 

-t boot-docker 代表你要构建的名字

更多参数输入查看:docker build --help

控制台输出:

Sending build context to Docker daemon 16.81MB 
Step 1/7 : FROM java:8 
---> d23bdf5b1b1b 
Step 2/7 : EXPOSE 8080 
---> Using cache 
---> b2445bf62da8 
Step 3/7 : VOLUME /slm 
---> Using cache 
---> b73d0b73b868 
Step 4/7 : ADD boot-docker-0.0.1-SNAPSHOT.jar boot-docker.jar 
---> Using cache 
---> 2b4868aafca9 
Step 5/7 : RUN sh -c 'touch /boot-docker.jar' 
---> Using cache 
---> 816b59f199af 
Step 6/7 : ENV JAVA_OPTS="" 
---> Using cache 
---> 784f033b9dd6 
Step 7/7 : ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /boot-docker.jar" ] 
---> Using cache 
---> 92a0da91ea19 
Successfully built 92a0da91ea19 
Successfully tagged bootdocker:latest 

我们可以看到已经构建完成,Successfully built 92a0da91ea19这句话指明了刚刚构建的镜像ID现在我们可以根据这个ID来进行操作。

docker run -d -p 8080:8080 92a0da91ea19

 控制台输出:

root@izz30yg92yl9i3z /# docker run -d -p 8080:8080 92a0da91ea19 62b837ac75e3d83a4be2d7b0f6edee5ff70c69a98bac4ff74c7ed6d3e70282ee root@izz30yg92yl9i3z /# 

-d 表示后台运行

-p映射端口

已经运行成功访问接口。注意这里因为映射到了宿主机的端口所以访问的是宿主机的IP加端口

 

 

你可能感兴趣的:(docker)