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

网站开发的案例分析模板西宁知名网站制作公司

网站开发的案例分析模板,西宁知名网站制作公司,济南住宅网签查询,网站版权符号grpc四种数据流 简介 1.简单模式 这种模式最为传统,即客户端发起一次请求,服务端响应一个数据,这和大家平时熟悉的rpc没什么区别,所以不在详细介绍 2.服务端数据流模式 这种模式是客户端发起一次请求#xff0c;服务端返回一段连续的数据流。典型的例子是客户端向服务端发…grpc四种数据流 简介 1.简单模式 这种模式最为传统,即客户端发起一次请求,服务端响应一个数据,这和大家平时熟悉的rpc没什么区别,所以不在详细介绍 2.服务端数据流模式 这种模式是客户端发起一次请求服务端返回一段连续的数据流。典型的例子是客户端向服务端发送一个股票代码服务端就把该股票的实时数据源源不断的返回给客户端。 3.客户端数据流模式 与服务端数据流模式相反这次是客户端源源不断的向服务端发送数据流而在发送结束后由服务端返回一个响应。典型的例子是物联网向服务器报送数据。 4.双向数据流模式 顾名思义这是客户端和服务端都可以向对方发送数据流这个时候双方的数据可以同时互相发送也就是可以实现实时交互。典型的例子是聊天机器人 proto文件代码编写 哪一方需要源源不断的返回数据,就在那一端的前面添加stream关键字,表示流 syntax proto3;option go_package../../common/stream/proto/v1; service Greeter {rpc GetStream(StreamReqData) returns (stream StreamResData); //服务端流模式rpc PutStream(stream StreamReqData) returns (StreamResData); //客户端流模式rpc AllStream(stream StreamReqData) returns (stream StreamResData); //双向流模式 }message StreamReqData {string data 1; }message StreamResData {string data 1; }服务端代码 除三种流模式实现代码外整体代码与之前的普通模式无异 服务端数据流模式: grpc生成的函数原型为: func GetStream(req *proto.StreamReqData, res proto.Greeter_GetStreamServer) errorproto.Greeter_GetStreamServer:使用方式类似于socket网络编程 客户端数据流模式: grpc生成的函数原型为: func PutStream(cliStr proto.Greeter_PutStreamServer) error双向数据流模式:grpc生成的函数原型为: func AllStream(allStr proto.Greeter_AllStreamServer) errorpackage mainimport (OldPackageTest/stream_grpc_test/protofmtgoogle.golang.org/grpcnetsynctime )const PORT :50052type server struct { }func (s *server) GetStream(req *proto.StreamReqData, res proto.Greeter_GetStreamServer) error {i : 0for {i_ res.Send(proto.StreamResData{Data: fmt.Sprintf(%v, time.Now().Unix()),})time.Sleep(time.Second)if i 10 {break}}return nil }func (s *server) PutStream(cliStr proto.Greeter_PutStreamServer) error {for {if a, err : cliStr.Recv(); err ! nil {fmt.Println(err)break} else {fmt.Println(a.Data)}}return nil }func (s *server) AllStream(allStr proto.Greeter_AllStreamServer) error {wg : sync.WaitGroup{}wg.Add(2)//启动两个协程,一发一收go func() {defer wg.Done()for {data, _ : allStr.Recv()fmt.Println(收到客户端消息 data.Data)}}()go func() {defer wg.Done()for {_ allStr.Send(proto.StreamResData{Data: 我是服务器})time.Sleep(time.Second)}}()wg.Wait()return nil }func main() {lis, err : net.Listen(tcp, PORT)if err ! nil {panic(err)}s : grpc.NewServer()proto.RegisterGreeterServer(s, server{})err s.Serve(lis)if err ! nil {panic(err)} } 客户端代码 客户端实现代码简单,大家自己阅读即可 package mainimport (contextfmtsynctimegoogle.golang.org/grpcOldPackageTest/stream_grpc_test/proto )func main() {conn, err : grpc.Dial(localhost:50052, grpc.WithInsecure())if err ! nil {panic(err)}defer conn.Close()//服务端流模式c : proto.NewGreeterClient(conn)res, _ : c.GetStream(context.Background(), proto.StreamReqData{Data: go})for {a, err : res.Recv() //如果大家懂socket编程的话就明白 send recvif err ! nil {fmt.Println(err)break}fmt.Println(a.Data)}//客户端流模式putS, _ : c.PutStream(context.Background())i : 0for {i_ putS.Send(proto.StreamReqData{Data: fmt.Sprintf(grpc %d, i),})time.Sleep(time.Second)if i 10 {break}}//双向流模式allStr, _ : c.AllStream(context.Background())wg : sync.WaitGroup{}wg.Add(2)go func() {defer wg.Done()for {data, _ : allStr.Recv()fmt.Println(收到客户端消息 data.Data)}}()go func() {defer wg.Done()for {_ allStr.Send(proto.StreamReqData{Data: go})time.Sleep(time.Second)}}()wg.Wait() }
http://www.dnsts.com.cn/news/5916.html

相关文章:

  • ios软件下载网站wordpress 当前主题目录
  • 做网站的挣钱么外包推广公司
  • 百度如何推广网站济南将开展治堵十大行动
  • 惠州做网站开发网站建设合同 模板 下载
  • 国内好的设计网站直播网站怎么做的
  • 网站运营和管理电工培训内容
  • 网站建设学习教程沈阳做网站哪家好
  • 做商城网站需要多大的服务器上海突发事件
  • 网站建设一般报价多少钱顺义区网站建设
  • 河南平价的seo整站优化定制前端app用什么开发
  • 淄博网站制作品牌定制网站建设企业开发公司
  • 网站维护和更新网络搏彩网站做代理
  • 京美建站官网商标注册查询中心
  • 营销网站的优势是什么青岛市建设监理网站
  • 长春网站建设团队磁力棒
  • 使用vue做简单网站教程淄博外贸网站制作
  • 传奇网站制作网口碑营销的案例
  • 东莞营销型网站建设公司品牌推广的渠道有哪些
  • 网站建设与推广范文长沙网站公司哪家好
  • 网站建设价格一览表codeus wordpress
  • 网站优化是外包还是自己做电商设计和ui设计哪个前景比较好
  • 怎么自己做论坛网站吗国外优惠卷网站如何做
  • 京东网站建设评估做汽车网可参考网站
  • 网站怎么加统计代码云南seo网站关键词优化软件
  • 蚌埠 网站制作烟台论坛
  • 做英文网站的标准字体济宁住房与建设网站
  • 淘宝做详情页的网站开发小程序定制公司
  • 网站开发的地图接口做实验流程图的网站
  • 医院网站源码 asp使用微信做网站第三方登录
  • 如何创建网络网站建设优化