国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Java微服務(wù)可以和Go一樣快嗎?

開發(fā) 前端
業(yè)界普遍認(rèn)為Java是"老的","慢的"和"無聊的"。 Go是"快速","新"和"酷"。 但是我們想知道這些特性是否得到實(shí)際性能數(shù)據(jù)的保證或支持。

我們想進(jìn)行實(shí)驗(yàn),看看Java微服務(wù)是否可以像Go微服務(wù)一樣快速運(yùn)行。 業(yè)界普遍認(rèn)為Java是"老的","慢的"和"無聊的"。 Go是"快速","新"和"酷"。 但是我們想知道這些特性是否得到實(shí)際性能數(shù)據(jù)的保證或支持。

[[351764]]

我們想要一個(gè)公平的測試,所以我們創(chuàng)建了一個(gè)非常簡單的微服務(wù),沒有外部依賴項(xiàng)(例如數(shù)據(jù)庫),并且代碼路徑非常短(僅處理字符串)。 我們確實(shí)包含了指標(biāo)和日志記錄,因?yàn)樗鼈兯坪蹩偸前谌魏螌?shí)際的微服務(wù)中。 我們使用了小型輕量級(jí)的框架(Helidon for Java和Go-Kit for Go),并且還嘗試了Java的純JAX-RS。 我們嘗試了不同版本的Java和不同的JVM。 我們對(duì)堆大小和垃圾收集器進(jìn)行了一些基本調(diào)整。 我們?cè)跍y試運(yùn)行之前對(duì)微服務(wù)進(jìn)行了預(yù)熱。

Java的歷史

Java由Sun Microsystems開發(fā),后來被Oracle收購。 其1.0版本于1996年發(fā)布,最新版本是2020年的Java15。主要設(shè)計(jì)目標(biāo)是Java虛擬機(jī)和字節(jié)碼的可移植性以及帶有垃圾回收的內(nèi)存管理。 它仍然是最流行的語言之一(根據(jù)StackOverflow和TIOBE之類的來源),它是在開源中開發(fā)的。

讓我們談?wù)?quot; Java問題"。

Java微服務(wù)可以和Go一樣快嗎?

多年來,Java有許多不同的垃圾收集算法,包括串行,并行,并發(fā)標(biāo)記/清除,G1和新的ZGC垃圾收集器。 現(xiàn)代垃圾收集器旨在最大程度地減少垃圾收集"停止世界"暫停的時(shí)間。

Oracle實(shí)驗(yàn)室開發(fā)了一種新的名為GraalVM的Java虛擬機(jī),該Java虛擬機(jī)用Java編寫,具有新的編譯器和一些令人興奮的新功能,例如能夠?qū)ava字節(jié)碼轉(zhuǎn)換為無需Java VM即可運(yùn)行的本機(jī)映像。

Go的歷史

Go由Google的Robert Griesemer,Rob Pike和Ken Thomson創(chuàng)建。

Go受C,Python,Javascript和C的影響。 它被設(shè)計(jì)為用于高性能網(wǎng)絡(luò)和多處理的最佳語言。

在我們演講時(shí),StackOverflow有27,872個(gè)被" Go"標(biāo)記的問題,而Java則為1,702,730。

Go是一種靜態(tài)類型的編譯語言。

Go是許多CNCF項(xiàng)目的首選語言,例如Kubernetes,Istio,Prometheus和Grafana都(大部分)用Go編寫。

它旨在具有快速的構(gòu)建時(shí)間和快速的執(zhí)行。

