溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

谷歌助力,快速實現(xiàn) Java 應(yīng)用容器化

發(fā)布時間:2020-07-31 17:36:20 來源:網(wǎng)絡(luò) 閱讀:240 作者:服務(wù)端思維 欄目:云計算

原文地址:梁桂釗的博客

博客地址:http://blog.720ui.com

歡迎關(guān)注公眾號:「服務(wù)端思維」。一群同頻者,一起成長,一起精進,打破認知的局限性。

Google 在 2018 年下旬開源了一款新的 Java 工具 Jib,可以輕松地將 Java 應(yīng)用程序容器化。通過 Jib,我們不需要編寫 Dockerfile 或安裝 Docker,通過集成到 Maven 或 Gradle 插件,就可以立即將 Java 應(yīng)用程序容器化。

谷歌助力,快速實現(xiàn) Java 應(yīng)用容器化cdn.xitu.io/2019/4/16/16a21cd9c5f0bb2b?w=2412&h=988&f=png&s=125437">

開源地址:https://github.com/GoogleContainerTools/jib

一、什么是 Jib

Jib 是一個快速而簡單的容器鏡像構(gòu)建工具,它作為 Maven 或 Gradle 的一部分運行,不需要編寫 Dockerfile 或運行 Docker 守護進程。它從 Maven 或 Gradle 中構(gòu)建我們的 Docker 鏡像, 并只將發(fā)生變更的層(而不是整個應(yīng)用程序)推送到注冊表來節(jié)省寶貴的構(gòu)建時間?,F(xiàn)在,我們對 Docker?構(gòu)建流程和 Jib 構(gòu)建流程進行對比。Docker 構(gòu)建流程,如下所示。

谷歌助力,快速實現(xiàn) Java 應(yīng)用容器化

Jib 構(gòu)建流程,則是這樣的。

谷歌助力,快速實現(xiàn) Java 應(yīng)用容器化

二、實戰(zhàn)出真知

1. 構(gòu)建一個簡單的 Java 工程

我們編寫一個簡單的 Java 類。

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

緊接著,我們再創(chuàng)建一個 pom.xml 文件。

<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>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>
            <!-- Jib -->
            <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>
                    <to>
                        <image>registry.cn-hangzhou.aliyuncs.com/lianggzone/jib-helloworld:v1</image>
                    </to>
                    <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 倉庫,而國內(nèi)訪問 gcr.io 不穩(wěn)定會經(jīng)常導(dǎo)致網(wǎng)絡(luò)超時,所以筆者使用了國內(nèi)的阿里云鏡像服務(wù),那么就不需要訪問谷歌的倉庫了?,F(xiàn)在,我們執(zhí)行 mvn compile jib:build?命令進行自動化構(gòu)建,它會從 &lt;from&gt;?拉取鏡像,并把生成的鏡像上傳到?&lt;to&gt;?設(shè)置的地址。這里,筆者還通過 <jvmFlags>`?設(shè)置了一些 JVM 參數(shù)。

mvn compile jib:build

此外,如果"登錄失敗,未授權(quán)",需要通過 docker login?登錄鑒權(quán)一下。此外,更好的做法是,你可以考慮在Maven 中放置憑據(jù)。

<settings>
  ...
  <servers>
    ...
        <server>
        <id>registry.cn-hangzhou.aliyuncs.com</id>
        <username>你的阿里云賬號</username>
        <password>你的阿里云密碼</password>
        </server>
  </servers>
</settings>

最后,執(zhí)行完成后,我們可以在阿里云鏡像倉庫獲取鏡像。
谷歌助力,快速實現(xiàn) Java 應(yīng)用容器化

大功告成,現(xiàn)在,我們來驗證一把。我們通過 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

執(zhí)行結(jié)果,如下所示。
谷歌助力,快速實現(xiàn) Java 應(yīng)用容器化

2. 構(gòu)建一個 SpringBoot 的可運行 Jar

我們來一個復(fù)雜一些的項目,構(gòu)建一個 SpringBoot 的項目。關(guān)于 SpringBoot 的使用,可以閱讀筆者之前的文章:http://blog.720ui.com/columns/springboot_all/?,F(xiàn)在,我們首先需要搭建一個工程,并創(chuàng)建一個啟動類。

@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";
    }
}

緊接著,我們再創(chuàng)建一個 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>

    <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>
            <!-- Jib -->
            <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>
                    <to>
                        <image>registry.cn-hangzhou.aliyuncs.com/lianggzone/jib-springboot:v1</image>
                    </to>
                    <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>

現(xiàn)在,我們執(zhí)行?mvn compile jib:build?命令進行自動化構(gòu)建。執(zhí)行完成后,我們可以在阿里云鏡像倉庫獲取鏡像。

谷歌助力,快速實現(xiàn) Java 應(yīng)用容器化

現(xiàn)在,我們再來驗證一把。我們通過?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

執(zhí)行結(jié)果,如下所示。

谷歌助力,快速實現(xiàn) Java 應(yīng)用容器化

現(xiàn)在,我們訪問 http://localhost:8080/blog?,我們可以正常調(diào)用 API 接口了。

谷歌助力,快速實現(xiàn) Java 應(yīng)用容器化

3. 構(gòu)建一個 WAR 工程

Jib 還支持 WAR 項目。如果 Maven 項目使用 war-packaging 類型,Jib 將默認使用 distroless Jetty?作為基礎(chǔ)鏡像來部署項目。要使用不同的基礎(chǔ)鏡像,我們可以自定義 &lt;container&gt;&lt;appRoot&gt;? ?, &lt;container&gt; &lt;entrypoint&gt;?和 &lt;container&gt; &lt;args&gt;?。以下是使用 Tomcat 鏡像的案例。

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

三、源碼地址

源碼地址:https://github.com/lianggzone/jib-samples

附:參考資料

  • https://github.com/GoogleContainerTools/jib
  • https://github.com/GoogleContainerTools/jib/tree/master/jib-maven-plugin

(完,轉(zhuǎn)載請注明作者及出處。)

寫在末尾

【服務(wù)端思維】:我們一起聊聊服務(wù)端核心技術(shù),探討一線互聯(lián)網(wǎng)的項目架構(gòu)與實戰(zhàn)經(jīng)驗。同時,擁有眾多技術(shù)大牛的「后端圈」大家庭,期待你的加入,一群同頻者,一起成長,一起精進,打破認知的局限性。

更多精彩文章,盡在「服務(wù)端思維」!

谷歌助力,快速實現(xiàn) Java 應(yīng)用容器化

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI