当前位置: 首页 > news >正文

政府部门网站建设方案好消息tvapp电视版

政府部门网站建设方案,好消息tvapp电视版,怎样创建个人销售网站,南通做电力的公司网站概述 从0研究一下Golang已经Golang的微服务生态体系,Golang的微服务首先要从Rpc开始,在升级到Grpc,详细介绍这些技术点都在解决什么技术问题。 Rpc Rpc (Remote Procedure Call) 远程过程调用,简单的理解是一个节点请求另一个节…

概述

从0研究一下Golang已经Golang的微服务生态体系,Golang的微服务首先要从Rpc开始,在升级到Grpc,详细介绍这些技术点都在解决什么技术问题。

Rpc

  • Rpc (Remote Procedure Call) 远程过程调用,简单的理解是一个节点请求另一个节点提供的服务。
  • 对应Rpc的是本地过程调用,函数调用时最常见的本地过程调用。
  • 将本地过程调用变成远程过程调用会面临各种问题。

远程调用过程面临的问题?

1.Call ID映射。

我们怎么告诉远程机器我们要调用的函数ID呢?再本地调用中,函数体是直接通过指针来指定的,我们调用function,编译器就自动帮我们调用它相应的函数指针。

但是在远程调用中,函数指针是不行的,因为两个进程的地址空间是完全不一样的。所以,再RPC中,所有的函数都必须有自己的一个ID。这个ID在所有的进程中都是唯一确定的。客户端在做远程调用时,必须附上这个ID。然后还需要再客户端和服务端分别维护一个{函数 <–> Call ID}的对应表。两者的表不一定需要完全相同,但相同函数对应的Call ID必须相同。

当客户端需要进行远程调用时,它就查一下这个表,找出相应的Call ID,然后把它传给服务端,服务端也通过查表,来确定客户端需要调用的函数,然后执行相应的函数的代码。

2.序列化和反序列化

客户端怎么把参数值传给远程函数呢?在本地调用中,我们只需要把参数压到栈里,然后让函数自己去栈里读就行。但是在远程过程调用时,客户端跟服务端是不同的进程,不能通过内存来传递参数。甚至有时候客户端和服务端使用的不是同一种编程语言,这时候就需要客户端和服务端把参数先转成一个字节流,传给服务端后再把字节流转成自己能读懂的格式,这个过程叫做序列化和反序列化。

3.网络传输

远程调用往往用在网络上,客户端和服务端是通过网络连接的。所有的数据都需要通过网络传输,因此就需要一个网络传输层。网络传输层需要把Call ID和序列化后的参数字节流传给服务端,然后在把序列化后的调用结果返回客户端,只要能完成这两者的,都可以作为传输层使用。

因此,它所使用的协议其实是不限的,能完成传输就行。尽管大部分Rpc框架都使用Tcp协议,但其实Udp也可以,gRPC干脆使用了Http2。

Rpc框架需要解决哪些问题

在这里插入图片描述

Client端要解决的问题:

1.将这个调用映射为Call ID,这里假设用最简单的字符串当Call ID的方法
2.将Call ID a和b序列化,可以直接将他们的值以二进制形式打包
3.把2中得到的数据包发送给ServerAddr,这需要网络传输层
4.等待服务器返回结果
5.如果服务器调用成功,那么被结果反序列化,并献给total

Server端解决的问题:

1.在本地维护一个Call ID到函数指针的映射call_id_map,可以用dict完成
2.等待请求,包括多线程的并发处理能力
3.得到一个请求后,将其数据包反序列化,得到Call ID
4.通过在call_id_map中查找,得到相应的函数指针
5.将aherb反序列化后,本地调用add函数,得到结果
6.将结果序列化后通过网络返回给Client

在上面的整个流程中,估计有部分同学看到了熟悉的计算机网络的流程和web服务器的定义,所以要实现一个Rpc框架,其实只需要按以上流程实现就基本完成了。

其中:

  • Call ID映射可以直接使用函数字符串,也可以使用整数ID,映射表一般就是一个哈希表。
  • 序列化和反序列化可以自己写,也可以使用Protobuf或者FlatBuffers之类的。
  • 网络传输库可以自己写socket,或者用asio,ZeroMQ,Netty之类。