Go(與Java相比)有什么好處-根據(jù)我的經(jīng)驗(yàn),這是我的個(gè)人看法:

  • 容易實(shí)現(xiàn)功能模式,例如合成,純函數(shù),不可變狀態(tài)。
  • 樣板代碼少得多(但仍然太多)。
  • 它仍然處于生命周期的早期,因此它不具有向后兼容的沉重負(fù)擔(dān)-他們?nèi)匀豢梢源蚱片F(xiàn)狀來改進(jìn)它。
  • 它可以編譯成本地靜態(tài)鏈接的二進(jìn)制文件-無虛擬機(jī)層-二進(jìn)制文件具有運(yùn)行程序所需的一切,這對(duì)于" FROM scratch"容器非常有用。
  • 它具有體積小,啟動(dòng)快和執(zhí)行快的特點(diǎn)。
  • 沒有OOP,繼承,泛型,斷言,指針?biāo)阈g(shù)。
  • 括號(hào)較少,例如
  • 沒有循環(huán)依賴性,沒有未使用的變量或?qū)耄瑳]有隱式類型轉(zhuǎn)換的強(qiáng)制。

那么,Go的"問題"是什么?

  • 工具生態(tài)系統(tǒng)還不成熟,尤其是依賴管理-有多種選擇,沒有一個(gè)是完美的,特別是對(duì)于非開源開發(fā)而言;
  • 建立具有新/更新依賴關(guān)系的代碼非常慢(例如Maven著名的"下載Internet"問題。
  • 導(dǎo)入會(huì)將代碼綁定到存儲(chǔ)庫,這使代碼在噩夢中移動(dòng)。
  • IDE非常適合編程,文檔查找,自動(dòng)完成等。
  • 指針!
  • 沒有Java風(fēng)格的try / catch異常(如果err!= nil的使用頻率太高,您最終會(huì)寫出來),沒有功能風(fēng)格的原語,例如列表,映射函數(shù)等。
  • 由于它尚不可用,您通常會(huì)最終實(shí)現(xiàn)一些基本算法。 最近,我寫了一些代碼,由sloe進(jìn)行了兩個(gè)字符串(列表)的比較,并進(jìn)行了轉(zhuǎn)換。 用一種功能語言,我本可以使用諸如map這樣的內(nèi)置函數(shù)來做到這一點(diǎn)。
  • 沒有動(dòng)態(tài)鏈接! (您問"誰在乎?"。)如果您要使用帶有"感染"靜態(tài)鏈接代碼的GPL許可證的代碼,這可能是一個(gè)真正的問題。
  • 調(diào)節(jié)執(zhí)行或垃圾收集,配置文件執(zhí)行或優(yōu)化算法的旋鈕并不多-Java具有數(shù)百種垃圾收集調(diào)整選項(xiàng),而Go具有一個(gè)-啟用或禁用。

負(fù)載測試方法

我們使用JMeter進(jìn)行負(fù)載測試。 測試多次調(diào)用服務(wù),并收集有關(guān)響應(yīng)時(shí)間,吞吐量(每秒事務(wù))和內(nèi)存使用情況的數(shù)據(jù)。 對(duì)于Go,我們收集常駐集大小;對(duì)于Java,我們跟蹤本機(jī)內(nèi)存。

在許多測試中,我們將JMeter與被測應(yīng)用程序在同一臺(tái)計(jì)算機(jī)上運(yùn)行。 如果我們?cè)诹硪慌_(tái)機(jī)器上運(yùn)行JMeter,結(jié)果似乎沒有任何干擾或差異,因此可以簡化設(shè)置。 當(dāng)我們以后將應(yīng)用程序部署到Kubernetes中時(shí),JMeter在集群外部的遠(yuǎn)程計(jì)算機(jī)上運(yùn)行。

在進(jìn)行測量之前,我們使用了1,000次服務(wù)調(diào)用來預(yù)熱了應(yīng)用程序。

應(yīng)用程序本身的源代碼以及負(fù)載測試的定義都在以下GitHub存儲(chǔ)庫中:

https://github.com/markxnelson/go-java-go

第一輪測試

在第一輪中,我們?cè)?quot;小型"計(jì)算機(jī)上進(jìn)行了測試,在這種情況下,該計(jì)算機(jī)是2.5GHz雙核Intel Core i7筆記本電腦,具有16GB RAM,運(yùn)行macOS。

結(jié)果如下:

Java微服務(wù)可以和Go一樣快嗎?

我們宣布Go成為第一輪的獲勝者!

