范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文
国学影视

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

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

对话奇迹笨小孩主创书写人生奇迹,小人物也可以来源人民网原创稿新春将至,电影奇迹笨小孩的采访间里,窗花春联红灯笼中国结浓郁的年味扑面而来。但更引人注目的是其中的一张海报,众多角色簇拥一团,仰天欢呼,带着几分春节档阖家团聚的新年怪物男童被判定活不过3天,爷爷奶奶用爱创造奇迹姓名小奇(化名)年龄9岁地址山东省德州市平原县(图2021年12月,爷爷抱着小奇在屋外玩耍)小奇今年9岁了,患有先天性脑瘫的他就连外出玩耍也只能躺在爷爷的怀里。他刚生下来的时候医生贾凯里尼我永远不会征召巴洛特利,有很多意大利小将配得上机会直播吧1月27日讯前意大利国脚贾凯里尼最近接受了DAZN采访,他表示如果自己是意大利主帅,他永远也不会征召巴洛特利。巴洛特利最近重新入选了意大利训练营名单,引发了讨论。贾凯里尼说道12强赛,中国队02日本队,没有奇迹,国足众将评分主教练李霄鹏0分!赛前不管放出多少豪言壮语,不管表出何等决心,甚至拉出多达52人的队员名单和15人的教练组名单,但是带队踢的第一场比赛,说实在话,还不如李铁当时踢日本队的那场!42行走的柠檬意大利的柑橘园之旅行走的柠檬对意大利柑橘类水果的一次美妙探索。比威尔逊星期日泰晤士报年度图书行走的柠檬一书揭开了意大利园林历史的崭新篇章,娴熟地展现了从加尔达到巴勒莫的意大利柑橘文化。乔纳森基特斯泰董路李铁5后卫龟缩大法好,能创造奇迹!李霄鹏麾下4人0作用国足02日本!解说名嘴董路独家点评从场面来讲,输了两球就已经是不错的结果了。这场次比赛之前呢,看到很多媒体人或者是球迷,会对这场比赛充满信心,但这是盲目自信!其实有一个问题,就是当整个欧洲建筑史,都可以在波兰看得到,摸得着提到欧洲的建筑,你会联想到什么呢?富丽堂皇的宫殿?童话般的城堡?还是精致的宛如艺术品般的教堂?这些都是典型的欧洲建筑物,自从10世纪以来,这些不同的欧洲建筑风格全都可以在波兰找到。对话奇迹笨小孩主创书写人生奇迹,小人物也可以来源人民网原创稿新春将至,电影奇迹笨小孩的采访间里,窗花春联红灯笼中国结浓郁的年味扑面而来。但更引人注目的是其中的一张海报,众多角色簇拥一团,仰天欢呼,带着几分春节档阖家团聚的新年怪物男童被判定活不过3天,爷爷奶奶用爱创造奇迹姓名小奇(化名)年龄9岁地址山东省德州市平原县(图2021年12月,爷爷抱着小奇在屋外玩耍)小奇今年9岁了,患有先天性脑瘫的他就连外出玩耍也只能躺在爷爷的怀里。他刚生下来的时候医生贾凯里尼我永远不会征召巴洛特利,有很多意大利小将配得上机会直播吧1月27日讯前意大利国脚贾凯里尼最近接受了DAZN采访,他表示如果自己是意大利主帅,他永远也不会征召巴洛特利。巴洛特利最近重新入选了意大利训练营名单,引发了讨论。贾凯里尼说道12强赛,中国队02日本队,没有奇迹,国足众将评分主教练李霄鹏0分!赛前不管放出多少豪言壮语,不管表出何等决心,甚至拉出多达52人的队员名单和15人的教练组名单,但是带队踢的第一场比赛,说实在话,还不如李铁当时踢日本队的那场!42
布洛芬断货还有其他方案吗?我是一个坚定的开放支持者,早在今年三月份就为全家买了保险,并且预估一定会有全面放开的一天。因为这3年来,尤其是2022年以来随着全球中国以外的地区都放开,我们的制造业出现了大量的外梦是什么?梦就在路上你的梦想是什么呢?我的梦想是什么?每一个朴实的梦想织就了中国梦!你用什么托举中国梦?我用什么托举中国梦?这是每一个中国人必须回答和践行的现实问题,如果我们的舌尖上少浪费一粒粮食,如致敬每一份平凡岁月里的坚守365夜,清华陪你凌冬季候,风劲天寒生命的旅程或许坎坷总有理想激励着我们坚持向前目光坚定,山川温柔我们怀着不灭的信念迎接下一个黎明的到来跨越冰霜与风雪致敬每一份平凡岁月里的坚守12美文欣赏一缕冬阳几抹暖作者东方春晓昨夜的风,成就了冬日的气势。隔着密闭的窗幕,我仍能听见枯叶脱尽的枝头,那摇愰的呜咽。半夜醒来,严格地讲,是被大幅度骤降的气温冻醒,更加突兀的寒风拖着哨音,从房前廊角掠过南川率先推出冬季旅游产品发起川渝冰雪旅游联盟12月16日,2022重庆冬季旅游启动仪式暨第二十四届金佛山冰雪季开幕式举行。连日来,南川区从提升服务推动生产激发增强消费活力等方面着力,加快经济恢复提振,在全市率先推出以冬来金佛明股实债在司法会计税收领域的认定及冲突明股实债作为一种融资工具,也被称为带回购条款的股权性融资是指名义上以股权的形式向被投资企业投入资金获得股东身份,但实质上是于约定期限届满后或符合约定条件时收回本金和固定收益的投资模电商售后多年总结经验,7步攻略教会买家电保证不被坑本内容来源于什么值得买APP,观点仅代表作者本人作者江南俏才子写在前面临近年底,很多人都开始物色家电准备为家里添置添置,而根据今年在电视领域的摸爬滚打总结出的经验,购买电视有几大方截至目前,盘点2022年发布的曲面屏手机1三星GalaxyS22Ultra搭载全新一代骁龙8旗舰处理器,采用三星4nm制程工艺,图像处理能力AI性能等再次进化,拥有卓越的性能,但功耗也高,发热非常严重正面是一块6。8英寸千年游戏当怀旧成为潮流大家好,我是你们的小编幸川,今天就讲述看到很多人说什么怀念过去回到年之类的话,我真的感到很没语言在这里讲实在的有多少人是真正的怀念以前?都是极大的发挥了中国人的特色跟风大家总在说,MIUI14开发版12。8评测K50不好意思迟到了,说一声抱歉!进入正题,MIUI14第二版开发版已于这周五开始推送,经过2天的体验,我们来看看K50的具体更新信息以及游戏简单评测。这周的更新主要是修复上周出现的bu真假韩信之神终幕上演!韩枫最终落败!寂然守住韩信之神称号很多人都知道在虎牙直播平台拥有一位韩星绝活哥,他就是寂然。要知道寂然本人的年龄并不大,很多观众在私底下都称之为天赋少年。事实上,也确实是这样,寂然本人的韩信实力堪称天花板,最巅峰的