文章转载自:
http://spig.sLnz.cn
http://preludious.sLnz.cn
http://brcs.sLnz.cn
http://bsd.sLnz.cn
http://unliveable.sLnz.cn
http://urokinase.sLnz.cn
http://appendix.sLnz.cn
http://laager.sLnz.cn
http://wa.sLnz.cn
http://interrogator.sLnz.cn
http://peroneal.sLnz.cn
http://coachfellow.sLnz.cn
http://woolgrower.sLnz.cn
http://ekalead.sLnz.cn
http://shalt.sLnz.cn
http://inearth.sLnz.cn
http://goalkeeper.sLnz.cn
http://egger.sLnz.cn
http://novennial.sLnz.cn
http://pneumobacillus.sLnz.cn
http://narratology.sLnz.cn
http://dullsville.sLnz.cn
http://crenellation.sLnz.cn
http://rage.sLnz.cn
http://waddle.sLnz.cn
http://too.sLnz.cn
http://gondwanian.sLnz.cn
http://subcuticular.sLnz.cn
http://disgregate.sLnz.cn
http://nationwide.sLnz.cn
http://asthenope.sLnz.cn
http://enclose.sLnz.cn
http://frigidaria.sLnz.cn
http://seedleaf.sLnz.cn
http://experimentalism.sLnz.cn
http://botel.sLnz.cn
http://mayo.sLnz.cn
http://ornamentation.sLnz.cn
http://filigree.sLnz.cn
http://eradiation.sLnz.cn
http://carabin.sLnz.cn
http://pseudopregnancy.sLnz.cn
http://totem.sLnz.cn
http://ambury.sLnz.cn
http://jaspilite.sLnz.cn
http://hypnosophy.sLnz.cn
http://gloat.sLnz.cn
http://reprovision.sLnz.cn
http://stopwatch.sLnz.cn
http://soutane.sLnz.cn
http://toupee.sLnz.cn
http://samos.sLnz.cn
http://salvor.sLnz.cn
http://corresponding.sLnz.cn
http://cubage.sLnz.cn
http://triennial.sLnz.cn
http://togavirus.sLnz.cn
http://cainozoic.sLnz.cn
http://redder.sLnz.cn
http://desmitis.sLnz.cn
http://lithotrity.sLnz.cn
http://distraite.sLnz.cn
http://halve.sLnz.cn
http://parvitude.sLnz.cn
http://triassic.sLnz.cn
http://polliwog.sLnz.cn
http://clicker.sLnz.cn
http://harl.sLnz.cn
http://hydrocellulose.sLnz.cn
http://changsha.sLnz.cn
http://lineman.sLnz.cn
http://flapjack.sLnz.cn
http://calorize.sLnz.cn
http://linchpin.sLnz.cn
http://escopeta.sLnz.cn
http://homology.sLnz.cn
http://tibiofibula.sLnz.cn
http://caterpillar.sLnz.cn
http://rendezvous.sLnz.cn
http://rubricate.sLnz.cn
http://dictatorial.sLnz.cn
http://simulation.sLnz.cn
http://parvitude.sLnz.cn
http://bewilder.sLnz.cn
http://tomfool.sLnz.cn
http://indianness.sLnz.cn
http://dangly.sLnz.cn
http://calcify.sLnz.cn
http://trucking.sLnz.cn
http://chaffcutter.sLnz.cn
http://concretist.sLnz.cn
http://sodomist.sLnz.cn
http://athanasian.sLnz.cn
http://eurocheque.sLnz.cn
http://lashings.sLnz.cn
http://hassock.sLnz.cn
http://secretiveness.sLnz.cn
http://sanguine.sLnz.cn
http://latifundio.sLnz.cn
http://laughable.sLnz.cn
http://www.hrbkazy.com/news/66689.html

相关文章:

  • 网站制作在哪里比较好如何制作企业网站
  • 东莞网络营销网络培训学校seo网站营销公司哪家好
  • 网站建设产品价格竞价推广账户竞价托管公司
  • 手把手教你做网站 3网络营销岗位有哪些
  • wordpress后台仪表盘整站优化快速排名
  • 先做网站主页还是先上架宝贝抖音推广怎么做
  • 企业网站改版项目描述口碑营销理论
  • 做一个网站后期维护需要多少钱成都百度推广和seo优化
  • 淄博网站建设服务网站排名查询工具
  • 做网站首页多少钱保定seo建站
  • 首页官网河北seo推广公司
  • 曰本真人性做爰视频网站名字seo入门教程网盘
  • 专门做装修的网站微博推广方式
  • 手机网站和电脑网站开发2022年百度seo
  • 广州专业做网站的科技公司百度竞价托管外包代运营
  • 洛阳市新区建设投资有限公司网站百度识图扫一扫
  • 池州北京网站建设互联网运营推广是做什么的
  • 个人业务网站后台windows优化大师免费版
  • 大型门户网站是这样炼成的源代码青岛百度关键词优化
  • 英文 网站 源码什么软件可以发帖子做推广
  • 常州高端网站制作公司排名百度一下了你就知道官网
  • c 网站做微信收款功能老域名购买
  • 怎么才能提高网站点击量 免费在线资源搜索引擎
  • 邯郸哪里有做网站的李创建网站免费
  • 市总工会智慧网站建设总结seo顾问咨询
  • wordpress网站搬家换域名做电商需要学哪些基础
  • 网站公司制作网站有何优势临沂色度广告有限公司
  • b2c建设网站公司推广方案策划
  • 酒店做网站草根seo视频大全
  • 关于色彩搭配的网站seo关键词推广