以下是我們根據(jù)這些結(jié)果得出的觀察結(jié)果:

  • 日志記錄似乎是主要的性能問題,尤其是java.util.logging。 因此,我們?cè)谶M(jìn)行日志記錄和不進(jìn)行日志記錄的情況下都進(jìn)行了測試。 我們還注意到,日志記錄是Go應(yīng)用程序性能好的重要因素。
  • Java版本具有顯著的更大的內(nèi)存占用空間,即使對(duì)于如此小的簡單應(yīng)用程序也是如此
  • 預(yù)熱對(duì)JVM產(chǎn)生了很大的影響-我們知道JVM在運(yùn)行時(shí)會(huì)進(jìn)行優(yōu)化,因此這很有意義
  • 在此測試中,我們正在比較不同的執(zhí)行模型-Go應(yīng)用程序被編譯為本地可執(zhí)行二進(jìn)制文件,而Java應(yīng)用程序被編譯為字節(jié)代碼,然后在虛擬機(jī)上運(yùn)行。

GraalVM本機(jī)映像

GraalVM具有本機(jī)映像功能,可讓您采用Java應(yīng)用程序并將其本質(zhì)上編譯為本機(jī)可執(zhí)行代碼。

該可執(zhí)行文件包括應(yīng)用程序類,其依賴項(xiàng)中的類,運(yùn)行時(shí)庫類以及JDK中的靜態(tài)鏈接本機(jī)代碼。

這是再次添加GraalVM本機(jī)圖像測試(使用GraalVM EE 20.1.1-JDK 11構(gòu)建的本地圖像)的第一輪結(jié)果:

Java微服務(wù)可以和Go一樣快嗎?

在這種情況下,與在JVM上運(yùn)行應(yīng)用程序相比,使用GraalVM本機(jī)映像沒有看到吞吐量或響應(yīng)時(shí)間的任何顯著改善,但是內(nèi)存占用空間較小。

以下是一些測試的響應(yīng)時(shí)間的圖表:

Java微服務(wù)可以和Go一樣快嗎?

> Response time graphs for round one

請(qǐng)注意,在所有這三種Java變體中,第一個(gè)請(qǐng)求的響應(yīng)時(shí)間要長得多(請(qǐng)?jiān)谂c左軸相對(duì)的右上方尋找那條藍(lán)線)。

第二輪

接下來,我們決定在更大的計(jì)算機(jī)上運(yùn)行測試。

與第一輪一樣,我們使用了100個(gè)線程,每個(gè)線程10,000個(gè)循環(huán),10秒的啟動(dòng)時(shí)間以及相同版本的Go,Java,Helidon和GraalVM。

結(jié)果如下:

Java微服務(wù)可以和Go一樣快嗎?

我們宣布GraalVM本機(jī)映像是第二輪的贏家!

以下是這些測試的響應(yīng)時(shí)間圖:

Java微服務(wù)可以和Go一樣快嗎?

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

Java微服務(wù)可以和Go一樣快嗎?

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

Java微服務(wù)可以和Go一樣快嗎?

> Response times for test runs with warmup but no logging

第二輪的一些觀察:

  • 在此測試中,Java變體的性能要好得多,并且在不使用日志記錄的情況下,其性能要比Go好很多
  • Java似乎更有能力使用硬件提供的多個(gè)內(nèi)核和執(zhí)行線程(與Go相比)–這是有一定道理的,因?yàn)镚o旨在作為一種系統(tǒng)和網(wǎng)絡(luò)編程語言,并且它是一種較年輕的語言,因此
  • 有趣的是,Java是在多核處理器不常見的時(shí)候設(shè)計(jì)的,而Go是在多核處理器不是通用的時(shí)候設(shè)計(jì)的。
  • 特別是,似乎Java日志記錄已成功卸載到其他線程/內(nèi)核,并且對(duì)性能的影響要小得多。
  • 這一輪的最佳性能來自GraalVM本機(jī)映像,平均響應(yīng)時(shí)間為0.25毫秒,每秒處理82,426個(gè)事務(wù),而Go的最佳結(jié)果為1.59毫秒和39,227 tps,但這是以增加兩個(gè)數(shù)量級(jí)的內(nèi)存為代價(jià)的用法!
  • Java變體的響應(yīng)時(shí)間似乎更加一致,但是出現(xiàn)了更多的峰值-我們認(rèn)為這意味著Go在做更多,更小的垃圾回收

