在 IntelliJ 中自动生成 Dockerfile 和其他部署工具的选项?

Nei*_*fey 4 tomcat intellij-idea docker

我正在探索使用 Docker 容器化基于 Tomcat 的 Java 项目的初始步骤。使用 IntelliJ 作为我的首选 IDE,我成功地:

  • 编写了一个概念验证 Servlet;
  • 设置构建工件来创建生成的 WAR;
  • 使用 IntelliJ Docker 插件和官方 Tomcat Docker 映像之一,设置一个容器配置,其中包含 WAR 内容作为其挂载点之一;
  • 通过 IntelliJ 将容器部署到本地 Docker,并确认我可以通过本地浏览器成功访问 Servlet。

因此,就基本开发周期而言,我已经启动并运行。

但当我最终进行外部部署时(甚至在开发过程中的某个时刻),我将需要添加库和资源并生成一个真正独立的容器:换句话说,我将需要从简单的部署开始IntelliJ 插件当前正在执行“带有挂载点的映像”,以拥有一个完整的 Dockerfile,其中指定了所有相关配置,包括我的挂载有效地转换为复制相关内容的指令。

现在我的问题是:人们通常如何实现这一目标?IntelliJ 中是否有内置工具可以帮助实现这一点?例如,在 IntelliJ 中的容器部署配置设置(指定安装点、基础映像等)中,似乎没有配置要复制的资源的选项(或者“复制到独立容器中而不是复制到独立容器中”的选项)从主机 FS 挂载”)。我是否在某处缺少工具/选项,或者 Docker 文件的脚本编写本质上是一个手动过程?或者我的整个方法只是在找错树?对于人们通常使用的流程的任何建议,我将不胜感激!

Ken*_*ler 5

谷歌的吉布

我想,吉布会提供你所需要的。它还为 Maven 和 Gradle 提供插件,并且可以通过运行/调试配置在 IntelliJ 中触发相应的插件(请参阅最底部的示例)。

什么是吉布?

Jib 无需 Docker 守护进程,也无需深入掌握 Docker 最佳实践,即可为您的 Java 应用程序构建优化的 Docker 和 OCI 镜像。它可作为 Maven 和 Gradle 的插件以及 Java 库使用。

吉布是做什么的?

Jib 处理将应用程序打包到容器映像中的所有步骤。您不需要了解创建 Dockerfile 的最佳实践或安装 Docker。Jib 将您的应用程序组织成不同的层;依赖项、资源和类;并利用 Docker 镜像层缓存通过仅重建更改来保持快速构建。Jib 的层组织和小型基础映像使整体映像尺寸保持较小,从而提高了性能和可移植性。

配置

您可以查看文档。它包含有关创建和部署 Docker 映像的不同类型配置选项的大量信息。您还可以简单地使用环境变量。

关于您的问题,请检查此部分,例如:将任意文件添加到图像

例如,在 IntelliJ 中的容器部署配置设置(指定挂载点、基础映像等)中,似乎没有配置要复制的资源的选项(或者“复制到独立容器中而不是复制到独立容器中”的选项)从主机 FS 挂载”)。

演示

出于演示目的,我使用 Maven 创建了一个简单的项目,其中还使用了基础镜像tomcat:9.0.36-jdk8-openjdk,顺便说一下,它也是可选的 - 请参阅Jib WAR 项目

Servlet:

@WebServlet(urlPatterns = {"/hello-world"})
public class HelloWorld extends HttpServlet {
    public void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException {
        response.setContentType("text/html");
        PrintWriter out = response.getWriter();
        out.println("Hello World");
    }
}
Run Code Online (Sandbox Code Playgroud)

pom.xml:

<?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.example</groupId>
    <artifactId>mvn-jib-example</artifactId>
    <version>1.0</version>
    <packaging>war</packaging>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <failOnMissingWebXml>false</failOnMissingWebXml>
    </properties>

    <dependencies>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>4.0.1</version>
            <scope>provided</scope>
        </dependency>
    </dependencies>

    <build>
        <finalName>servlet-hello-world</finalName>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.8.1</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
            <plugin>
                <groupId>com.google.cloud.tools</groupId>
                <artifactId>jib-maven-plugin</artifactId>
                <version>2.5.0</version>
                <configuration>
                    <allowInsecureRegistries>true</allowInsecureRegistries>
                    <from>
                        <image>tomcat:9.0.36-jdk8-openjdk</image>
                    </from>
                    <to>
                        <image>registry.localhost/hello-world</image>
                        <auth>
                            <username>registry_username</username>
                            <password>registry_password</password>
                        </auth>
                        <tags>
                            <tag>latest</tag>
                        </tags>
                    </to>
                    <container>
                        <appRoot>/usr/local/tomcat/webapps/ROOT</appRoot>
                    </container>
                    <extraDirectories>
                        <paths>
                            <path>
                                <from>./src/main/resources/extra-stuff</from>
                                <into>/path/in/docker/image/extra-stuff</into>
                            </path>
                            <path>
                                <from>/absolute/path/to/other/stuff</from>
                                <into>/path/in/docker/image/other-stuff</into>
                            </path>
                        </paths>
                    </extraDirectories>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>
Run Code Online (Sandbox Code Playgroud)
  • 执行以下目标将动态创建 docker 镜像:
mvn clean package jib:dockerBuild
Run Code Online (Sandbox Code Playgroud)
  • 确认镜像已创建:
docker image ls
Run Code Online (Sandbox Code Playgroud)
  • 从镜像启动容器
docker run --rm -p 8082:8080 registry.localhost/hello-world:latest
Run Code Online (Sandbox Code Playgroud)

结果:

来自 Tomcat docker 容器的 Hello World

部署

要将映像部署到外部 docker 注册表,您可以检查以下部分:

集成开发环境

最后但并非最不重要的一点是,由于您使用的是 IntelIJ IDEA,因此您可以简单地创建一个运行/调试配置来通过按钮自动创建和部署映像,例如,一种用于构建映像的配置,一种用于将其部署到本地主机,另一种用于将其部署到本地主机。部署到外部注册表等。

这里有一个 Maven 的例子(参见): Maven 和 Jib 与 IntelliJ IDEA