登录
首页 >  Golang >  Go教程

gRPC 服务参数校验:在 HTTP 层还是 RPC 层进行?

时间:2024-12-25 15:49:11 284浏览 收藏

目前golang学习网上已经有很多关于Golang的文章了,自己在初次阅读这些文章中,也见识到了很多学习思路;那么本文《gRPC 服务参数校验:在 HTTP 层还是 RPC 层进行?》,也希望能帮助到大家,如果阅读完后真的对你学习Golang有帮助,欢迎动动手指,评论留言并分享~

gRPC 服务参数校验:在 HTTP 层还是 RPC 层进行?

gRPC 封装 HTTP 服务中的参数校验

在将 HTTP 服务封装到 gRPC 服务中时,关于参数校验的位置存在一些争论。在 Node.js 中使用 Iris 框架和 go-proto-validators 库,出现了不同的意见。

争论的焦点

  • 靠近数据库的一层进行校验:防止恶意调用影响数据库。
  • 在 HTTP 参数传入时进行校验:确保参数及时被验证,避免浪费资源。

同事的想法:

  • 认为前端的参数校验不可靠,因此需要在 RPC 服务中再次校验。

作者的想法:

  • 使用 go-proto-validators 在客户端拦截器中进行参数校验,认为这是一种更有效率的方式。

正确的方法

实际上,应该在 HTTP 参数传入时进行参数校验。这可以确保在请求到达 gRPC 服务之前,非法参数已被阻止。

但是,使用 Interceptor 进行校验是否合适?

  • 性能隐患:在 Interceptor 中进行校验可能会造成性能损失,因为此时 gRPC 连接可能已经打开。
  • 业务封装:如果将来需要在 HTTP 服务中添加业务封装,则在 Interceptor 中进行校验可能会导致维护困难。

建议

  • 在 HTTP 服务中实现参数校验。
  • 根据实际需求,考虑在 Interceptor 中进行额外校验。
  • 权衡 Interceptor 校验的性能影响。

今天关于《gRPC 服务参数校验:在 HTTP 层还是 RPC 层进行?》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>