第三輪-Kubernetes

在第三輪中,我們決定在Kubernetes集群中運(yùn)行應(yīng)用程序—您可能會(huì)說,這是微服務(wù)的更自然的運(yùn)行時(shí)環(huán)境。

在這一輪中,我們使用了具有三個(gè)工作節(jié)點(diǎn)的Kubernetes 1.16.8集群,每個(gè)工作節(jié)點(diǎn)都有兩個(gè)內(nèi)核(每個(gè)都有兩個(gè)執(zhí)行線程),14GB的RAM和Oracle Linux 7.8。 在某些測試中,我們?yōu)槊總€(gè)變體運(yùn)行了一個(gè)Pod,在其他測試中運(yùn)行了100個(gè)Pod。

應(yīng)用程序訪問是通過Traefik入口控制器進(jìn)行的,其中JMeter在Kubernetes集群外部運(yùn)行,以進(jìn)行某些測試,對(duì)于其他測試,我們使用ClusterIP并在集群中運(yùn)行JMeter。

與之前的測試一樣,我們使用了100個(gè)線程,每個(gè)線程10,000個(gè)循環(huán),以及10秒的啟動(dòng)時(shí)間。

以下是每個(gè)變體的容器大小:

  • 繼續(xù)11.6MB
  • Java / Helidon 1.41GB
  • Java / Helidon JLinked 150MB
  • 本機(jī)圖像25.2MB

結(jié)果如下:

Java微服務(wù)可以和Go一樣快嗎?

以下是一些響應(yīng)時(shí)間表:

Java微服務(wù)可以和Go一樣快嗎?

> Response times from Kubernetes tests

在這一輪中,我們觀察到Go有時(shí)會(huì)更快,而GraalVM本地映像有時(shí)會(huì)更快,但是兩者之間的差異很小(通常小于5%)

那我們學(xué)到了什么?

我們對(duì)所有這些測試和結(jié)果進(jìn)行了反思,以下是一些結(jié)論:

  • Kubernetes似乎沒有迅速擴(kuò)展
  • Java似乎比Go更擅長使用所有可用的內(nèi)核/線程-我們發(fā)現(xiàn)Java測試期間CPU利用率更高
  • 在具有更多內(nèi)核和內(nèi)存的機(jī)器上,Java性能更好;在較小/功能較弱的機(jī)器上,Go性能更好。
  • Go的性能總體上更加一致-可能是由于Java的垃圾回收
  • 在"生產(chǎn)規(guī)模"的計(jì)算機(jī)上,Java的運(yùn)行速度與Go一樣快,甚至更快
  • 日志記錄似乎是我們?cè)贕o和Java中遇到的主要瓶頸
  • Java的現(xiàn)代版本以及諸如Helidon之類的新框架在消除/減少Java的一些眾所周知且長期存在的問題(例如冗長程度,GC性能,啟動(dòng)時(shí)間等)的痛苦方面取得了長足的進(jìn)步。

接下來是什么?

這是一個(gè)非常有趣的練習(xí),我們打算繼續(xù)努力,特別是:

  • 我們想通過Kubernetes自動(dòng)擴(kuò)展做更多的工作-我們可能需要更復(fù)雜的微服務(wù)或更高的負(fù)載才能看到性能上的差異
  • 我們希望研究更復(fù)雜的微服務(wù),多種服務(wù)以及電路中斷等模式,并觀察網(wǎng)絡(luò)如何影響性能以及如何調(diào)整微服務(wù)網(wǎng)絡(luò)
  • 還想看一下日志記錄問題,看看該怎么做才能消除瓶頸
  • 我們想看一下目標(biāo)代碼并比較正在執(zhí)行的實(shí)際指令,看看是否可以在代碼路徑中做一些進(jìn)一步的優(yōu)化。
  • 我們想知道JMeter是否可以在不成為瓶頸的情況下產(chǎn)生足夠的負(fù)載,但是我們的測試表明這根本不是一個(gè)因素,它可以輕松跟上Go和Java實(shí)現(xiàn)。
  • 想要對(duì)容器啟動(dòng)時(shí)間,內(nèi)存占用量等進(jìn)行更詳細(xì)的測量。

 

