如果您像我一样,则将大部分时间都花在开发应用程序上。 在此期间,很难花时间管理容器。 如今,编写Dockerfile几乎已成为正常开发过程的一部分,但是有另一种方法。 我宁愿花费尽可能多的时间来开发我的应用程序,并将Docker配置保留为对我自动完成的最小部署过程。
我相信Google的员工在生产Jib时会以这种方式进行思考。 Jib项目允许人们自动创建Docker映像,以便在构建项目后即可简单地启动容器。 无需创建Dockerfile,因为Jib会为您处理。 Jib可与Maven和Gradle一起使用,在这篇文章中,我将演示如何与Maven一起使用它并将其部署到Payara Micro。 默认情况下,Jib包含一个Jetty发行版,应用程序将在容器内部署到该发行版。 但是,我熟悉Payara Micro,并且非常喜欢Payara Micro环境,因此在本示例中,我将绕过Jetty的使用并部署到Payara Micro。
首先,通过阅读文档熟悉Jib Maven流程很重要。
在这个示例中,我利用了我在2018年为《 Java Magazine》撰写的SportsTeamQueryService微服务,但只是修改了POM文件以合并Jib构建。 我不会在这篇文章中详细介绍Jib,因为文档本身做得很好。 相反,我将解释如何使该项目在Mac上构建并部署到Docker。 如果使用其他操作系统,则可能必须配置主机-容器网络,以便容器与主机数据库进行通信。
首先,POM文件如下所示,仅包括项目所需的那些依赖项。 我提醒您注意Jib钩子的<plugins>部分:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.javamagazine</groupId>
<artifactId>SportsTeamQueryService</artifactId>
<version>1.0</version>
<packaging>war</packaging>
<name>SportsTeamQueryService</name>
<properties>
<endorsed.dir>${project.build.directory}/endorsed</endorsed.dir>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>javax.persistence</groupId>
<artifactId>javax.persistence-api</artifactId>
<version>2.2</version>
<scope>provide