2021-03-16 15:57:15 +00:00
|
|
|
|
# gRPC
|
2021-03-15 15:59:11 +00:00
|
|
|
|
|
|
|
|
|
基于 gRPC 的传输方式。
|
|
|
|
|
|
2021-03-16 15:57:15 +00:00
|
|
|
|
它基于 HTTP/2 协议,理论上可以通过其它支持 HTTP/2 的服务器(如 Nginx)进行中转。
|
|
|
|
|
gRPC(HTTP/2)内置多路复用,不建议使用 gRPC 与 HTTP/2 时启用 mux.cool。
|
|
|
|
|
|
2021-03-17 13:31:34 +00:00
|
|
|
|
::: warning ⚠⚠⚠
|
2021-03-26 06:01:07 +00:00
|
|
|
|
|
2021-03-26 16:44:51 +00:00
|
|
|
|
- gRPC 不支持指定 Host。请在出站代理地址中填写 **正确的域名** ,或在 `(x)tlsSettings` 中填写 `ServerName`,否则无法连接。
|
2021-03-17 13:31:34 +00:00
|
|
|
|
- gRPC 不支持回落到其他服务。
|
2021-03-26 16:44:51 +00:00
|
|
|
|
- gRPC 服务存在被主动探测的风险。建议使用 Caddy 或 Nginx 等反向代理工具,通过 Path 前置分流。
|
2021-03-26 06:01:07 +00:00
|
|
|
|
:::
|
2021-03-17 04:42:25 +00:00
|
|
|
|
|
2021-03-16 15:57:15 +00:00
|
|
|
|
::: tip
|
2021-03-17 06:11:09 +00:00
|
|
|
|
如果您使用 Caddy 或 Nginx 等反向代理,请注意下列事项:
|
2021-03-26 06:01:07 +00:00
|
|
|
|
|
2021-03-17 06:11:09 +00:00
|
|
|
|
- 请确定反向代理服务器开启了 HTTP/2
|
|
|
|
|
- 请使用 HTTP/2 或 h2c (Caddy),grpc_pass (Nginx) 连接到 Xray。
|
2021-04-06 06:05:47 +00:00
|
|
|
|
- 普通模式的 Path 为 `/${serviceName}/Tun`, Multi 模式为 `/${serviceName}/TunMulti`
|
2021-03-26 06:01:07 +00:00
|
|
|
|
:::
|
2021-03-16 15:57:15 +00:00
|
|
|
|
|
2021-03-17 12:59:02 +00:00
|
|
|
|
::: tip
|
|
|
|
|
如果你正在使用回落,请注意下列事项:
|
2021-03-26 06:01:07 +00:00
|
|
|
|
|
2021-03-26 16:44:51 +00:00
|
|
|
|
- 不建议回落到 gRPC,存在被主动探测的风险。
|
|
|
|
|
- 请确认`h2` 位于 (x)tlsSettings.alpn 中的第一顺位,否则 gRPC(HTTP/2)可能无法完成 TLS 握手。
|
2021-03-17 13:31:34 +00:00
|
|
|
|
- gRPC 无法通过进行 Path 分流。
|
2021-03-26 06:01:07 +00:00
|
|
|
|
:::
|
2021-03-15 15:59:11 +00:00
|
|
|
|
|
2021-03-16 15:57:15 +00:00
|
|
|
|
## GRPCObject
|
2021-03-15 15:59:11 +00:00
|
|
|
|
|
|
|
|
|
`GRPCObject` 对应传输配置的 `grpcSettings` 项。
|
|
|
|
|
|
|
|
|
|
```json
|
|
|
|
|
{
|
2021-03-16 15:57:15 +00:00
|
|
|
|
"serviceName": "name",
|
|
|
|
|
"multiMode": false
|
2021-03-15 15:59:11 +00:00
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2021-03-26 06:01:07 +00:00
|
|
|
|
> `serviceName`: string
|
2021-03-15 15:59:11 +00:00
|
|
|
|
|
2021-04-06 06:05:47 +00:00
|
|
|
|
一个字符串,指定服务名称,**类似于** HTTP/2 中的 Path。
|
|
|
|
|
客户端会使用此名称进行通信,服务端会验证服务名称是否匹配。
|
2021-03-15 15:59:11 +00:00
|
|
|
|
|
2021-03-16 15:57:15 +00:00
|
|
|
|
> `multiMode`: bool <Badge text="BETA" type="warning"/>
|
|
|
|
|
|
|
|
|
|
一个布尔值。表示是否启用 `multiMode`。
|
|
|
|
|
|
2021-03-17 04:42:25 +00:00
|
|
|
|
这是一个 **实验性** 选项,可能不会被长期保留,也不保证跨版本兼容。此模式在 **测试环境中** 能够带来约 20% 的性能提升,实际效果因传输速率不同而不同。
|