責(zé)任編輯:趙寧寧 來源: 今日頭條
相關(guān)推薦

2021-04-12 10:20:20

Java微服務(wù)Go

2020-11-17 15:31:23

Java微服務(wù)Go

2021-01-14 09:55:21

Java微服務(wù)Go

2020-09-10 13:55:53

VScodego開發(fā)工具

2020-01-09 17:03:29

人工智能技術(shù)算法

2021-08-27 06:41:34

Docker ContainerdRun&Exec

2020-03-02 10:56:41

辦公電腦疫情

2021-01-14 16:00:52

VRVR電影3D電影

2024-08-19 11:23:36

2014-03-17 10:20:30

數(shù)據(jù)目錄服務(wù)

2021-10-17 22:02:27

顯卡內(nèi)存裝機(jī)

2024-01-05 07:36:54

人工智能創(chuàng)造力模型

2020-02-24 17:58:54

RSA大會(huì)網(wǎng)絡(luò)安全

2021-12-22 07:31:18

RedisNoSQL數(shù)據(jù)庫

2021-12-23 15:11:46

Web 3.0元宇宙Metaverse

2011-03-14 16:51:24

2021-05-12 08:46:09

電腦電腦網(wǎng)速技巧

2011-02-28 10:38:13

Windows 8

2012-03-07 17:24:10

戴爾咨詢

2012-12-20 10:17:32

IT運(yùn)維
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

