前言

gRPC默认的请求的超时时间是很长的,当你没有设置请求超时时间时,所有在运行的请求都占用大量资源且可能运行很长的时间,导致服务资源损耗过高,使得后来的请求响应过慢,甚至会引起整个进程崩溃。

为了避免这种情况,我们的服务应该设置超时时间。前面的入门教程提到,当客户端发起请求时候,需要传入上下文context.Context,用于结束超时或取消的请求。

本篇以简单RPC为例,介绍如何设置gRPC请求的超时时间。

客户端请求设置超时时间

修改调用服务端方法

1.把超时时间设置为当前时间+3秒

clientDeadline := time.Now().Add(time.Duration(3 * time.Second))

ctx, cancel := context.WithDeadline(ctx, clientDeadline)

defer cancel()

2.响应错误检测中添加超时检测

// 传入超时时间为3秒的ctx

res, err := grpcClient.Route(ctx, &req)

if err != nil {

//获取错误状态

statu, ok := status.FromError(err)

if ok {

//判断是否为调用超时

if statu.Code() == codes.DeadlineExceeded {

log.Fatalln("Route timeout!")

}

}

log.Fatalf("Call Route err: %v", err)

}

// 打印返回值

log.Println(res.Value)

服务端判断请求是否超时

当请求超时后,服务端应该停止正在进行的操作,避免资源浪费。事实上,我并不能很好控制服务端停止工作而避免资源浪费,只能尽量减少资源浪费。一般地,在耗时操作或写库前进行超时检测,发现超时就停止工作。

// Route 实现Route方法

func (s *SimpleService) Route(ctx context.Context, req *pb.SimpleRequest) (*pb.SimpleResponse, error) {

timeout := make(chan struct{}, 1)

data := make(chan *pb.SimpleResponse, 1)

go func() {

time.Sleep(4 * time.Second)

res := pb.SimpleResponse{

Code: 200,

Value: "hello " + req.Data,

}

log.Println("goroutine still running")

data

}()

go func() {

for {

if ctx.Err() == context.Canceled {

timeout

}

}

}()

select {

case res :=

return res, nil

case

return nil, status.Errorf(codes.Canceled, "Client cancelled, abandoning.")

}

}

上面这段代码,当超时后,获取数据的goroutine仍然在运行,并不能避免资源浪费。所以还是那句话,在耗时操作或写库前进行超时检测,发现超时就停止工作。除非找到更好解决的解决方案。

运行结果

服务端:

:8000 net.Listing...

goroutine still running

客户端:

Route timeout!

总结

超时时间的长短需要根据自身服务而定,例如返回一个hello grpc,可能只需要几十毫秒,然而处理大量数据的同步操作则可能要很长时间。需要考虑多方面因素来决定这个超时时间,例如系统间端到端的延时,哪些RPC是串行的,哪些是可以并行的等等。

有疑问加站长微信联系(非本文作者)

