go语言配合J***A,go语言 j***a

kodinid 19 0

大家好,今天小编关注到一个比较意思的话题,就是关于go语言配合java问题,于是小编就整理了1个相关介绍go语言配合Java的解答,让我们一起看看吧。

  1. 为什么许多原本的Java项目都试图用go进行重写开源?

什么许多原本的JAVA项目都试图用go进行重写?

国内不多,国外倒是不少公司会这么做,我司就这么做了,把之前部分微服务从J***a转为了Go,以及部分新的微服务也直接用Go开发

当时部门开会讨论,非中国人那波人认为Go语言执行非常快,效率得到很大提升;但中国人这波人认为是浪费时间,J***a性能也不差,而且学习成本低。

go语言配合JAVA,go语言 java-第1张图片-安济编程网
图片来源网络,侵删)

但拗不住外国人占主流,最后还是部分微服务***用了Go。根据目前使用来看,使用Go的微服务在性能上的提升并没有多明显(也许针对高并发会好一些),所以本人一直持保守意见,不过好在后来没有再要求把已开发的J***a服务代码改为Go了。

不过Go也有Go的好处,对于微服务,***用Go开发的话确实轻量化,代码量比J***a少,开发速度可以非常快,并且部署k8s也很简单,还可以方便的直接集成到云端(例如GCP的Cloud Function)。

很多j***a开发者应该听过当初j***a兴起时的一句宣传口号:“一次编译,到处运行”,但这个优势已经被容器大幅度地削弱,不再是大多数服务端开发者技术选型的主要考虑因素了。

go语言配合JAVA,go语言 java-第2张图片-安济编程网
(图片来源网络,侵删)

现在微服务盛行,对应用的容器化亲和性,譬如镜像体积、内存消耗、启动速度,以及达到最高性能的时间等方面提出了新的要求。

而j***a对云原生不友好,一个j***a应用的docker镜像几百兆,在k8s动态扩容时拉取镜像、启动容器比较耗时;而go应用镜像只有几十兆,相对来说启动速度快了很多,占用内存较小。

个人觉得应该是三个主要原因吧。

go语言配合JAVA,go语言 java-第3张图片-安济编程网
(图片来源网络,侵删)

一. 体积可以明显缩小,部署更简单

因为容器服务越来越主流,这到不是说J***a不能在云原生环境使用,现在云原生里的微服务模式,主流编程语言还是J***a,只是,依赖于JDK平台确实让容器镜像体积大了很多!大部分情况下,微服务本身jar的体积(包括各种依赖的flat jar)也与JDK本身的体积相差无几(甚至不及)。在多个服务情况下,拉取镜像的成本就高很多,虽然分层存储可以有效降低存储容量,但这也依赖所有微服务需要相同的镜像基座(部署好JDK),对于不同厂商的微应用(服务)情况不一定乐观。

Golang在这部分表现好很多,虽然打包后的Binary也不小(相比于C),但它包含运行时支持静态链接,非常独立(单体程序易于部署),体积相比J***a的服务,总体要小很多。

二. 开发难度不大

后端应用服务最重要的是稳定,J***a之所以能长时间占据后端开发市场份额,也是因为其异常及GC机制能够平衡好程序开发难度程序质量两个矛盾体。而Golang也引入了GC,开发难度也不高(并不比J***a难),不需要特别优秀的能力也能写出健壮的后端应用。

三. 语言发展的必然结果

现在越来越多的人开始使用Golang写后端应用。当你进入这个领域,你就会发现,你需要的各种框架基础设施基本上都是在重复写一遍其他已经进入该领域的语言的各种框架和基础库😄 这是工程本身决定的,到不一定是抄J***a。记得Nodejs刚出来的时候,借助于V8强大的性能,大前端的各种开发工具,框架如雨后春笋般发展起来,但也基本上是走了一遍其他语言(尤其是J***a)的路。

不同语言在发展过程中,总会进入其他“先入语言”的领域,然后也会再走一遍人家的路,完善和建立自身在该领域的生态。这是后发语言发展的必经之路!

到此,以上就是小编对于go语言配合J***A的问题就介绍到这了,希望介绍关于go语言配合J***A的1点解答对大家有用。

标签: JAVA 服务 语言