BT

你的观点很重要! 快来参与InfoQ调研吧!

从成本角度看Java微服务

| 作者 薛命灯 关注 11 他的粉丝 发布于 2017年11月2日. 估计阅读时间: 2 分钟 | ArchSummit社交架构图谱:Facebook、Snapchat、Tumblr等背后的核心技术

亲爱的读者:我们最近添加了一些个人消息定制功能,您只需选择感兴趣的技术主题,即可获取重要资讯的邮件和网页通知

近年来,微服务因其良好的灵活性和伸缩性等特点备受追捧,很多公司开始采用微服务架构或将已有的单体系统改造成微服务。IBM也于近日开源了轻量级Java微服务应用服务器Open Liberty。但是采用Java开发微服务真的是最好的选择吗?来自JPmorgan的高级工程师Elliot Forbes基于自身的经历,从成本角度进行分析,并与其他语言的微服务做了对比,很好地回答了这个问题。

Elliot所在的团队最初使用Java开发了一个单体系统。他们的生产环境总共有12台服务器,每台服务器上部署了20到30个实例,每个实例使用8G内存。这样,总共耗费了1.5T到2.5T内存。后来,他们将单体拆解成5个微服务,并使用容器来部署微服务。每个容器运行一个微服务,因为是基于JVM的,所以至少需要1G内存。原先的一个单体实例使用8G内存,拆成微服务后总共只需要5G到6G内存,省下了至少2G内存。

但事情不会就这么简单。他们当中的一个微服务负责对外提供REST API,是整个系统最为关键的部分。为了提高可用性,他们在欧洲、北美和亚洲分别部署了4个实例。这样一来,这个微服务总共使用了12G内存,所以整体的内存使用反而增加了不少。

而如果使用Go语言替代Java开发微服务会怎样呢?每个微服务的内存可以从1G降到64M,那么之前那个部署了12个实例的微服务总共只需要768M内存,这比之前的单个Java微服务实例用的内存还要少。

假设微服务是部署在谷歌云平台上的,按照GCP的收费标准,1G内存每小时收费在1美分到2美分之间,一年大概需要87美元到175美元,那么12G内存一年至少要花费1000美元。5个微服务加起来一年至少需要5000美元。而如果使用Go语言,这个数字差不多在500美元左右,可以说是减少了一个数量级。

不过Elliot也解释说,成本只是在采用微服务时需要考虑的众多因素当中的一个。除了成本,还需要考虑开发语言适用性等方面的问题。不过对于大型企业来说,他们拥有大量的微服务,成本仍然是一个重要的考虑因素,毕竟一年下来,有可能为他们节省数百万美元。


感谢郭蕾对本文的审校。

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

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

无意义的文章 by 刘 睿

无意义的文章

这是为了说明GO更省内存? by Chen YuGuo

这是为了说明GO更省内存?

Java 9 呢 by 东 东

Java 9 的 App Image 启动内存会下降吗?

这种文章也能上首页?!! by 王 铭源

这种文章也能上首页?!!

Re: 无意义的文章 by yuanzhi wang

Java要1G,GO只要64M,相同并发,相同业务? 这牛吹大了吧。怎么听着都不敢相信呀。

微服务拆分不好,的确会增加部分实例,但是拿64m的Go和 1g 的java比就没有意义了吧? by yang shuqing

微服务拆分不好,的确会增加部分实例,但是拿64m的Go和 1g 的java比就没有意义了吧?比也得比 支持同等量级的业务量需要的内存数,而不是最小启动内存

国内使用java的公司快走火入魔了,一般的中小型公司没必要跟阿里学 by 刘 义宝

国内使用java的公司快走火入魔了,一般的中小型公司没必要跟阿里学

太肤浅 by 洪 成志

我在此控诉内容管理人员,这样的内容肤浅的文章也能上头条。

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

8 讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT