本文示例完整demo github地址 https://github.com/moxingwang/practice/tree/master/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的方式集成到项目中,只需要在你的项目中引入下面代码即可
1 |
|
这只是一个最简单的配置,比如registry认证配置,jvm配置等等,可以参考github jib详细说明jib/jib-maven-plugin/。
构建你的镜像
1 |
|
可能你刚刚运行玩这一步就出现错误,提示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使用镜像
1
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 能够正确返回)。
1 |
|
接下来直接操作,首先查看本地已有images
1 |
|
执行mvn compile jib:dockerBuild
可以看到本地image已经build成功。可以直接启动使用
1 |
|
启动成功后同样可以直接访问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 ‘' 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
1
docker login --username=你的hub.docker的用户名 registry.hub.docker.com
- registry.cn-hangzhou.aliyuncs.com
1
docker login --username=阿里云docker用户名 registry.cn-hangzhou.aliyuncs.com