色综合视频二区偷拍在线| 一级毛片国产| 欧美日韩一区自拍| 日韩美女免费观看| 免费一级欧美在线大片| 亚洲精品乱码久久久久久金桔影视| 日本国产在线| 亚洲va国产天堂va久久en| 二区中文字幕| 亚洲免费在线观看视频| 噼里啪啦国语在线观看免费版高清版| 麻豆成人免费电影| 亚洲欧美日韩另类精品一区二区三区 | 成人网址大全| 国产香蕉久久精品综合网| 精品久久久久久无码中文野结衣| 精一区二区三区| 一区国产精品| 国产精品一品二品| 波多野结衣 作品| 国产黄人亚洲片| 国产精品va在线观看无码| 国产**成人网毛片九色| 丝袜人妻一区二区三区| 成人av午夜电影| 日本一区二区黄色| 国产精品美女久久久久久久 | 国产精品久久久久久搜索 | 国产91精品在线观看| 99热这里只有精品免费| 成人三级伦理片| 成人在线免费在线观看| 中文无字幕一区二区三区| 丁香激情视频| 色偷偷久久人人79超碰人人澡| 欧美日韩在线看片| 日韩av网址在线观看| 日本午夜免费一区二区| 久久久久久久久国产| 久久99久久人婷婷精品综合 | 欧美亚洲自拍偷拍| 青草av在线| 一区二区三区高清国产| av一级亚洲| 国产91一区二区三区| 韩国视频一区二区| 免费国产成人av| 色婷婷av久久久久久久| 丁香花高清在线观看完整版| 一区二区三区在线播放欧美| 日本亚洲不卡| 91免费看蜜桃| 国产在线视频一区二区| 午夜免费看视频| 欧美视频一区二区三区| 日本黄色免费在线| 26uuu另类亚洲欧美日本老年| 亚洲国产一成人久久精品| 在线观看亚洲视频啊啊啊啊| 欧美激情综合网| 女女色综合影院| 久久久精品网站| 亚洲色图网站| 韩国无码av片在线观看网站| 一区二区三区在线视频观看| 日本精品600av| 91国内在线视频| 日韩专区在线视频| 亚洲第一狼人区| 精品蜜桃在线看| 校花撩起jk露出白色内裤国产精品| 2022国产精品| 性一交一乱一区二区洋洋av| 91精品视频在线免费观看| 国产精品视频区1| 欧美顶级大胆免费视频| 久久av喷吹av高潮av| 亚洲国产精品成人| 成人欧美一区二区三区在线观看| 久久久久综合| 欧美日韩在线三区| 国产亚洲字幕| 久久99热只有频精品91密拍| 欧美激情一区二区三区不卡| 18videosex性欧美麻豆| 欧美激情18p| 日本v片在线高清不卡在线观看| 日本韩国福利视频| 中文字幕国内精品| 国产欧美精品久久| 超碰色偷偷男人的天堂| 亚洲人成网站色ww在线| 亚洲三级色网| 992tv成人国产福利在线| 久久在精品线影院精品国产| 久久精品午夜| 青青色在线视频| 欧美一级电影久久| 国产成人av资源| 欧洲一区二区三区| 91精品黄色| 一级中文字幕一区二区| 国产亚洲精aa在线看| 久久免费在线观看| 99re热视频精品| 天堂中文最新版在线中文| 国产中文日韩欧美| 亚洲国产日韩综合久久精品| 卡通欧美亚洲| 日本午夜精品一区二区三区| 在线免费观看日本一区| 亚洲色图国产| 黄色av电影在线播放| 成人免费xxxxx在线观看| 一片黄亚洲嫩模| 欧美精品一卡| 日韩电影精品| 久久亚洲国产成人精品无码区| 国产午夜亚洲精品不卡| jizz欧美大全| 26uuu另类亚洲欧美日本老年| 91视视频在线观看入口直接观看www| 久久久久久久性潮| 成人黄色免费电影| 在线播放 亚洲| 7777精品伊人久久久大香线蕉 | 欧美成人免费小视频| 亚洲欧美精品在线| 在线a欧美视频| 久久国产精品久久国产精品| 丝袜美腿精品国产二区| 久久久精品视频成人| 久久精品国产一区二区三区| 色婷婷亚洲精品| 久久成人av少妇免费| 日韩国产一二三区| 中文字幕在线观| 永久久久久久| 亚洲人成电影网站色| 亚洲国产日韩欧美一区二区三区| 日韩av视屏| 精品国产一区二区三区日日嗨| 91精品国产综合久久精品图片| 久久综合中文| 成人黄色免费短视频| 可以在线看的av网站| 欧美成人精品一区| 国产精品久久免费看| 亚洲va久久久噜噜噜久久| 在线观看免费av网| 九九九九九九精品| 亚洲白拍色综合图区| 国产精品一区二区在线播放 | 欧美精品18+| 捆绑紧缚一区二区三区视频| 欧美暴力调教| 天天激情综合| 97超级碰碰| 亚洲国产三级网| 91在线精品一区二区| 女人av一区| 日本在线观看网站| 久久av喷吹av高潮av| 日韩在线视频网站| 一区二区三区蜜桃| 亚洲综合欧美| 午夜精品在线| 国产h在线观看| 亚洲精品天堂成人片av在线播放| 久久久久国产视频| 欧美性大战久久久久久久蜜臀| 国产精品1区二区.| 国产精品一在线观看| 超碰免费在线播放| 日韩视频免费在线播放| 成人久久18免费网站漫画| 亚洲视频电影图片偷拍一区| 亚洲男人的天堂av| 日韩av中文字幕一区二区| 精品一区二区三区亚洲| 国产小视频免费在线网址| 日韩网站在线免费观看| 国产精品一区av| 亚洲老头同性xxxxx| 亚洲精品日韩综合观看成人91| 丝袜美腿亚洲一区| 色综合www| 欧美私密网站| 91嫩草在线播放| 自拍视频一区二区三区| 国产精品中文字幕在线| 亚洲男人的天堂在线播放| 亚洲国产精品影院| 不卡视频一二三四| 国产亚洲亚洲| 人人狠狠综合久久亚洲婷| 成人黄色在线| 超碰最新在线| 成人动漫av| 国模无码视频一区二区三区|