116 lines
3.8 KiB
Markdown
Raw Normal View History

2021-03-16 23:57:15 +08:00
# gRPC
2021-03-15 23:59:11 +08:00
基于 gRPC 的传输方式。
2021-03-16 23:57:15 +08:00
它基于 HTTP/2 协议,理论上可以通过其它支持 HTTP/2 的服务器(如 Nginx进行中转。
gRPCHTTP/2内置多路复用不建议使用 gRPC 与 HTTP/2 时启用 mux.cool。
2021-03-17 21:31:34 +08:00
::: warning ⚠⚠⚠
2021-03-26 14:01:07 +08:00
2021-03-27 00:44:51 +08:00
- gRPC 不支持指定 Host。请在出站代理地址中填写 **正确的域名** ,或在 `(x)tlsSettings` 中填写 `ServerName`,否则无法连接。
2021-03-17 21:31:34 +08:00
- gRPC 不支持回落到其他服务。
2021-03-27 00:44:51 +08:00
- gRPC 服务存在被主动探测的风险。建议使用 Caddy 或 Nginx 等反向代理工具,通过 Path 前置分流。
2021-03-26 14:01:07 +08:00
:::
2021-03-17 12:42:25 +08:00
2021-03-16 23:57:15 +08:00
::: tip
2021-03-17 14:11:09 +08:00
如果您使用 Caddy 或 Nginx 等反向代理,请注意下列事项:
2021-03-26 14:01:07 +08:00
2021-03-17 14:11:09 +08:00
- 请确定反向代理服务器开启了 HTTP/2
- 请使用 HTTP/2 或 h2c (Caddy)grpc_pass (Nginx) 连接到 Xray。
2021-04-06 14:05:47 +08:00
- 普通模式的 Path 为 `/${serviceName}/Tun`, Multi 模式为 `/${serviceName}/TunMulti`
- 如果需要接收客户端 IP可以通过由 Caddy / Nginx 发送 `X-Real-IP` header 来传递客户端 IP。
2021-03-26 14:01:07 +08:00
:::
2021-03-16 23:57:15 +08:00
2021-03-17 20:59:02 +08:00
::: tip
如果你正在使用回落,请注意下列事项:
2021-03-26 14:01:07 +08:00
2021-03-27 00:44:51 +08:00
- 不建议回落到 gRPC存在被主动探测的风险。
- 请确认`h2` 位于 (x)tlsSettings.alpn 中的第一顺位,否则 gRPCHTTP/2可能无法完成 TLS 握手。
2021-03-17 21:31:34 +08:00
- gRPC 无法通过进行 Path 分流。
2021-03-26 14:01:07 +08:00
:::
2021-03-15 23:59:11 +08:00
2021-03-16 23:57:15 +08:00
## GRPCObject
2021-03-15 23:59:11 +08:00
`GRPCObject` 对应传输配置的 `grpcSettings` 项。
```json
{
2021-03-16 23:57:15 +08:00
"serviceName": "name",
"multiMode": false,
"user_agent": "custom user agent",
2022-07-02 21:22:16 +08:00
"idle_timeout": 60,
"health_check_timeout": 20,
"permit_without_stream": false,
"initial_windows_size": 0
2021-03-15 23:59:11 +08:00
}
```
2021-03-26 14:01:07 +08:00
> `serviceName`: string
2021-03-15 23:59:11 +08:00
2021-04-06 14:05:47 +08:00
一个字符串,指定服务名称,**类似于** HTTP/2 中的 Path。
客户端会使用此名称进行通信,服务端会验证服务名称是否匹配。
2021-03-15 23:59:11 +08:00
> `user_agent`: string
::: tip
**只需**在**出站****客户端**)配置。
:::
设置 gRPC 的用户代理,可能能防止某些 CDN 阻止 gRPC 流量。
2021-10-22 02:23:28 +08:00
> `multiMode`: true | false <Badge text="BETA" type="warning"/>
2021-03-16 23:57:15 +08:00
2021-10-22 02:23:28 +08:00
`true` 启用 `multiMode`,默认值为: `false`
2021-03-16 23:57:15 +08:00
2021-03-17 12:42:25 +08:00
这是一个 **实验性** 选项,可能不会被长期保留,也不保证跨版本兼容。此模式在 **测试环境中** 能够带来约 20% 的性能提升,实际效果因传输速率不同而不同。
2022-08-07 13:28:22 +08:00
::: tip
**只需**在**出站****客户端**)配置。
:::
2022-03-07 16:58:51 +08:00
> `idle_timeout`: number
单位秒,当这段时间内没有数据传输时,将会进行健康检查。如果此值设置为 `10` 以下,将会使用 `10`,即最小值。
2022-04-19 00:16:58 +08:00
::: tip
2022-10-17 18:02:32 +08:00
如果没有使用 Caddy 或 Nginx 等反向代理工具(**通常不会**),设为 `60` 以下,服务端可能发送意外的 h2 GOAWAY 帧以关闭现有连接。
2022-04-19 00:16:58 +08:00
:::
健康检查默认**不启用**。
2022-08-07 13:28:22 +08:00
::: tip
**只需**在**出站****客户端**)配置。
:::
::: tip
可能会解决一些“断流”问题。
:::
> `health_check_timeout`: number
单位秒,健康检查的超时时间。如果在这段时间内没有完成健康检查,且仍然没有数据传输时,即认为健康检查失败。默认值为 `20`
2022-08-07 13:28:22 +08:00
::: tip
**只需**在**出站****客户端**)配置。
:::
2021-10-22 02:23:28 +08:00
> `permit_without_stream`: true | false
2021-10-22 02:23:28 +08:00
`true` 允许在没有子连接时进行健康检查。默认值为 `false`
2022-08-07 13:28:22 +08:00
::: tip
**只需**在**出站****客户端**)配置。
:::
2022-02-26 23:46:44 +08:00
> `initial_windows_size`: number
2021-12-21 21:40:55 +08:00
h2 Stream 初始窗口大小。当值小于等于 `0` 时,此功能不生效。当值大于 `65535`动态窗口机制Dynamic Window会被禁用。默认值为 `0`,即不生效。
2022-08-07 13:28:22 +08:00
::: tip
**只需**在**出站****客户端**)配置。
:::
::: tip
通过 Cloudflare CDN 时,可将值设为 `65536` 及以上即禁用动态窗口机制Dynamic Window可防止 Cloudflare CDN 发送意外的 h2 GOAWAY 帧以关闭现有连接。
:::