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

互联网公司理想架构的探讨

  本文探讨了互联网公司的技术架构,涉及DNS、负载均衡、长连接、API网关、PUSH推送、微服务、分布式事务以及相关支撑的基础服务。主要是为了学习,希望可以给大家一个参考。 整体架构
  APP、PC以及第三方等调用方通过传统的域名解析服务LocalDNS获取负载均衡器的IP,APP可以通过HttpDNS的方式来实现更实时和灵活精准的域名解析服务。
  通过负载均衡器到达统一接入层,统一接入层维护长连接 。
  API网关作为微服务的入口,负责协议转换、请求路由、认证鉴权、流量控制、数据缓存等。
  业务Server通过PUSH推送系统来实现对端的实时推送,如IM、通知等功能。
  业务Server之间通过专有的RPC协议实现相互调用,并通过NAT网关调用外部第三方服务。 域名解析传统DNS
  DNS(Domain Name System)域名系统,一种分布式网络目录服务,用于域名与IP地址的相互转换,能够使人更方便的访问互联网,而不用去记住机器的IP地址。
  DNS的解析过程如下:
  客户端递归查询LocalDNS(一般是ISP互联网服务提供商提供的边缘DNS服务器)获取IP LocalDNS迭代查询获取IP,即不断的获取域名服务器的地址进行查询 HttpDNS
  移动解析(HttpDNS)基于Http协议向DNS服务器发送域名解析请求,替代了基于DNS协议向运营商Local DNS发起解析请求的传统方式,可以避免Local DNS造成的域名劫持和跨网访问问题,解决移动互联网服务中域名解析异常带来的困扰。
  以腾讯云HttpDNS为参考,相较于传统LocalDNS的优势对比:
  优势
  腾讯云HttpDNS
  运营商LocalDNS
  高速
  接入节点覆盖国内Top17运营商、东南亚及北美,解析精准,访问迅速
  用户跨网访问、解析异常问题
  安全
  绕开运营商Local DNS,无劫持,防止DNS被污染拦截
  域名解析结果被指向广告页面、插入第三方广告
  智能
  精确识别来源请求,访问导向最准确节点
  自身不进行域名递归解析,而把请求转发给其他运营商
  可靠
  一个IP三地集群容灾,秒级自动故障切换,服务提供99%以上的SLA
  缓存服务器运维环境参差不齐,时有故障 负载均衡
  为了解决单台机器的性能问题以及单点问题,需要通过负载均衡将多台机器进行水平扩展,将请求流量分发到不同的服务器上面。
  客户端的流量首先会到达负载均衡服务器,由负载均衡服务器通过一定的调度算法将流量分发到不同的应用服务器上面,同时负载均衡服务器也会对应用服务器做周期性的健康检查,当发现故障节点时便动态的将节点从应用服务器集群中剔除,以此来保证应用的高可用。
  网络负载均衡主要有硬件与软件两种实现方式,主流负载均衡解决方案中,硬件厂商以F5为代表,软件主要为LVS、NGINX、HAProxy。
  技术原理上分为L4四层负载均衡和L7七层负载均衡。 L4 vs L7
  L4四层负载均衡工作于处于OSI模型的传输层,主要工作是转发。它在接收到客户端报文后,需要了解传输层的协议内容,根据预设的转发模式和调度算法将报文转发到应用服务器。以TCP为例,当一个TCP连接的初始SYN报文到达时,调度器就选择一台服务器,将报文转发给它。此后通过查发报文的IP和TCP报文头地址,保证此连接的后继报文被转发到该服务器。
  L7七层负载均衡工作在OSI模型的应用层,主要工作就是代理。七层负载均衡会与客户端建立一条完整的连接并将应用层的请求解析出来,再按照调度算法选择一个应用服务器,并与应用服务器建立另外一条连接将请求发送过去。 LVS转发模式
  LVS(IP负载均衡技术)工作在L4四层以下,转发模式有:DR模式、NAT模式、TUNNEL模式、FULL NAT模式。
  DR模式(直接路由)
  改写请求报文的MAC地址,将请求发送到真实服务器,而真实服务器将响应直接返回给客户。要求调度器与真实服务器都有一块网卡连在同一物理网段上,并且真实服务器需要配置VIP。
  NAT模式 (网络地址转换)
  调度器重写请求报文的目标地址,根据预设的调度算法,将请求分派给后端的真实服务器;真实服务器的响应报文通过调度器时,报文的源地址被重写,再返回给客户,完成整个负载调度过程。要求负载均衡需要以网关的形式存在于网络中。
  TUNNEL模式
  调度器把请求报文通过IP隧道转发至真实服务器,而真实服务器将响应直接返回给客户,所以调度器只处理请求报文。要求真实服务器支持隧道协议和配置VIP。
  FULL NAT模式
  在NAT模式的基础上做一次源地址转换(即SNAT),做SNAT的好处是可以让应答流量经过正常的三层路由回到负载均衡上,这样负载均衡就不需要以网关的形式存在于网络中了。性能要逊色于NAT模式,真实服务器会丢失客户端的真实IP地址。 调度算法
  轮询
  将外部请求按顺序轮流分配到集群中的真实服务器上,它均等地对待每一台服务器,而不管服务器上实际的连接数和系统负载。
  加权轮询
  权值越大分配到的访问概率越高,主要用于后端每台服务器性能不均衡的情况下,达到合理有效的地利用主机资源。
  最少连接
  将网络请求调度到已建立的链接数最少的服务器上。如果集群系统的真实服务器具有相近的系统性能,采用"最小连接"调度算法可以较好地均衡负载
  哈希
  将指定的Key的哈希值与服务器数目进行取模运算,获取要求的服务器的序号
  一致性哈希
  考虑到分布式系统每个节点都有可能失效,并且新的节点很可能动态的增加进来,一致性哈希可以保证当系统的节点数目发生变化时尽可能减少访问节点的移动。 API网关
  API网关(API Gateway)是一个服务器集群,对外的唯一入口。从面向对象设计的角度看,它与外观模式类似。API网关封装了系统内部架构,对外提供REST/HTTP的访问API。同时还具有其它非业务相关的职责,如身份验证、监控、负载均衡、缓存、流量控制等。 API管理
  API网关核心功能是 API 管理。提供 API 的完整生命周期管理,包括创建、维护、发布、运行、下线等基础功能;提供测试,预发布,发布等多种环境;提供版本管理,版本回滚。
  API配置包括 前端配置 和 后端配置 。前端配置指的是Http相关的配置,如HTTP 方法、URL路径,请求参数等。后端配置指的是微服务的相关配置,如服务名称、服务参数等。这样通过API配置,就完成了前端Http到后端微服务的转换。 全异步
  由于API网关主要处理的是网络I/O,那么通过非阻塞I/O以及I/O多路复用,就可以达到使用少量线程承载海量并发处理,避免线程上下文切换,大大增加系统吞吐量,减少机器成本。
  常用解决方案有 Tomcat/Jetty+NIO+servlet3.1 和 Netty+NIO,这里推荐Netty+NIO,能实现更高的吞吐量。Spring 5.0 推出的WebFlux反应式编程模型,特点是异步的、事件驱动的、非阻塞,内部就是基于Netty+NIO 或者 Servlet 3.1 Non-Blocking IO容器 实现的。 链式处理
  链式处理即通过责任链模式,基于 Filter 链的方式提供了网关基本的功能,例如:路由、协议转换、缓存、限流、监控、日志。也可以根据实际的业务需要进行扩展,但注意不要做耗时操作。
  Spring cloud gateway (基于 Spring WebFlux)的工作机制大体如下: Gateway 接收客户端请求。 客户端请求与路由信息进行匹配,匹配成功的才能够被发往相应的下游服务。 请求经过 Filter 过滤器链,执行 pre 处理逻辑,如修改请求头信息等。 请求被转发至下游服务并返回响应。 响应经过 Filter 过滤器链,执行 post 处理逻辑。 向客户端响应应答。 请求限流
  请求限流是在面对未知流量的情况下,防止系统被冲垮的最后一道有效的防线。可以针对集群、业务系统和具体API维度进行限流。
  具体实现可以分为集群版和单机版,区别就是集群版是使用后端统一缓存如Redis存储数据,但有一定的性能损耗;单机版则在本机内存中进行存储(推荐)。
  常用的限流算法:计数器、漏桶、令牌桶(推荐) 熔断降级
  服务熔断
  当下游的服务因为某种原因突然变得不可用或响应过慢,上游服务为了保证自己整体服务的可用性,不再继续调用目标服务,直接返回,快速释放资源。如果目标服务情况好转则恢复调用。
  熔断是为了解决服务雪崩,特别是在微服务体系下,通常在框架层面进行处理。内部机制采用的是断路器模式,其内部状态转换图如下:
  服务降级
  当负荷超出系统整体负载承受能力时,为了保证核心服务的可用,通常可以对非核心服务进行降级,如果返回缓存内容或者直接返回。
  服务降级的粒度可以是API维度、功能维度、甚至是系统维度,但是都需要事前进行服务级别的梳理和定义。
  真实场景下,通常是在服务器负载超出阈值报警之后,管理员决定是扩容还是降级。 业务隔离
  API网关统一了非业务层面的处理,但如果有业务处理的逻辑,不同业务之间就可能会相互影响。要进行业务系统的隔离,通常可以采用线程池隔离和集群隔离,但对于Java而言,线程是比较重的资源,推荐使用集群隔离。 PUSH推送
  消息推送系统 针对不同的场景推出多种推送类型,满足用户的个性化推送需求,并集成了苹果、华为、小米、FCM 等厂商渠道的推送功能,在提供控制台快速推送能力的同时,也提供了服务端接入方案,方便用户快速集成移动终端推送功能,与用户保持互动,从而有效地提高用户留存率,提升用户体验。
  设备建连、注册、绑定用户流程
  消息推送过程
  在非常多的业务场景中,当业务发生时用户未必在线,也未必有网络。因此,在 MPS 中所有消息均会被持久化。业务发生时,MPS 会尝试做一次推送(第三方渠道推送或自建的TCP 连接推送)。自建渠道中,会通过查询缓存来判断用户的终端是否有 TCP 连接,如果存在则推送,客户端收到推送消息后,会给服务端回执,服务端即可更新消息状态。如果推送失败,或者回执丢失,用户在下一次建立连接时,会重新接受消息通知,同时客户端会进行逻辑去重。 微服务体系
  转载地址:https://mp.weixin.qq.com/s/fqPLVZkAhyjAlXqLeXh7Ow
  转载公众号:架构文摘

