把公司内部服务通讯的 http 全改成了 grpc,看着连接数过山车式的下降,真舒坦

2020-01-07 20:04:45 +08:00
 itstudying

改之前内部服务的连接数比用户的连接数还多

14150 次点击
所在节点    程序员
59 条回复
lxd152
2020-01-07 20:12:43 +08:00
棒棒棒
optional
2020-01-07 20:14:18 +08:00
这 tps/qps 没变少吧,,只是 grpc 走了 http/2
0ZXYDDu796nVCFxq
2020-01-07 20:14:22 +08:00
有性能对比吗
TypeError
2020-01-07 20:19:05 +08:00
连接复用了?
meteor957
2020-01-07 20:25:40 +08:00
这也太夸张了吧
fox1955
2020-01-07 20:32:32 +08:00
经历过 http -> grpc. 性能的提升远不及联调开发效率的降低, 最后换回去了.
ofooo
2020-01-07 20:32:41 +08:00
不是只换了一种链接方式么? 通讯量应该一样才对吧?
dcalsky
2020-01-07 20:33:21 +08:00
各个服务之间共用 protoc 吗,protoc gen 等基础设施经验能分享一下吗?
diveIntoWork
2020-01-07 20:44:26 +08:00
改成 gRpc 后,不走 Http 协议了,统计出来的连接数当然变少了,要看 cpu 利用率、内存占用、吞吐才有意义
outoftimeerror
2020-01-07 20:48:20 +08:00
grpc 不也是基于 http2 吗
itstudying
2020-01-07 21:00:22 +08:00
@TypeError #4 是的 http2 的多路复用
itstudying
2020-01-07 21:05:26 +08:00
@ofooo #7
@diveIntoWork #9
是的 不过改造的目的就只是为了降低连接数,以及因为连接太多带来的内存占用大。监控平台中能最直观看出来改造前后区别的也就这个
itstudying
2020-01-07 21:15:24 +08:00
@outoftimeerror #10 是呀 只是因为 http2 支持多路复用,不搞连接池的话也就只有一个连接
luozic
2020-01-07 21:19:04 +08:00
这种得开发配套的工具链,否则出问题联调,apm 接入,debug 等等一堆的工具链需要开发配套,如过涉及到 cdn,网络硬件等更深远的坑,就等着哭吧。restful with http 主要是生态,别的东西有个 JB 生态
itstudying
2020-01-07 21:38:50 +08:00
@luozic 服务之间通讯使用 rpc 框架不是很正常的吗,grpc 虽然没 http 生态好但也是很成熟的了,也不至于差很多到了会踩很多深坑的地步。更不至于像你说的 JB 生态都没有
luozic
2020-01-07 22:03:08 +08:00
@itstudying 我的意思是边界约定好,大公司使用一部分特殊能性能的工具是他们能配套建立全链路的工具,小公司一般没有,而这种全链路的工具没听说过哪家开源的。rest 是因为文本的自然原因导致容易找到全链路的替代品。
luozic
2020-01-07 22:10:21 +08:00
最简单的 apm 用啥,API gateway 等最基础的服务治理有几个支持了,支持程度如何?
wangyzj
2020-01-07 23:19:31 +08:00
不喜欢 pb
都是 http2
会有很大变化吗
itstudying
2020-01-08 00:21:47 +08:00
@luozic grpc 也就是个 http2 也有 header,也有请求 path 多说无益…… 搜索引擎第一页就有结果
itstudying
2020-01-08 00:23:36 +08:00
@wangyzj 实际只是复用了连接,不想用 pb 不用就是~

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/635902

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX