专栏电商日志财经减肥爱情
投稿投诉
爱情常识
搭配分娩
减肥两性
孕期塑形
财经教案
论文美文
日志体育
养生学堂
电商科学
头戴业界
专栏星座
用品音乐

微服务框架的实现舍与不舍

  生活中充满了各种tradeoff(权衡),编程开发中也是如此。本文将通过实战的角度,分享在开发微服务框架的过程中,针对不同的组件做的一些抉择,包括,协议支持的多少?数据传输采用TCP还是UDP?网络处理是普通处理模型还是定制的epoll?序列化框架那么多,该用哪种?注册中心选哪家?路由方式哪种好,如何限流等等。
  资深工程师晁岳攀(鸟窝)
  嘉宾介绍:Go微服务框架rpcx的作者,拥有20余年的软件开发经验,先后在清华同方、Motorola、微博等公司工作,出版了国内第一本原创Scala图书《Scala集合技术手册》,并在台湾发行了繁体版。Go语言的布道者,在GopherChinameetupGopherChina大会上分享过《Go微服务框架实践》、《Go并发编程》等主题。
  以下是晁岳攀老师在SACC2022大会的演讲实录:
  rpcx微服务框架协议的实现
  事实上,每个拥有一定规模的互联网大厂都有自己的微服务框架。比如,阿里巴巴、哔哩哔哩、百度、今日头条、学而思、好未来等。因为业务繁多需要微服务来划分,中间的调用关系必须通过框架来实现。
  框架独有接口(rpcx)
  如上图所示,采用压缩的方式来实现。第一个是Magicnumber(魔法数字),使用特殊的字节(0x08)来标明Request开头。第二个是Version(版本号),在做微服务设计的时候,要尽量做到协议的兼容性。
  后面几个字节,比如MessageType、Heartbeat、Oneway、CompressType、MessageStatusType、SerializeType、Reserred,使用bit做设置,将其压缩在一起,尽量减少内存的占用。
  接下来,MessageID使用了8个字节的数据。最后是sizeofrestdata,sizeofserricePath,sizeofserriceMethod,sizeofmeta,sizeofpayload等数据的处理。
  框架独有接口(dubbo)
  dubbo的处理方式与rpcx是类似的,它使用两个字节做魔法数,分别是高位和低位。后面是标记它的请求响应、需要往返、事件、序列化ID、状态、RPC请求ID等信息,接下来是消息体数据长度。
  框架独有接口(motan)
  motan的协议设计与rpcx是类似的。grpc是架构在HTTP2。0基础之上的协议,它的请求是RequestHeaders,加一系列的Message。对于请求,EOS(流结束)是通过在最后接收到的数据帧上出现ENDSTREAM标志来表示的。
  ResponseHeaders和TrailersOnly都在单个HTTP2报头帧块中传递。对于响应,流的结束是通过在最后一个接收到的带有Trailers的报头帧上的ENDSTREAM标志来指示的。
  thrift框架中的message表示一次接口调用、接口调用结果或者异常。这个函数中主要是调用相应的write函数来序列和写入thrift的版本、message的name以及seqid等基本信息,name字段是函数的名字。
  如果使用通用的请求,常用的协议有HTTPaccess、RestfulAPI、JSONRPC2。0、WebSocket等。JSONRPC是一个无状态且轻量级的远程过程调用(RPC)协议。从性能的角度来考虑,实现特定的协议是比较常用的一种手段。数据传输
  在协议实现之后,客户端通过哪种传输方式把消息传输给服务端,服务端又通过什么方式将消息返还给客户端。常见的数据传输方式有几种,比如HTTP、TCP、UDP、Unixdomainsocket等。如果想要实现更高性能网络,我们可以在特定网络协议基础之上做数据传输。
  HTTP1。1vsHTTPpipelining
  HTTP1。0的每一次请求都伴随着一次三次握手的过程,并且是串行的请求,增加了不必要的性能开销。HTTP1。1新增了长链接的通讯方式,减少了性能损耗。HTTPPipelining是把多个HTTP请求放到一个TCP连接中一一发送,而在发送过程中不需要等待服务器对前一个请求的响应。
  HTTP1。1vsHTTP2。0vsHTTP3。0
  HTTP1。1安全性不足和性能不高;HTTP2。0完全兼容HTTP1。0,是更安全的HTTP,更快的HTTPS,头部压缩,多路复用等技术充分利用了带宽,降低了延迟。HTTP3。0的底层支撑协议QUIC基于UDP实现,又含TCP的特点,实现了又快又可靠的协议。
  rawTCP
  TCP提供了一个逻辑上的连接,在进行数据传输之前必须建立连接,在数据传输之后必须终止连接。TCP为了保证数据的可靠性,要求有应答机制,应答机制实际上是通过一个基本的序列号和相对应的回应号来进行完成的。TCP本质上是一种面向连接的、非常可靠的数据传输方式,是基于IP协议来做的。
  KCP是一个基于UDP实现快速、可靠、向前纠错的的协议,能以比TCP浪费1020的带宽的代价,换取平均延迟降低3040,且最大延迟降低三倍的传输效果。纯算法实现,并不负责底层协议(如UDP)的收发。
  kcpgo是用go实现了KCP协议的一个库,其实KCP类似TCP,协议的实现也很多参考TCP协议的实现,滑动窗口,快速重传,选择性重传,慢启动等。KCP和TCP一样,也分客户端和监听端。
  Unixdomainsocket又叫IPC(interprocesscommunication进程间通信)socket,用于实现同一主机上的进程间通信。它有SOKCETDGRAM(数据包套接字)和SOCKETSTREAM(流套接字)两种模式,类似于UDP和TCP,但是面向消息的UNIXsocket也是可靠的,消息既不会丢失也不会顺序错乱。网络处理库
  Go基于IOmultiplexing和goroutine构建了一个简洁而高性能的原生网络模型(基于Go的IO多路复用netpoll),提供了goroutineperconnection这样简单的网络编程模式。
  connectionpergoroutine
  虽然goroutine是轻量级的,但也并非创建的越多越好。其中有几个原因,goroutine只负责消息读取解析,当它的数量较大时,会占用很大的内存,消耗大量的CPU资源。
  workerpool是一个Erlang进程池,其中的工作进程是Erlang的genserver模式进程。工作中常用workerpool模式,可以控制goroutine的数量,防止goroutine泄露和暴涨。
  Netpoll是一款Go语言高性能、IO非阻塞(NIO)网络库,专注于RPC场景。由于EpollWait回调之后,SubReactor内是串行处理IO事件的,导致排在最后的事件可能会有长尾问题。序列化方式
  编解码主要有通用跨平台和专有高性能两种方式,通用跨语言库有Protobuf、MessagePack、JSON(标准库JSON、jsoniteratorgo、easyjson等)、XML、Thrift。特定语言的编解码方式有Hessian2、andyleapgencode、colfer、zebrapack。
  序列化方式
  上图参考https:github。comsmallnestgosercomp,我们可以看出,各个序列化方式Marshal与Unmarshal的数据。我们不要把自己的平台限制在某一种序列化方式,而是应该支持定制化,将决定权交给用户。注册中心
  在微服务框架之下,我们要引入注册中心,它是微服务框架依赖的一个基础服务。常见的注册中心有分布式一致性的平台,比如zookeeper(CP)、etcd(CP)、consul(CP)、Eureka(AP)。
  分布式一致性
  分布式注册中心遵循CAP原理,指的是在一个分布式系统中,Consistency(一致性)、Availability(可用性)、PartitionTolerance(分区容错性),三者无法同时满足。
  当满足CA时,要保持数据一致性,就必须进行节点数据的同步;同时要满足可用性,则响应时间必须较短,就要去数据同步时间很短,这样就不能部署太多的节点,也就无法满则高可用性。
  当CP满足时,要进行数据同步,且机器数量较多,这样数据的同步时间就会比较长,无法保证较快的响应。当满足AP时,既要有一定机器数量,又要保证较快的响应时间,就无法进行节点数据的同步。
  国内互联网大厂一般自研注册中心,实现AP系统,来保证可用性。比如,阿里nacos、微博vintage、腾讯PolarisMesh。那么,中小企业如何选择注册中心?可以选择etc,consul,做好zk本地缓存的功能;使用dns、redis、mysql等云服务;采用大厂的AP系统。路由选择
  最简单的方式是利用随机函数选择节点,有无法区分权重;无法根据性能实时调整;无法进行复杂情况下的选择;随机不随机,比如可能出现111112222233333的情况等问题。
  利用轮询的方式选择节点,每个节点可以均匀,压力也平均,但面临无法区分权重;无法根据性能实时调整;无法进行复杂情况下的选择等问题。
  基于权重的随机算法
  基于权重,可以避免随机算法可能的压力集中。Nginx的算法可以平均生成每个节点:smoothweightedroundrobinbalancingalgorithm。
  基于请求的服务和方法,以及请求参数,利用一致性哈希算法,总是选择固定的节点,动态调整节点。
  网络质量优先,client定期测试各节点的网络质量,根据网络质量分配权重。地理位置优先,同机房优先,同区域优先,国内优先。
  基于特殊的需求,允许用户定制,比如正常调用同机房优先;如果失败,第二次从备份机房调用。限流与降级
  降级是临时禁用非核心功能,比如明星出轨、结婚离婚等重大公共事件,秒杀、抢红包等流量激增的时候,功能屏蔽但是不下线。
  限流是客户端和服务端限流,从根上限制,避免无意义的带宽传输;无法避免业务偷偷放量;基于令牌桶和漏桶,需要处理burst场景。测试
  rpc测试的困难,需要客户端和服务端才能真正模拟,持续集成框架机器可能不允许网络连接,配置服务端和客户端略微复杂。网络传输单独测试,客户端和服务端业务测试时使用mock。虚假连接,把客户端请求直接给服务端处理,把客户端请求直接给服务端处理github。comakutzmemconn。