魔兽争霸3年度人气战术盘点之制霸路人与比赛的人族双防流一晃眼,还有几天时间2021年黄金联赛总决赛就要开始了,这也意味着2021年也即将结束。接下来的时间里,我们就来盘点一下,在即将完全过去的2021年中,那些备受玩家欢迎的战术思路。战地2042官推发概念图遭网友无情打脸战地官推发布了战地2042的概念图,展示了一个战斗机械狗(游戏中叫游侠)原型。官推表示,在战地2042的世界中,首个支持战斗的机器狗原型是在2030年,在会跑之前先学会步行。在战地DNF春节套开始预热,如何做到8折买年套?回收代币券很关键22年春节套估计将在1。20版本上线,时间还比较长,不过在此之前,聪明的老玩家已经开始行动起来了,用代币券买年套,会便宜很多。不过如何回收代币券何时出售入手同样是个问题,这里咱们就魔兽TBC怀旧服迎来新魔改,1件强力饰品被削弱,近战崛起成空谈魔兽世界TBC版本怀旧服近战职业之所以低迷,除了自身的职业机制之外,最重要的原因是TBC版本没有了世界BUFF的加成。为了能够重现60级的辉煌,近战玩家们也在不断寻找新的强力BUF帕斯卡契约评测优秀的国产魂like手游自10年前黑暗之魂横空出世以来,魂系游戏就成了硬核和受苦的象征。经过了这么多年的发展,魂系游戏也逐渐壮大,出现了如血源诅咒只狼等优秀的魂like游戏。下面要给大家介绍的这款魂lik明日方舟新年保底卡池出货率详解新博士福音老博士人手一只瑕光明日方舟对于这次期待已久的跨年欢庆系列的相关主题限定卡池,估计不少玩家已经迫不及待了,等到元旦当天终于正式开启了,玩家自然也是积极的第一时间投入去抽卡,对于这次卡池的具体出货率还有三国志战略版最能打的PVP神将,这五位武将上榜前言本文首发三国志战略版配将君的公众号,未授权禁止抄袭文章到其他平台。作者三国志战略版配将君大家好,我是三战配将君,每天帮配将开荒,和你说求贤令的武将选择,希望能帮到你!三国志战略王者荣耀知己知彼我都是经常看主播玩王者局巅峰赛,意识自然而然就跟上他们了,不知不觉我就学到了很多东西,变强了。所以虽然我是钻石段位,可我的意识已经达到了王者,打钻石局上分,那就很简单了。因为意识已原神凝光与神里的大招输出差距有多大?凝光在2。4版本下有新衣服穿了,相信不少玩家手上都会有这角色,也有玩家准备拉起这个角色,在当下凝光当主c去通关12层深渊能过吗?,答案是可以,本人实测凝光钟离香班尼特这个队伍是可在EPIC刚刚赠送的古墓丽影崛起游戏如何?古墓丽影崛起好玩吗?今天,小编为大家带来了E宝刚刚赠送的古墓丽影崛起画面和游戏玩法体验。对场景的详细描述很到位,无论是叙利亚,滚滚的尘浪,西伯利亚,漫天的风雪,被岁月侵蚀的古遗址,永恒沉默天影传奇天影沉默2打金小攻略(二)大家好!今天继续给大家带来天影沉默2打金小攻略的下半部分。效率最高的开区充400米直升四转,这个赞助也是大多数玩家的选择,这时候就可以进入第二大陆,越快进入第二大陆,你获得的装备和
梦幻西游网页版共闯龙潭玩法高分技巧,好玩到停不下来(上)今天,来聊聊骨妹这几天玩了梦幻西游网页版葫芦兄弟联动活动共闯龙潭玩法的总结体验。整体来看,要想高分入榜,运气最重要。但运气这东西,无法掌控,骨妹就从其他可以掌控的细节入手,先从基础沉默单职业神器怎么玩,装备搭配详细攻略,这样搭配能恶心死敌人热血经典丶传奇不止。神机今天接着上期咱们说沉默单职业版本的神器装备到底该怎么搭配,小白玩家也能跟土豪玩家一站到底。首先沉默单职业的神器分为两种,一种是较为稀有的神器装备一种是普通玩星际贸易前沿单机手游版,贸易战争类游戏,可选角色多达33种感谢您阅读我们的文章,喜欢的请关注我们,每天为您酿造经典好游戏!各位朋友大家好!今天小编为大家推荐一款好玩的单机手游星际贸易前沿,一款结合了贸易,战争,经营等游戏元素融为一体的手游王者荣耀吕布咋出装啊,我看有些主播基本上都是全攻击,有点脆吧?你好,很高兴回答你的问题。在王者荣耀里,吕布一直是一个很强的边路。他强就强在他的二技能加护盾,而且有真伤。绝对是后期坦克的克星。下面我来说一下吕布的出装以及铭文。这是我的一种出装。3亿鼠标的梦想高清重制!这就是力压光环的护航游戏?点击右上方关注,第一时间获取科技资讯技能攻略产品体验,私信我回复01,送你一份玩机技能大礼包。相信不少玩家即使没玩过,但也听过这款游戏的大名,它号称是3亿人的鼠标梦想,风靡各大网吧张艺兴一直想要的十三是什么?谁能想到是梦幻手游里的宠物就在前几天,张艺兴在向往的生活中提到自己希望给孩子取名为张十二。随即又改口叫张十三。这下可好,弹幕里一下子炸出不少梦幻西游手游玩家。原来,张艺兴本人就是个资深的梦幻西游手游玩家。在铁甲神盾贾克斯不死武神完克天使云顶之弈11。10版本中武器成为了最大赢家,控制型阵容的减少变相的为站桩武器提供了足够多的输出机会。在这种情况下,神盾武器也成为了T0级别的版本之子,强度甚至强于骑士天使。版本分析DNF都说海博伦升级泰波尔斯伤害会提高15,但是为什么很多人不建议升级呢?地下城在更新了全新的95级版本之后,泰波尔斯装备就成为了广大玩家追求的首选。但是对于平民玩家来说,个人并不建议先升级泰波尔斯特殊装备,而是先升级防具,然后升级特殊装备,最后首饰。首魔兽世界60年代狂暴T是什么?狂暴战还可以当坦克吗?相信很多魔兽世界玩家都知道,60年代唯一的MT就是战士,大多数情况下战士都是用防御天赋来拉怪的,只有极少情况下会遇到使用狂暴战拉怪(当然五人本你爱有什么用什么,这里单指团本)。不过兰陵王打仗为什么要带面具?兰陵王,高长恭,又名高孝瓘,面具下的悲情王子。北齐第二代皇帝文襄皇帝高澄的第四子,至于他的母亲,却没人知晓,这让他的身世多了神秘感。又因他屡立战功被封为巨鹿郡长乐郡乐平了郡高阳郡公云顶之弈11。10版本强势阵容排名强势阵容哪个厉害云顶之弈S5赛季11。10版本已经过去了两周,在更新到来之前有哪些强势阵容可以上分呢,下面请看云顶之弈11。10版本强势阵容排行,希望能够帮助大家。艾欧尼亚顶级玩家阵容统计本次摩昂
友情链接:快好知快生活快百科快传网中准网文好找聚热点快软件