返回顶部
首页 > 资讯 > 后端开发 > GO >在golang中覆盖gRPC客户端的http主机头
  • 336
分享到

在golang中覆盖gRPC客户端的http主机头

2024-02-09 08:02:06 336人浏览 泡泡鱼
摘要

在golang中覆盖grpc客户端的Http主机头是一个常见的需求。grpc是一种高性能、跨语言的远程过程调用框架,而在使用gRPC进行通信时,有时需要自定义http请求的主机头。PH

golang中覆盖grpc客户端的Http主机头是一个常见的需求。grpc是一种高性能、跨语言的远程过程调用框架,而在使用gRPC进行通信时,有时需要自定义http请求的主机头。PHP小编西瓜将为您介绍如何在Golang中实现这个功能,以便更好地满足您的业务需求。

问题内容

我通过 gRPC 客户端通过连接发送了请求

conn, err := grpc.Dial("hostname:port",opts...)

服务器端,我看到http.request中的host是确切的hostname:port。然后,我的 Nginx 服务器设置如下

server {
    listen port http2;
    server_name hostname;
    # ...
}
server {
    listen port http2;
    server_name another_hostname;
    # ...
}

这是一种常见的虚拟主机技术。 无论我在 grpc.Dial(xxx:port) 中使用哪个主机名,它都可以正常工作。然而,当我把

md := metadata.New(map[string]string{"host":"another_hostname:port"})

在grpc上下文中(将填充在http2请求的标头中)。这个请求将被 nginx 阻止,我得到了

rpc error: code = Internal desc = unexpected HTTP status code received from server: 400 (Bad Request); transport: received unexpected content-type "text/html"

之所以要手动输入主机名,是因为grpc.Dial中的主机名是固定的。而且我不能使用不同的位置来做反向代理,因为port后面是restful api的路由路径。

如果主机名固定并且路由也固定,还有其他方法可以进行反向代理吗?

(23/09)更新:结果发现http2中的host头被:Authority伪头取代了。

解决方法

gRPC 使用 HTTP/2,不使用 :host 标头,而是使用 :authority 伪标头。此标头的值在此处确定: https://GitHub .com/grpc/grpc-go/blob/aa6ce35c792863305e0f42acc27f2c7153275f89/clientconn.go#L1942

TL;博士

默认情况下,用于 :authority 标头的值是用户拨号目标的端点部分,其格式为 url://authority/endpoint

gRPC-Go 还支持拨号选项来覆盖此 authority。请参阅:https://pkg.go.dev/google.golang.org/ grpC#WithAuthority。但还要注意,此拨号选项会覆盖 TLS 握手期间使用的 ServerName 值。

如果您有更多问题/疑虑,请随时通过我们的 gitHub 存储库与我们联系。您的查询将在那里得到更好的响应时间。

以上就是在golang中覆盖gRPC客户端的http主机头的详细内容,更多请关注编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: 在golang中覆盖gRPC客户端的http主机头

本文链接: https://lsjlt.com/news/562288.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作