写点什么

Arun Gupta:使用 Docker 和 Kubernetes 部署 Java EE 应用的方法

  • 2015-04-01
  • 本文字数:1347 字

    阅读完需:约 4 分钟

Arun Gupta 在 2015 年 JavaLand 大会上,展示了多种使用 Docker Kubernetes 部署 Java EE 应用的方法。Gupta 讲述了容器对于部署和管理应用的优势,容器具备快速部署、隔离性和可移植性等优点。使用容器集群管理系统,比如 Kubernetes,可以将 Docker 容器相关的管理作为唯一单位,简化了跨主机通信的实现,保证了可用性和可扩展性。

Red Hat 软件的开发者宣传董事 Gupta,在 JavaLand 的演讲首先介绍了 Docker ,开源项目 Docker 可用于基于 (LXC)[ https://linuxcontainers.org/ ]软件容器应用的自动部署。使用Docker 胜于更传统的部署机制之处包括更快的部署、隔离性、可移植性、限制资源使用的能力,以及提供安全沙箱。

接下来,Gupta 演示了九种使用Docker 打包和部署Java EE 应用的方法。这些方法包括使用 Docker Machine 安装 Docker、运行在单个 Docker 容器内的 WildFly Java EE 应用服务器使用 H2 内存数据库,以及分别在两个容器中部署应用服务器和数据库并通过容器的link 进行通信。

除此之外的方法还包括使用 Fig Docker Compose 这两种编排工具定义多应用和多容器环境。Gupta 还演示了如何在为服务发现预配置 IP 地址的两台主机上部署容器,以及如何使用 Eclipse IDE 管理基于 Docker 的开发阶段的部署。在整个介绍的最后部分,Gupta 概述了 Arquillian Cube 的使用,通过 Maven 构建工具的 surefire-plugin 插件,在测试生命周期内控制 Docker 镜像的生命周期。

接下来,Gupta 的演示探讨了使用 Google 的 Kubernetes 集群管理系统,部署和管理 Java EE 应用。Kubernetes 是一种 Docker 容器的开源编排系统,其核心概念包括:pod,用于组合在一起将容器编组,以便共享IP 和存储卷;service,用于为pod 集合提供唯一不变的名称,还可以用作负载均衡;replication controller,用于管理pod 的生命周期并确保任何时间正在运行的service 数量不低于预定值。

Gupta 演示了基于 Kubernetes 的方法,包括使用 Vagrant 以加载并运行本地 Kubernetes 开发环境集群,WildFly 应用服务器 service 的创建以及与 MySQL service 的通信,还有使用 replication controller 确保运行指定数量的应用服务器 service。

Gupta 表示 Docker 和 Kubernetes 是有益于部署和管理 Java EE 应用的工具。 除了上面提及的 Docker 的优点之外,Kubernetes 还可以将 Docker 容器相关的管理作为唯一单位,有助于跨主机通信,并且通过自动化部署和监控 pod 及其跨主机的复本,从而保证了可用性和可扩展性。

这种方式的潜在缺点包括,在 Docker 中没有包含更高级别的加载或者使用情况追踪能力(但是通过额外的工具可以实现),使用 Kubernetes 部署应用有可能会导致复杂的生命周期,包括构建、部署、管理和升级(包括改造已有应用支持这一过程)。

前述方法的更多信息和全部细节详见 Gupta 的博客 _“ Miles to go 2.0 ”_ 和他帐号下的 slideshare 。JavaLand 是在德国布吕尔召开的年度 Java 大会,详情参见 JavaLand 事件网站

查看英文原文: Arun Gupta: Recipes for Deploying Java EE Apps with Docker and Kubernetes


感谢邵思华对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们,并与我们的编辑和其他读者朋友交流。

2015-04-01 06:443050

评论

发布
暂无评论
发现更多内容

源中瑞智慧社区解决方案,社区服务平台

13530558032

GO训练营第10周——日志&指标&链路追踪

Glowry

电子门锁没电的解决办法

孙叫兽

生活 程序人生 电子锁

2021金三银四春招来袭,掌握这份成长宝典,offer岂不是随便拿?

Java架构之路

Java 程序员 架构 面试 编程语言

GO训练营第12、13周—— runtime

Glowry

跟我学ModelArts丨探索ModelArts平台个性化联邦学习API

华为云开发者联盟

AI 联邦学习 API 华为云 modelarts

如何批量下载YouTube视频到本地

科技猫

软件 音视频 经验分享 资源分享 工具分享

拍乐云推出“实时标注”,助力少儿编程、在线金融等行业场景实现高效互动

拍乐云Pano

音视频 在线教育 互动白板 实时标注 在线金融

全票通过!微众开源项目EventMesh进入Apache孵化器

康月牙

Apache 开源 Event 事件网格 eventmesh

我看 JAVA 之 引用类型(Reference)

awen

Java ThreadLocal Reference

标准引领 浪潮工业互联网助力澳门质量品牌国际认证联盟成立

工业互联网

Java 和 Python 关于 % 的那些坑

与你一起学算法

Java Python

2021 年要了解的 34 种 JavaScript 简写优化技术

LeanCloud

JavaScript 面试 大前端

2021最新总结网易/腾讯/CVTE/字节面经分享(附答案解析)

比伯

Java 编程 架构 面试 程序人生

寻找被遗忘的勇气(十九)

Changing Lin

3月日更

堪称完美!中国Java之父纯手打,阿里首发:多线程与高并发

Java架构之路

Java 程序员 架构 面试 编程语言

EGG Network公链技术创新,EFTalk打造高效全能公链

币圈那点事

区块链

2B营销路径: 9大步骤自我拆解

boshi

营销数字化 七日更

【前端面试题】关于一些js的一些面试题(金融行业),我和面试官扯了三个小时

孙叫兽

JavaScript 大前端 金融 笔试题

看了上百份面经,发现每次面试的问题都逃不过这几方面

yes

面试

GO训练营第11周——DNS&CDN&多活架构

Glowry

产品调研报告

Ashley.

xshell不能输入命令字符了?

Geek_6370d5

xshell 错误集锦

区块链电子发票平台,区块链电子发票优势

13530558032

安卓嵌入式底层开发!整理出这份8万字Android性能优化实战解析,已开源

欢喜学安卓

android 程序员 面试 移动开发

智慧党建信息管理平台系统建设

13530558032

冲击大厂!阿里P9纯手打Java面试小抄(21版)在GitHub上已获80万star

Java 程序员 面试

打卡学习 VBA 和 PYTHON week01-02

小怪兽

3月日更 【IT蜗壳教学】 【自我错误点总结】

快点来学吧!Android性能优化面试题集锦,深度解析,值得收藏

欢喜学安卓

android 程序员 面试 移动开发

炸了,炸了!阿里P9纯手打Java面试小抄(21版)在GitHub上已获80万star

Java架构之路

Java 程序员 架构 面试 编程语言

FFmpeg入门篇

Changing Lin

ffmpeg media

Arun Gupta:使用Docker和Kubernetes部署Java EE应用的方法_DevOps & 平台工程_Daniel Bryant_InfoQ精选文章