Jib构建你的第一个java镜像

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Jib构建你的第一个java镜像相关的知识,希望对你有一定的参考价值。

jib Official:GoogleContainerTools/jib

本文示例完整demo github地址 https://github.com/moxingwang/jib

想要了解并且使用jib,首先你得知道或者使用过docker,在这个基础上才能够明白jib是干什么得,解决了什么问题。

首先我们先看一个例子,如何将一个spring-boot项目简单容器化,如果你从未操作过,可以动手自己实现,或者仔细阅读这篇文章第一个 spring Boot 应用通过Docker 来实现构建、运行、发布。你可能发现如果需要把一个java项目容器化这是一个麻烦和相对复杂的过程,首先你需要编写dockerfile,然后在build dockefile,如过需要push到registries,还需要经过push操作。虽然build和push还是非常简单得。但是写一个dockerfile真的比较麻烦,学习成本也高,看看官网Dockerfile reference就不想学了。那么有没有简单得办法呢,记住几个简单得命令就可以运行了,如同‘mvn spring-boot:run’这么简单得命令,这个时候jib出场了,他就是来完成这个伟大得使命。

如果你还没明白jib是用来做什么事情得,推荐你阅读谷歌开源Java镜像构建工具Jib的前半部分,或者阅读jib Official:GoogleContainerTools/jib

接下来主要介绍具体如何使用(maven的方式)。

将java项目容器化push到registries

jib的引入非常简单,已maven plugin的方式集成到项目中,只需要在你的项目中引入下面代码即可

<plugin>
    <groupId>com.google.cloud.tools</groupId>
    <artifactId>jib-maven-plugin</artifactId>
    <version>0.9.6</version>
    <configuration>
        <from>
            <!--base image-->
            <image>openjdk:alpine</image>
        </from>
        <to>
            <!--<image>registry.cn-hangzhou.aliyuncs.com/m65536/jibtest</image>-->
            <!--目标镜像registry地址,为了方便测试,你需要换成自己的地址,如果你的网络不好,可以选用国内加速器,比如阿里云的-->
            <image>registry.hub.docker.com/moxingwang/jibtest</image>
        </to>
    </configuration>
    <executions>
        <execution>
            <phase>package</phase>
            <goals>
                <goal>build</goal>
            </goals>
        </execution>
    </executions>
</plugin>

这只是一个最简单的配置,比如registry认证配置,jvm配置等等,可以参考github jib详细说明jib/jib-maven-plugin/

构建你的镜像

mvn compile jib:build

可能你刚刚运行玩这一步就出现错误,提示Unauthorized,不用担心,这个命令需要把构建出来的image commit并且push到你远程的registry(我这里是registry.hub.docker.com),你可以按照【常见错误1】的方法解决问题。

如果你的网速慢一点可能会在最后步骤‘Finalizing...‘,不过没有关系,稍微多等一会就ok,直到‘BUILD SUCCESS‘出现。最终一个完整的java project被实例化成镜像并且push到了registry里。接下来你可以测试刚刚完成push的镜像。

打开https://hub.docker.com/,你会发现你的image已经构建成功。

技术分享图片

  • docker使用镜像
    docker run -it --rm -p8080:8080 registry.hub.docker.com/moxingwang/jibtest

    技术分享图片

一个spring-boot的image这样就被启动成功了。本文示例demo中集成了swagger-iu, 项目启动成功后我们可以通过http://localhost:8080/sw/swagger-ui.html访问,可以成功在浏览器打开swagger。

技术分享图片

把镜像直接构建到本地docker中

使用这种构建方式,首先你要确保本已经安装docker并且环境变量都配置正确,因为这种方式jib依赖docker 命令执行,你还需要保证已经启动服务(在terminal中执行 docker --version 能够正确返回)。

mvn compile jib:dockerBuild

接下来直接操作,首先查看本地已有images

docker iamges

技术分享图片

执行mvn compile jib:dockerBuild

技术分享图片

可以看到本地image已经build成功。可以直接启动使用

docker run -it --rm -p8080:8080 moxingwang/jibtest

启动成功后同样可以直接访问http://localhost:8080/sw/swagger-ui.htmlswagger页面。

常见错误

常见错误1 Failed to execute goal com.google.cloud.tools:jib-maven-plugin:0.9.6:build (default-cli) on project jib: Build image failed, perhaps you should set a credential helper name with the configuration ‘<from><credHelper>‘ or set credentials for ‘registry.hub.docker.com‘ in your Maven settings: Unauthorized for registry.hub.docker.com/moxingwang/jibtest: 401 Unauthorized

当你从私有的registries pull或者push的时候需要认证机制。阅读官方说明按照步骤操作即可。Authentication Methods
如果帮你本机已经按照docker,那么操作更简单,可以通过docker命令直接登陆registries,然后继续其他jib的操作。

  • registry.hub.docker.com

    docker login --username=你的hub.docker的用户名 registry.hub.docker.com
  • registry.hub.docker.com
    docker login --username=阿里云docker用户名 registry.cn-hangzhou.aliyuncs.com

推荐阅读

以上是关于Jib构建你的第一个java镜像的主要内容,如果未能解决你的问题,请参考以下文章

Jib构建镜像的问题分析(Could not find or load main class ${start-class})

jib-maven-plugin构建镜像

如何使用 GITHUB_TOKEN 密钥和 Maven Jib 插件将图像推送到 GitHub 包?

Docker 一键打包微服务

7月份GitHub上热门Java开源项目排行

在heroku中无法发布推送的docker镜像。