谷歌助力,快速实现 Java 应用容器化

Google 在 2018 年下旬开源了一款新的 Java 工具 Jib,可以轻松地将 Java 应用程序容器化。通过 Jib,我们不需要编写 Dockerfile 或安装 Docker,通过集成到 Maven 或 Gradle 插件,就可以立即将 Java 应用程序容器化。

一、什么是 Jib

Jib 是一个快速而简单的容器镜像构建工具,它作为 Maven 或 Gradle 的一部分运行,不需要编写 Dockerfile 或运行 Docker 守护进程。它从 Maven 或 Gradle 中构建我们的 Docker 镜像, 并只将发生变更的层(而不是整个应用程序)推送到注册表来节省宝贵的构建时间。现在,我们对 Docker 构建流程和 Jib 构建流程进行对比。Docker 构建流程,如下所示。

谷歌助力,快速实现 Java 应用容器化

Jib 构建流程,则是这样的。

谷歌助力,快速实现 Java 应用容器化

二、实战出真知

1. 构建一个简单的 Java 工程

我们编写一个简单的 Java 类。

public class HelloWorld {
public static void main(String[] args) {
System.out.println("Hello World!");
System.out.println("http://blog.720ui.com");
}
}

紧接着,我们再创建一个 pom.xml 文件。

<project> 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>com.lianggzone.sample.lib/<groupid>
<artifactid>helloworld-samples/<artifactid>
<version>0.1/<version>
<packaging>jar/<packaging>
<name>helloworld-samples/<name>
<properties>
<project.build.sourceencoding>UTF-8/<project.build.sourceencoding>
<jib-maven-plugin.version>1.0.2/<jib-maven-plugin.version>
<maven-compiler-plugin.version>3.8.0/<maven-compiler-plugin.version>
/<properties>
<dependencies>
/<dependencies>
<build>
<plugins>
<plugin>
<groupid>org.apache.maven.plugins/<groupid>
<artifactid>maven-compiler-plugin/<artifactid>
<version>${maven-compiler-plugin.version}/<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>${jib-maven-plugin.version}/<version>
<configuration>
<from>
<image>registry.cn-hangzhou.aliyuncs.com/lianggzone/oracle_java8/<image>
/<from>

<image>registry.cn-hangzhou.aliyuncs.com/lianggzone/jib-helloworld:v1/<image>

<container>
<jvmflags>
<jvmflag>-Xms512m/<jvmflag>
<jvmflag>-Xdebug/<jvmflag>
/<jvmflags>
<mainclass>com.lianggzone.HelloWorld/<mainclass>
/<container>
/<configuration>
<executions>
<execution>
<phase>package/<phase>
<goals>
<goal>build/<goal>
/<goals>
/<execution>
/<executions>
/<plugin>
/<plugins>
/<build>
/<project>

由于默认访问谷歌的 gcr.io 仓库,而国内访问 gcr.io 不稳定会经常导致网络超时,所以笔者使用了国内的阿里云镜像服务,那么就不需要访问谷歌的仓库了。现在,我们执行 mvn compile jib:build 命令进行自动化构建,它会从 <from> 拉取镜像,并把生成的镜像上传到 设置的地址。这里,笔者还通过 ` 设置了一些 JVM 参数。

/<from>

mvn compile jib:build

此外,如果”登录失败,未授权”,需要通过 docker login 登录鉴权一下。此外,更好的做法是,你可以考虑在Maven 中放置凭据。

<settings>
...
<servers>
...
<server>
registry.cn-hangzhou.aliyuncs.com
<username>你的阿里云账号/<username>
<password>你的阿里云密码/<password>
/<server>
/<servers>
/<settings>

最后,执行完成后,我们可以在阿里云镜像仓库获取镜像。

谷歌助力,快速实现 Java 应用容器化

大功告成,现在,我们来验证一把。我们通过 docker pull 拉取镜像,并运行。

docker pull registry.cn-hangzhou.aliyuncs.com/lianggzone/jib-helloworld:v1
docker run --name jib-helloworld -it registry.cn-hangzhou.aliyuncs.com/lianggzone/jib-helloworld:v1 /bin/bash

执行结果,如下所示。

谷歌助力,快速实现 Java 应用容器化

2. 构建一个 SpringBoot 的可运行 Jar

我们来一个复杂一些的项目,构建一个 SpringBoot 的项目。关于 SpringBoot 的使用,可以阅读笔者之前的文章:

http://blog.720ui.com/columns/springboot_all/ 。现在,我们首先需要搭建一个工程,并创建一个启动类。

@SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}

同时,需要一个 Web 的接口。

@RestController
public class WebController {
@RequestMapping("/blog")
public String index() {
return "http://blog.720ui.com";
}
}

紧接着,我们再创建一个 pom.xml 文件。


<project> 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>
<parent>
<groupid>org.springframework.boot/<groupid>
<artifactid>spring-boot-starter-parent/<artifactid>
<version>2.1.2.RELEASE/<version>
/<parent>
<groupid>com.lianggzone.sample.lib/<groupid>
<artifactid>springboot-samples/<artifactid>
<version>0.1/<version>
<packaging>jar/<packaging>
<name>springboot-samples/<name>
<dependencies>
<dependency>
<groupid>org.springframework.boot/<groupid>
<artifactid>spring-boot-starter-web/<artifactid>
/<dependency>

/<dependencies>
<properties>
<project.build.sourceencoding>UTF-8/<project.build.sourceencoding>
<jib-maven-plugin.version>1.0.2/<jib-maven-plugin.version>
<maven-compiler-plugin.version>3.8.0/<maven-compiler-plugin.version>
/<properties>
<build>
<plugins>
<plugin>
<groupid>org.apache.maven.plugins/<groupid>
<artifactid>maven-compiler-plugin/<artifactid>
<version>${maven-compiler-plugin.version}/<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>${jib-maven-plugin.version}/<version>
<configuration>
<from>
<image>registry.cn-hangzhou.aliyuncs.com/lianggzone/oracle_java8/<image>
/<from>

<image>registry.cn-hangzhou.aliyuncs.com/lianggzone/jib-springboot:v1/<image>

<container>
<jvmflags>
<jvmflag>-Xms512m/<jvmflag>
<jvmflag>-Xdebug/<jvmflag>
/<jvmflags>
/<container>
/<configuration>
<executions>
<execution>
<phase>package/<phase>
<goals>
<goal>build/<goal>
/<goals>
/<execution>
/<executions>
/<plugin>
/<plugins>
/<build>

/<project>

现在,我们执行 mvn compile jib:build 命令进行自动化构建。执行完成后,我们可以在阿里云镜像仓库获取镜像。

谷歌助力,快速实现 Java 应用容器化

现在,我们再来验证一把。我们通过 docker pull 拉取镜像,并运行。

docker pull registry.cn-hangzhou.aliyuncs.com/lianggzone/jib-springboot:v1
docker run -p 8080:8080 --name jib-springboot -it registry.cn-hangzhou.aliyuncs.com/lianggzone/jib-springboot:v1 /bin/bash

执行结果,如下所示。

谷歌助力,快速实现 Java 应用容器化

现在,我们访问 http://localhost:8080/blog ,我们可以正常调用 API 接口了。

谷歌助力,快速实现 Java 应用容器化

3. 构建一个 WAR 工程

Jib 还支持 WAR 项目。如果 Maven 项目使用 war-packaging 类型,Jib 将默认使用 distroless Jetty 作为基础镜像来部署项目。要使用不同的基础镜像,我们可以自定义 <container><approot> , <container> <entrypoint> 和 <container> <args> 。以下是使用 Tomcat 镜像的案例。/<args>/<container>/<entrypoint>/<container>/<approot>/<container>

<configuration>
<from>
<image>tomcat:8.5-jre8-alpine/<image>
/<from>
<container>
<approot>/usr/local/tomcat/webapps/ROOT/<approot>
/<container>
/<configuration>

欢迎工作一到五年的Java工程师朋友们加入Java程序员开发: 721575865

群内提供免费的Java架构学习资料(里面有高可用、高并发、高性能及分布式、Jvm性能调优、Spring源码,MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多个知识点的架构资料)合理利用自己每一分每一秒的时间来学习提升自己,不要再用"没有时间“来掩饰自己思想上的懒惰!趁年轻,使劲拼,给未来的自己一个交代!


分享到:


相關文章: