Java微服务是否可以和Go一样快

发布时间:2021-10-25 10:23:11 作者:iii
来源:亿速云 阅读:168

这篇文章主要讲解了“Java微服务是否可以和Go一样快”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java微服务是否可以和Go一样快”吧!

Java的历史

Java由Sun Microsystems开发,后来被Oracle收购。  其1.0版本于1996年发布,最新版本是2020年的Java15。主要设计目标是Java虚拟机和字节码的可移植性以及带有垃圾回收的内存管理。  它仍然是最流行的语言之一(根据StackOverflow和TIOBE之类的来源),它是在开源中开发的。

让我们谈谈" Java问题"。

Java微服务是否可以和Go一样快

多年来,Java有许多不同的垃圾收集算法,包括串行,并行,并发标记/清除,G1和新的ZGC垃圾收集器。  现代垃圾收集器旨在最大程度地减少垃圾收集"停止世界"暂停的时间。

Oracle实验室开发了一种新的名为GraalVM的Java虚拟机,该Java虚拟机用Java编写,具有新的编译器和一些令人兴奋的新功能,例如能够将Java字节码转换为无需Java  VM即可运行的本机映像。

Go的历史

Go由Google的Robert Griesemer,Rob Pike和Ken Thomson创建。

Go受C,Python,Javascript和C的影响。 它被设计为用于高性能网络和多处理的最佳语言。

在我们演讲时,StackOverflow有27,872个被" Go"标记的问题,而Java则为1,702,730。

Go是一种静态类型的编译语言。

Go是许多CNCF项目的首选语言,例如Kubernetes,Istio,Prometheus和Grafana都(大部分)用Go编写。

它旨在具有快速的构建时间和快速的执行。

Go(与Java相比)有什么好处-根据我的经验,这是我的个人看法:

那么,Go的"问题"是什么?

负载测试方法

我们使用JMeter进行负载测试。 测试多次调用服务,并收集有关响应时间,吞吐量(每秒事务)和内存使用情况的数据。  对于Go,我们收集常驻集大小;对于Java,我们跟踪本机内存。

在许多测试中,我们将JMeter与被测应用程序在同一台计算机上运行。  如果我们在另一台机器上运行JMeter,结果似乎没有任何干扰或差异,因此可以简化设置。  当我们以后将应用程序部署到Kubernetes中时,JMeter在集群外部的远程计算机上运行。

在进行测量之前,我们使用了1,000次服务调用来预热了应用程序。

第一轮测试

在第一轮中,我们在"小型"计算机上进行了测试,在这种情况下,该计算机是2.5GHz双核Intel Core i7笔记本电脑,具有16GB  RAM,运行macOS。

结果如下:

Java微服务是否可以和Go一样快

我们宣布Go成为第一轮的获胜者!

以下是我们根据这些结果得出的观察结果:

GraalVM本机映像

GraalVM具有本机映像功能,可让您采用Java应用程序并将其本质上编译为本机可执行代码。

该可执行文件包括应用程序类,其依赖项中的类,运行时库类以及JDK中的静态链接本机代码。

这是再次添加GraalVM本机图像测试(使用GraalVM EE 20.1.1-JDK 11构建的本地图像)的第一轮结果:

Java微服务是否可以和Go一样快

在这种情况下,与在JVM上运行应用程序相比,使用GraalVM本机映像没有看到吞吐量或响应时间的任何显着改善,但是内存占用空间较小。

以下是一些测试的响应时间的图表:

Java微服务是否可以和Go一样快

> Response time graphs for round one

请注意,在所有这三种Java变体中,第一个请求的响应时间要长得多(请在与左轴相对的右上方寻找那条蓝线)。

第二轮

接下来,我们决定在更大的计算机上运行测试。

与第一轮一样,我们使用了100个线程,每个线程10,000个循环,10秒的启动时间以及相同版本的Go,Java,Helidon和GraalVM。

结果如下:

Java微服务是否可以和Go一样快

我们宣布GraalVM本机映像是第二轮的赢家!

以下是这些测试的响应时间图:

Java微服务是否可以和Go一样快

> Response times for test runs with logging enabled but no warmup

Java微服务是否可以和Go一样快

> Response times for test runs with no logging and no warmup

Java微服务是否可以和Go一样快

> Response times for test runs with warmup but no logging

第二轮的一些观察:

第三轮-Kubernetes

在第三轮中,我们决定在Kubernetes集群中运行应用程序—您可能会说,这是微服务的更自然的运行时环境。

在这一轮中,我们使用了具有三个工作节点的Kubernetes  1.16.8集群,每个工作节点都有两个内核(每个都有两个执行线程),14GB的RAM和Oracle Linux 7.8。  在某些测试中,我们为每个变体运行了一个Pod,在其他测试中运行了100个Pod。

应用程序访问是通过Traefik入口控制器进行的,其中JMeter在Kubernetes集群外部运行,以进行某些测试,对于其他测试,我们使用ClusterIP并在集群中运行JMeter。

与之前的测试一样,我们使用了100个线程,每个线程10,000个循环,以及10秒的启动时间。

以下是每个变体的容器大小:

结果如下:

Java微服务是否可以和Go一样快

以下是一些响应时间表:

Java微服务是否可以和Go一样快

> Response times from Kubernetes tests

在这一轮中,我们观察到Go有时会更快,而GraalVM本地映像有时会更快,但是两者之间的差异很小(通常小于5%)

那我们学到了什么?

我们对所有这些测试和结果进行了反思,以下是一些结论:

接下来是什么?

这是一个非常有趣的练习,我们打算继续努力,特别是:

感谢各位的阅读,以上就是“Java微服务是否可以和Go一样快”的内容了,经过本文的学习后,相信大家对Java微服务是否可以和Go一样快这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

推荐阅读:
  1. Java和go语言哪个更好?
  2. php和java对比哪个快

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

java go

上一篇:Linux中Rsync命令有哪些备份选项

下一篇:Python爬虫经常会被封的原因是什么

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》