Docker整合springboot进行测试环境的快速迭代

最近项目较多,接口的修改与测试每次比较麻烦,基于jenkins还是麻烦了一些,又要写脚本还得点那么多按钮,所以考虑直接在idea里面进行docker部署,这样每次修改了代码后,通过maven本地化构建完就可以直接推送到docker里面去了(网速不好可能也是硬伤如果接口部署在外网的话。。。不过能跟我们写字楼这个网速的情况还是不多的所以可以忽略这种情况)

一、Docker的几个基本概念,

image:镜像文件,就像我们的CD碟片一样,这些碟有很多标准的公用版本,这些版本就像maven仓库一样存在共有的镜像仓库中,(这里面涉及到安装时候的一点修改就是也要改成国内的镜像不然下载死啦死啦地)。继续刚才的例子,我们可以买一张光盘这个过程等于是从公用镜像上面下载了一个带有tomcat的docker文件,但是我们通过电脑的CD驱动又往光盘上刻制了一些内容,此时就生成了一个新的镜像,我们可以将镜像放到仓库里面这个仓库是我们自己部署在服务端的server里面保存的。
docker-server:docker的server端,他的主要职责是管理我们的镜像文件,还有docker的另外一个概念container,也就是容器,容器是docker部署应用的真正载体。
container:容器是docker真正跑代码的载体,我们的应用是执行在容器里面的。

二、安装docker服务端

此处引用其他人的内容,做个记录
https://www.cnblogs.com/shihaibin821/p/12731194.html
着重强调一点一定要修改镜像仓库地址为国内镜像。
为docker添加证书保障安全性
https://blog.csdn.net/oceanyang520/article/details/101563309

三、idea里面如何将代码部署到远程的docker

1、首先要在idea中安装docker插件
file--》settings--》plugins--》搜索docker,安装即可


image.png

2、安装好插件后为docker配置远程服务地址
file--》settings--》builds,excution,deployment--》docker
点击加号添加连接


image.png

下方出现connection successful即表示连接远程server端成功。
3、添加Dockerfile文件在项目中文件名Dockerfile,文件内容如下
FROM java:8
VOLUME /tmp
ADD calculation.jar app.jar
EXPOSE 8999
ENTRYPOINT [ "java", "-jar", "/app.jar" ]

4、修改pom里面maven的build模块,可以将之前的构建方式先注释添加内容如下

<build>
        <finalName>${project.artifactId}</finalName>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <fork>true</fork>
                </configuration>
            </plugin>
            <!-- 跳过单元测试 -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-surefire-plugin</artifactId>
                <configuration>
                    <skipTests>true</skipTests>
                </configuration>
            </plugin>
            <!--使用docker-maven-plugin插件-->
            <plugin>
                <groupId>com.spotify</groupId>
                <artifactId>docker-maven-plugin</artifactId>
                <version>1.0.0</version>
                <!--将插件绑定在某个phase执行-->
                <executions>
                    <execution>
                        <id>build-image</id>
                        <!--用户只需执行mvn package ,就会自动执行mvn docker:build-->
                        <phase>package</phase>
                        <goals>
                            <goal>build</goal>
                        </goals>
                    </execution>
                </executions>
                <configuration>
                    <!--指定生成的镜像名-->
                    <imageName>insurance/${project.artifactId}</imageName>
                    <!--指定标签-->
                    <imageTags>
                        <imageTag>latest</imageTag>
                    </imageTags>
                    <!-- 指定 Dockerfile 路径-->
                    <dockerDirectory>${project.basedir}</dockerDirectory>
                    <!--指定远程 docker api地址-->
                    <dockerHost>http://docker地址:2375</dockerHost>
                    <!-- 这里是复制 jar 包到 docker 容器指定目录配置 -->
                    <resources>
                        <resource>
                            <targetPath>/</targetPath>
                            <!--jar 包所在的路径  此处配置的 即对应 target 目录-->
                            <directory>${project.build.directory}</directory>
                            <!-- 需要包含的 jar包 ,这里对应的是 Dockerfile中添加的文件名 -->
                            <include>${project.build.finalName}.jar</include>
                        </resource>
                    </resources>
                </configuration>
            </plugin>
        </plugins>
    </build>

5、配置好后点击maven构建


image.png

6、点击idea底部的service打开docker面板


image.png

找到刚刚打包并push的image镜像点击右键选择create container,完成配置,配置截图如下
image.png

主要做好端口的映射,Binds ports 前面是宿主机对外暴露的端口号,后面是docker container的端口号,这两个端口是负责通信,将我们部署在docker container里面的应用与外界能够进行通信。
7、 启动


image.png

8、日志查看
点击控制台的log查看应用启动日志


image.png

9、最后打开浏览器我们试着访问宿主机的8999端口进行检查
image.png

每次更新代码构建完成后,点击镜像文件选择create container--》docker image 就可以将原来的container里面的应用刷新,肥肠滴方便。
image.png

ok成功了,将此作为一个笔记,后面计划在团队中推广,结合swagger进行敏捷开发,感觉美美哒。。。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容