【Docker进阶篇 DockerFile】2.SpringBoot项目远程打包

前言

上篇讲到了SpringBoot制作成镜像,但是操作十分麻烦,需要手动拖拽到Linux上,并且还需要执行多的操作。本篇文章描述远程打包流程。

打包SpringBoot项目

pom.xml内容

			<!-- Docker maven plugin -->
            <plugin>
                <groupId>com.spotify</groupId>
                <artifactId>docker-maven-plugin</artifactId>
                <version>1.0.0</version>
                <configuration>
                    <!-- docker私服的地址 -->
                    <dockerHost>http://192.168.112.135:2375</dockerHost>
                    <!--镜像名称以及版本号-->
                    <imageName>office:1.0.0</imageName>
                    <!-- 若需要重复构建相同标签名称的镜像,可将 forceTags 设置为 true -->
                    <forceTags>true</forceTags>
                    <!--Dockerfile的位置 -->
                    <dockerDirectory>${project.basedir}/src/main/docker</dockerDirectory>
                    <!-- 这里是复制 jar 包到 docker 容器指定目录配置 -->
                    <resources>
                        <resource>
                            <targetPath>/</targetPath>
                            <directory>${project.build.directory}</directory>
                            <include>${project.artifactId}.jar</include>
                        </resource>
                    </resources>
                </configuration>
            </plugin>
            <!-- Docker maven plugin -->

创建Dockerfile

image-20220304113825887

DockerFile 内容

# 基础镜像使用java
FROM java:8
# 作者
MAINTAINER terry
# VOLUME 指定了临时文件目录为/tmp。
# 其效果是在主机 /var/lib/docker 目录下创建了一个临时文件,并链接到容器的/tmp
VOLUME /tmp
# 添加jar包到容器并重命名
ADD tools-office.jar office.jar
# 运行jar包
RUN bash -c 'touch /office.jar'
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/office.jar"]
# ENV JAVA_OPTS="-Xms512m -Xmx512m"
# -Djava.security.egd=file:/dev/./urandom 加速tomcat启动
# ENTRYPOINT ["sh","-c","java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -Dspring.profiles.active=prod -jar /demo.jar"]
#暴露8080端口
EXPOSE 8080

打包

使用Idea maven工具,找到package选项打包。

image-20220304114004154

打包成功后会再target目录生成jar包

image-20220304114218057

制作成Docker镜像

开放docker私服端口供外部访问

  1. 编辑docker.service文件

    vim /usr/lib/systemd/system/docker.service
    
  2. 在ExecStart追加配置(开放2375端口容易被黑客攻击,一般在内网设置)

-H tcp://0.0.0.0:2375  -H unix:///var/run/docker.sock 

image-20220304165435455

  1. 重启docker

    systemctl daemon-reload
    service docker restart 
    

使用maven docker插件找到docker:build选项

改操作是先制作成Docker镜像,并上传到私服。

image-20220304114623766

上传成功后

image-20220304165520253

docker查看镜像

image-20220304170051955

运行镜像

docker run -d --name tools -p 8080:8080 -t tools:1.0.0

查看容器运行日志

docker logs -f -t --tail 50 tools

image-20220304170420227

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

terrybg

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值