诗歌原创你不解的风情,我写给你啊捣云立秋之前,我要生一场病缱绻的那种,介于既得与错失之间你要加紧替我治疗摘一些天边的云,昙花和马蹄草还要一串羞涩的野葡萄在黄昏的衣钵里,细细地捣碎月老屋东头,柚子树旁,有一湾鱼塘无人生,吃苦是磨炼,吃亏是福气人需要吃饭喝水,这是人的物质和生存需求人也需要吃苦吃亏,这是人的精神内在需求,也是人的本领素质需求,人是高级动物,人与动物的区别就在一个吃字上,人除了吃饭外还能够吃苦和吃亏,能够吃月色下的母亲河刘新华(北京)月色下的母亲河刘新华(北京)风起天际,犹如脱缰的野马呼啸掠过,打破沉寂的夜色沿月光映照的方向,开始搜寻搜寻那首黄土高坡,或青藏高原歌声唱响黄河长江浩荡的乡愁随蜿蜒的河水东流在祖国的小王子看东西只有用心才能看得清楚有些人有些书是你生命中注定要遇见的,躲不过绕不开,小王子就是这样的一个人一本书。再读小王子,深深地懂得生有涯而知无涯,未知永远多于已知,当我们自我感觉懂得越多时,越会发现自己的渺小放假通知!今早热搜霸屏,网友关注点都在它今早国庆放假安排冲上微博热搜第一阅读量超3亿据央视新闻,国务院办公厅发布2022年国庆节放假安排通知如下10月1日至7日放假调休,共7天10月8日(星期六)10月9日(星期日)上班珠江公园现鱼跃莲花引游客追拍鱼跃青池满,莺吟绿树低近日,唐代诗人李白作品晓晴中描写的情景出现在了广州珠江公园。莲花池边聚满众多摄影爱护者,争相抓拍鱼跃莲花的有趣现象。衔荷花花瓣最初可能只是鱼儿改善伙食的尝试,iPhone14将是印度越南出品?不再是国产的苹果,你还会喜欢吗?每年9月份,基本上都是各大手机厂商出新手机的时候,比如苹果,今年又是新的手机即将面世的时候,而对于很多果粉来说,那必须是1年1买的。但是,今年的情形又有些不一样了,到底哪里不一样呢低调的汕头富豪周奕丰22岁创业,44岁公司上市,如今身家130亿周奕丰01周奕丰,1969年5月出生在广东汕头,从澳门公开大学工商管理专业毕业后,来到广州市成禧经济发展有限公司工作。成禧公司的前身是成立于1979年的峡山塑料工艺厂,1987年工我喜欢你,一直都是好巧,我也是(已完结)想到了当年被我抛弃的学霸。我舔着脸上门了,那什么,辅导作业,被气得心梗的事儿考虑一下吗?呜呜,我被幼儿园卷麻了。专业的事儿得找孩子爹来办。1hr我是个一生要强的单亲妈妈,我努力赚钱500个品牌案例TheRow低调的极简轻奢品牌编辑安琪品牌名称TheRow成立时间2006年创始人Olsen姐妹总部地点美国纽约品牌理念量身定做的服装品牌故事TheRow背后的两位创始人MaryKateOlsen和Ashley酒馆战棋盘点那些酒馆消失的强力随从,有你喜欢的吗1漂浮观察者俗称小绿,和愤怒编织者小粉搭配养成很快,前期能拿到基本烂分就稳了。2族群领袖俗称狼爹,曾经传统野兽展开流的前中期核心,配上鼠群瞬间锁血。不过可惜本身不是野兽属性不能被B
猎头给出年薪23万的待遇,我是否应该放弃现在工作?谢邀请回答。现在的工作年收入,有12万元。每月1万,在二,三线城市工作能有这么高的薪酬,还是很可观的,应该感到滿意。但有朋友突然要聘请你到他那里去。并承诺年收入23万元,接近是现有在农村供一个大学生已经很吃力了,现在大学毕业工作半年了,孩子想考研,家里该不该支持?先说孩子的客观情况,大学毕业工作半年,他想考研,说明他已经经历了一段时间的社会磨练,已经清楚在社会上打拼不易,或者说看明白了学历在就业过程中的重要性,所以他才会有想考研的想法,目的单位领导聚餐时,如果领导安排你倒茶递水,这意味着什么?呵呵,看来不少人真还不懂职场中的规矩,也有不少回答者只是站在自己的主观立场来进行猜测而已,很多时候都没有讲到位,说清楚道明白!那究竟是怎么回事呢?一通常来说单位领导聚餐,是不会喊普怎么做一个管理者和怎么成为一个管理者?如何成为一个优秀的管理者?成为一个优秀的管理者,要具备相应的素质,下面的我一条一条地为大家分析,大家可以自己对照一下,有哪些有哪些是你缺少的素质?缺什么补什么。1坚定目标和方向。目应届毕业生,月薪5000每天工作8小时,每周双休的要求过分吗?对于应届毕业生而言,希望能够得到这样的待遇完全合情合理,这一点必须要承认。在此前提之下更需要面对现实,这才是最理性的求职之道。针对此问题,老鬼和朋友们系统的分享一些有关求职的实战性从摄影专业角度分析,街拍是专业摄影吗?从专业的角度来看,街拍也是一种艺术创作。但是这种创作从诞生以来就饱受争议的是关于侵权与街拍如何权衡的问题。街拍,是一种源于时尚杂志需求与传递大众时尚元素的街头文化活动。现在多指国内想入手一辆摩托车,价格不超过3万元,有什么推荐?没有看到您对用途的描述,是城市通勤?还是长短途摩旅?还是喜欢操控追求动力?但是3万级的摩托车,性能都不是非常出色,多数为250cc300cc之间,这个价位介于国产车和合资车之间,甚雷克萨斯属于哪个档次,与奥迪凯迪拉克相比呢?Lexus(雷克萨斯)刚进入中国市场的时候名为凌志,最早也是最普及的车型应该就是LS400了,当时这款车也是不多见配备V型排列8缸(V8)发动机的豪华车,四挡自动变速箱空气悬架(可餐饮行业不好做,有建议改行做什么好?其实哪个行业好不好做,就要看你自己了我就是做餐饮的,一年收入还可以吧,做事情得做精餐饮在很多方面是一款暴利的行业,就看你能不能把他做精,大家看一下,我下面的一篇文章大家好,今天我们贵州六盘水哪个旅游景点比较好玩呢?素有中国凉都之称的贵州省六盘水市,风光秀美,气候宜人,夏季平均气温仅19。7度,曾连续多次入选国家避暑旅游城市榜,如果您打算前往六盘水旅游,以下景点最值得推荐乌蒙山国家地质公园地处地球为什么会随着太阳旋转,而不会因为太阳的引力落入太阳呢?首先谢邀!地球围绕太阳转,是由于太阳与地球之间的万有引力和地球运动产生的离心力达到平衡,才能保证地球围绕太阳转。如果太阳与地球之间的距离发生改变,有二种情况,第一,如果太阳与地球之
友情链接:快好找快生活快百科快传网中准网文好找聚热点快软网