PHP获取grpc请求时间,Go gRPC进阶-超时设置(六)相关推荐

  1. Python基础学习----Requests获取url请求时间:

    想知道爬虫目标页面的二级目录的url的响应时间并打印出来: 使用的方法是: import requests r=requests.get("http://www.baidu.com" ...

  2. java ftp 连接超时时间_ftpClient的连接超时设置(setConnectTimeout,setSoTimeout) | 学步园...

    从 ftpClient的官方网的FAQ里面看到,实现这个需要用一个 自定义的SocketFactory 然后实现里面的 createSocket方法,有好多个. http://wiki.apache. ...

  3. gRPC(1)- gRPC 简介

    概述 在 gRPC 中,客户端应用程序可以直接调用不同机器上的服务器应用程序上的方法,就像它是本地对象一样,使您可以更轻松地创建分布式应用程序和服务.与许多 RPC 系统一样,gRPC 基于定义服务的 ...

  4. PICE(6):集群环境里多异类端点gRPC Streaming - Heterogeneous multi-endpoints gRPC streaming

    gRPC Streaming的操作对象由服务端和客户端组成.在一个包含了多个不同服务的集群环境中可能需要从一个服务里调用另一个服务端提供的服务.这时调用服务端又成为了提供服务端的客户端了(服务消费端) ...

  5. PICE(6):集群环境里多异类端点gRPC Streaming - Heterogeneous multi-endpoints gRPC streaming...

    gRPC Streaming的操作对象由服务端和客户端组成.在一个包含了多个不同服务的集群环境中可能需要从一个服务里调用另一个服务端提供的服务.这时调用服务端又成为了提供服务端的客户端了(服务消费端) ...

  6. php yat grpc,Laravel 5 使用 Grpc 构建的微服务

    最近有用微服务相关的项目,所以记录一下. 服务端采用的是 NodeJS 代码就不贴了(主要是计算DY签名的),这里贴一下 .proto 文件的代码 proto 文件 syntax = "pr ...

  7. [bug]超时时间已到。超时时间已到,但是尚未从池中获取连接。出现这种情况可能是因为所有池连接均在使用,并且达到了最大池大小。...

    引言 自己弄了一个小项目--日程管理系统,在初始化日期时,查询了数据库,每个日期就会查询一次数据库,就导致了这个问题. 问题 出现这种情况可能是因为所有池连接均在使用,并且达到了最大池大小. Desc ...

  8. ajax对日期处理,AJAX获取服务器当前时间及时间格式输出处理

    AJAX获取服务器当前时间 ------------------------------ WebService1.asmx---------------------------------- // 若 ...

  9. 获取两个时间之间的间隔_花了两天,终于把 Python 的时间转化给整明白了(超多图解)...

    来源:Python编程时光(未经授权不得私自转载) Python 的时间转化,我相信是很多开发者的痛.学得慢,忘得快,一到要用就去百度,效率太低.建议收藏这些文章(但也别忘了点赞呐,求你了),需要的时 ...

  10. Spring/SpringBoot 过滤器修改、获取http 请求request中的参数 和 response返回值,比如修改请求体和响应体的字符编码

    通过自定义filter,RequestWrapper,ResponseWrapper 处理请求和响应数据,比如修改请求体和响应体的字符编码 1.request 和 response 中的数据都是 存在 ...

最新文章

  1. Leetcode 461. Hamming Distance JAVA语言
  2. 开源大数据查询分析引擎
  3. CSS文件添加 @charset utf-8; 可能会引起样式在IE6下失效
  4. 【算法】159题 Longest Substring with at Most Two Distinct Characters 最大的子串
  5. 面试官问你final、finally、finalize的区别
  6. ant通用模板(build_common.xml)使用介绍
  7. TensorFlow图像数据预处理
  8. 10 个内存引发的大坑,你能躲开几个?
  9. 用原生NodeJS实现简易的静态web
  10. 【poker】WASD变成上下左右键(方向键)的解决方法
  11. [Linux] 解决virtualbox共享文件夹没有访问权限的问题
  12. Java编程:树(实际应用)
  13. 修复Ubuntu 14.04中Chromium的Adobe Flash Player的问题
  14. python集合类型
  15. alexa全攻略(转)
  16. 16 Cesium—矢量数据
  17. 【freeradius】使用radclient调试radius协议
  18. This account is currently not available 解决办法
  19. 金融行情尽在掌握 — Google(谷歌)推出谷歌金融 Onebox
  20. 笔记本电脑wifi图标消失解决

热门文章

  1. 【表盘识别】基于matlab投影法电表表盘读数识别【含Matlab源码 1101期】
  2. 【协作通信】基于matlab协作通信仿真【含Matlab源码 1006期】
  3. 【单目标优化求解】基于matlab海洋捕食者算法(MPA)求解单目标问题【含Matlab源码 478期】
  4. java线程池的好处_Java 线程池的使用好处
  5. @scheduled注解配置时间_《SpringBoot整合redis、Scheduled/quartz定时任务》
  6. 您实际上可以通过这些YouTube视频了解GPT-3
  7. mysql引擎接口_Mysql存储引擎MyISAM和InnoDB
  8. 设置PyCharm相同词汇高亮
  9. fatal error: openssl/sha.h: No such file or directory
  10. java集合升序降序