去年,我们开始着手帮助开发人员更轻松地实现Java应用程序的容器化转换。我们注意到,开发人员们在使用现有工具时往往面临诸多困难——例如构建速度太慢,Dockerfiles混合不堪,以及容器体积过大等等。为了改变上述状况,我们开发出了Jib。Jib是一款开源工具,能够非常轻松地与您的Java应用程序实现集成——您无需安装Docker、无需运行Docker守护程序,甚至不需要编写Dockerfile。只需要在Maven或者Gradle build当中使用这款插件并运行构建过程,一切即可迎刃而解。Jib能够利用既有构建信息快速且高效地自动与您的应用程序完成适配。在Jib的帮助下,构建Java容器如今就像打包JAR文件一样简单。我们于去年公布了Jib的beta测试版本,从那时开始,我们陆续收到了来自社区的诸多反馈与贡献,这也帮助我们更好地实现了其容器化体验。今天,我们高兴地宣布Jib 1.0.0通用版本的正式来临,其已经做好充分的准备,能够满足生产环境对于稳定性的严格要求。我们将在这篇文章当中对版本中的主要变更做出说明,具体包括对WAR项目的支持、与Skaffold的集成以及面向Java的全新容器构建库Jib Core。Java编写的Web应用程序通常会被打包成WAR文件。如今,Jib已经能够对WAR项目进行容器化,且完全无需额外配置。您只需要直接运行以下命令:$ mvn package jib:build
$ gradle jib
该容器中的默认应用服务器为Jetty,但您也可以对基础镜像以及appRoot进行配置调整,从而使用Tomcat等其它服务器选项:
tomcat:8.5-jre8-alpine
gcr.io/my-project/my-war-image
/usr/local/tomcat/webapps/my-webapp
jib {
from.image = 'tomcat:8.5-jre8-alpine'
to.image = 'gcr.io/my-project/my-war-image'
container.appRoot = '/usr/local/tomcat/webapps/my-webapp'
}
感兴趣的朋友请参阅Docker化Maven WAR项目[1]与Docker化Gradle WAR项目[2]的相关说明。在Kubernetes开发当中与Skaffold for Java相集成
Skaffold是一款用于在Kubernetes上实现持续开发的命令行工具。我们将Skaffold与Jib加以集成,旨在实现Kubernetes之上的无缝化开发体验。Jib现在已经可以作为Skaffold当中的builder选项。
要在您的Java项目当中开始使用Skaffold,您首先需要安装Skaffold并向项目当中添加skaffold.yaml文件:skaffold.yaml:
apiVersion: skaffold/v1beta4
kind: Config
build:
artifacts:
- image: gcr.io/my-project/my-java-image
# Use this for a Maven project:
jibMaven: {}
# Use this for a Gradle project:
jibGradle: {}
请确保您已经把Kubernetes清单存放在k8s/目录当中,且Container规范中的镜像引用匹配至gcr.io/my-project/my-java-image位置。请查阅Skaffold库作为参考[3]。接下来,您可以使用以下命令启动Skaffold的持续开发功能:$ skaffold dev --trigger notify
Skaffold能够帮助您消除在进行每一项变更之后,对应用程序进行重新构建与重新部署所带来的一系列繁琐步骤。Skaffold会利用Jib对您的应用程序进行容器化转换,而后在检测到变更时将其部署至您的Kubernetes集群当中。现在,您将能够把精力集中到真正重要的工作——编写代码身上。Jib Core:在Java中构建Docker镜像Jib运行在我们自己用于构建容器镜像的通用库之上,我们将这套库以Jib Core的形式进行发布,同时进行了一系列API改进。现在,您可以将Jib作为Maven以及Gradle插件,从而在无需Docker守护程序的前提下面向任意应用程序利用Java进行容器构建。要使用Jib Core,您需要在项目当中添加以下文件:
com.google.cloud.tools
jib-core
0.1.1
dependencies {
implementation 'com.google.cloud.tools:jib-core:0.1.1'
}
以下是构建一套简单Docker镜像的操作示例。其将以基础镜像为起点,添加单一层、设置入口点,而后使用几行代码将镜像推送至远端注册表当中:Jib.from("busybox")
.addLayer(Arrays.asList(Paths.get("helloworld.sh")), AbsoluteUnixPath.get("/"))
.setEntrypoint("sh", "/helloworld.sh")
.containerize(
Containerizer.to(RegistryImage.named("gcr.io/my-project/hello-from-jib")
.addCredential("myusername", "mypassword")));
我们也鼓励大家利用Jib Core构建属于自己的自定义容器化解决方案[4]。欢迎您在我们的Gitter频道[5]上共享利用Jib Core构建的一切项目。另外,您也可以参考我们发布的Jib Core其它使用示例,例如Gradle构建脚本[6]。利用Jib对Java应用程序进行容器化转换仍然与以往一样简单易行。如果您使用的是Maven,只需要将这款插件添加至pom.xml当中:
com.google.cloud.tools
jib-maven-plugin
1.0.0
gcr.io/my-project/my-java-image
要构建一套镜像并将其推送至容器注册表,您可使用以下命令:$ mvn compile jib:build
或者使用以下命令面向Docker守护程序进行构建:$ mvn compile jib:dockerBuild
您现在甚至可以在无需修改pom.xml文件的前提下实现应用程序容器化,具体操作如下:$ mvn compile com.google.cloud.tools:jib-maven-plugin:1.0.0:
build -Dimage=gcr.io/my-project/my-java-image
若需了解更多细节信息,请参阅Jib Maven快速入门[7]。 当配合Gradle使用Jib时,您需要将该插件添加至build.gradle当中:plugins {
id 'com.google.cloud.tools.jib' version '1.0.0'
}
jib.to.image = 'gcr.io/my-project/my-java-image'
在此之后,您可以利用以下命令将应用程序容器化至目标容器注册表:
$ gradle jib
或者使用以下命令将其容器化至Docker守护程序:$ gradle jibDockerBuild
若需了解更多细节信息,请参阅Jib Gradle快速入门[8]。我们希望Jib能够帮助每一位朋友简化并加快自己的Java开发进程。要开始使用Jib,请参阅我们的示例[9];此外,您也可使用Codelabs将Spring Boot应用程序或者Micronaut应用程序部署至Kubernetes当中。Jib能够与大多数Docker注册表提供程序以及托管注册表相兼容;请尽情尝试,并通过github.com/GoogleContainerTools/jib与我们分享您的心得体会。感谢!https://cloudtoolsforjava.page.link/hfCY
https://cloudtoolsforjava.page.link/iDVw
https://cloudtoolsforjava.page.link/WepQ
https://cloudtoolsforjava.page.link/U1YB
https://gitter.im/google/jib
https://cloudtoolsforjava.page.link/K5uf
https://cloudtoolsforjava.page.link/vhUX
https://cloudtoolsforjava.page.link/vhUX
https://cloudtoolsforjava.page.link/Xwwv
原文链接:https://cloud.google.com/blog/products/application-development/jib-1-0-0-is-ga-building-java-docker-images-has-never-been-easier
Kubernetes实战培训将于2019年3月8日在深圳开课,3天时间带你系统掌握Kubernetes,学习效果不好可以继续学习。本次培训包括:云原生介绍、微服务;Docker基础、Docker工作原理、镜像、网络、存储、数据卷、安全;Kubernetes架构、核心组件、常用对象、网络、存储、认证、服务发现、调度和服务质量保证、日志、监控、告警、Helm、实践案例等。