资讯专栏INFORMATION COLUMN

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

MudOnTire / 3053人阅读

摘要:在年下旬开源了一款新的工具,可以轻松地将应用程序容器化。由于默认访问谷歌的仓库,而国内访问不稳定会经常导致网络超时,所以笔者使用了国内的阿里云镜像服务,那么就不需要访问谷歌的仓库了。执行完成后,我们可以在阿里云镜像仓库获取镜像。

原文地址:梁桂钊的博客

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

欢迎关注公众号:「服务端思维」。一群同频者,一起成长,一起精进,打破认知的局限性。

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

开源地址:https://github.com/GoogleContainerTools/jib
一、什么是 Jib

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

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

二、实战出真知 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 文件。


    4.0.0
    com.lianggzone.sample.lib
    helloworld-samples
    0.1
    jar
    helloworld-samples
    
        UTF-8
        1.0.2
        3.8.0
    
    
    
    
        
            
                org.apache.maven.plugins
                maven-compiler-plugin
                ${maven-compiler-plugin.version}
                
                    1.8
                    1.8
                
            
            
            
                com.google.cloud.tools
                jib-maven-plugin
                ${jib-maven-plugin.version}
                
                    
                        registry.cn-hangzhou.aliyuncs.com/lianggzone/oracle_java8
                    
                    
                        registry.cn-hangzhou.aliyuncs.com/lianggzone/jib-helloworld:v1
                    
                    
                        
                            -Xms512m
                            -Xdebug
                        
                        com.lianggzone.HelloWorld
                    
                
                
                    
                        package
                        
                            build
                        
                    
                
            
        
    

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

mvn compile jib:build

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


  ...
  
    ...
        
        registry.cn-hangzhou.aliyuncs.com
        你的阿里云账号
        你的阿里云密码
        
  

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

大功告成,现在,我们来验证一把。我们通过 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

执行结果,如下所示。

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 文件。



    4.0.0

    
        org.springframework.boot
        spring-boot-starter-parent
        2.1.2.RELEASE
    

    com.lianggzone.sample.lib
    springboot-samples
    0.1
    jar
    springboot-samples

    
        
            org.springframework.boot
            spring-boot-starter-web
        
    

    
        UTF-8
        1.0.2
        3.8.0
    
    
    
        
            
                org.apache.maven.plugins
                maven-compiler-plugin
                ${maven-compiler-plugin.version}
                
                    1.8
                    1.8
                
            
            
            
                com.google.cloud.tools
                jib-maven-plugin
                ${jib-maven-plugin.version}
                
                    
                        registry.cn-hangzhou.aliyuncs.com/lianggzone/oracle_java8
                    
                    
                        registry.cn-hangzhou.aliyuncs.com/lianggzone/jib-springboot:v1
                    
                    
                        
                            -Xms512m
                            -Xdebug
                        
                    
                
                
                    
                        package
                        
                            build
                        
                    
                
            
        
    

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

现在,我们再来验证一把。我们通过 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

执行结果,如下所示。

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

3. 构建一个 WAR 工程

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


  
    tomcat:8.5-jre8-alpine
  
  
    /usr/local/tomcat/webapps/ROOT
  
三、源码地址

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

附:参考资料

https://github.com/GoogleContainerTools/jib

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

(完,转载请注明作者及出处。)

写在末尾

【服务端思维】:我们一起聊聊服务端核心技术,探讨一线互联网的项目架构与实战经验。同时,拥有众多技术大牛的「后端圈」大家庭,期待你的加入,一群同频者,一起成长,一起精进,打破认知的局限性。

更多精彩文章,尽在「服务端思维」!

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/74115.html

相关文章

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

    摘要:在年下旬开源了一款新的工具,可以轻松地将应用程序容器化。由于默认访问谷歌的仓库,而国内访问不稳定会经常导致网络超时,所以笔者使用了国内的阿里云镜像服务,那么就不需要访问谷歌的仓库了。执行完成后,我们可以在阿里云镜像仓库获取镜像。 原文地址:梁桂钊的博客博客地址:http://blog.720ui.com 欢迎关注公众号:「服务端思维」。一群同频者,一起成长,一起精进,打破认知的局限性。...

    Anonymous1 评论0 收藏0
  • 稳定高于一切的金融行业如何用容器

    摘要:在谷歌不是这样,谷歌不会把特定的应用装在某台服务器上,业务应用和服务器的强绑定对于谷歌这种量级的数据中心的维护难度太高了。但是金融机构的数据中心规模不像谷歌这么大,所以能做到业务应用和硬件的强绑定。 复杂的基础IT架构是传统金融的现状,如何快速响应用户需求,加快新业务上线速度,缩短产品的迭代周期? 数人云在容器落地金融云的2年实践中,实现金融核心业务技术WebLogic、J2EE、Or...

    scola666 评论0 收藏0
  • Cube如何助力科盾业务容器“一步到位”?

    前言 以Docker为代表的容器技术缩短了企业应用从开发、构建到发布、运行的整个生命周期。Gartner推测到2022年将会有75%的全球化企业将在生产中使用容器化的应用(当前约为30%)。由于Docker往往难以独立支撑起大规模容器化部署,因此诞生了Kubernetes等容器编排工具,解决了大规模容器的组织和管理难题。 但事实上,Kubernetes的使用体系还是非常复杂的,对于企业的开...

    happyhuangjinjin 评论0 收藏0
  • UCloud Cube助力科盾业务容器一步到位

    摘要:帮助科盾实现了业务的快速回滚和横向扩展。后续,科盾计划引入集群,并将更多数据处理链等上的服务迁移至。前言 以Docker为代表的容器技术缩短了企业应用从开发、构建到发布、运行的整个生命周期。Gartner推测到2022年将会有75%的全球化企业将在生产中使用容器化的应用(当前约为30%)。由于Docker往往难以独立支撑起大规模容器化部署,因此诞生了Kubernetes等容器编排工具,解决...

    songjz 评论0 收藏0
  • 谷歌发布Kubernetes v1.0,容器生态前景明媚

    摘要:与此同时,谷歌联合基金会及其他合作伙伴共同成立了基金会,并将作为首个编入管理体系的开源项目,助力容器技术生态的发展进步。年月谷歌宣布开源。年月容器引擎启动,谷歌宣布中支持容器及服务,并以为构架。 7月22日Google正式对外发布 Kubernetes v 1.0,意味着这个开源容器编排系统可以正式在生产环境使用。与此同时,谷歌联合linux基金会及其他合作伙伴共同成立了CNCF基金会...

    Mertens 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<