88 lines
2.3 KiB
Markdown
Raw Normal View History

2024-10-01 18:51:39 +00:00
# HTTP
2021-03-15 23:59:11 +08:00
2024-10-01 18:51:39 +00:00
基于 HTTP/2 或 HTTP/3 的传输方式。
2021-03-15 23:59:11 +08:00
2024-10-01 18:51:39 +00:00
它完整按照 HTTP 标准实现,可以通过其它的 HTTP 服务器(如 Nginx进行中转。
2021-03-15 23:59:11 +08:00
2024-10-01 18:51:39 +00:00
客户端必须开启 TLS 才可以正常使用这个传输方式。
2021-03-15 23:59:11 +08:00
2024-10-01 18:51:39 +00:00
HTTP/2和3 内置多路复用,不建议使用时启用 mux.cool。
2021-03-16 23:57:15 +08:00
2021-03-15 23:59:11 +08:00
::: tip
2022-08-07 12:57:55 +08:00
当前版本的 HTTP/2 的传输方式并不强制要求**入站****服务端**)有 TLS 配置.
2024-10-01 18:51:39 +00:00
这使得可以在特殊用途的分流部署环境中,由外部网关组件完成 TLS 层对话Xray 作为后端应用,网关和 Xray 间使用明文HTTP进行通讯。
2021-03-16 23:57:15 +08:00
:::
2021-03-15 23:59:11 +08:00
2024-10-01 18:51:39 +00:00
::: tip
当alpn有且仅有 `h3`该传输才会工作在h3模式。
:::
2021-03-26 14:01:07 +08:00
2024-10-01 18:51:39 +00:00
::: warning
- HTTP/2 和 HTTP/3 无法通过xray的回落 Path 进行分流,不建议使用回落分流。
2021-03-26 14:01:07 +08:00
:::
2021-03-15 23:59:11 +08:00
## HttpObject
`HttpObject` 对应传输配置的 `httpSettings` 项。
```json
{
"host": ["xray.com"],
2021-09-30 01:13:53 +08:00
"path": "/random/path",
"read_idle_timeout": 10,
"health_check_timeout": 15,
"method": "PUT",
"headers": {
"Header": ["value"]
}
2021-03-15 23:59:11 +08:00
}
```
> `host`: \[string\]
一个字符串数组,每一个元素是一个域名。
客户端会随机从列表中选出一个域名进行通信,服务器会验证域名是否在列表中。
::: tip
若不写 `"httpSettings"``"host": []` 值留空时,会使用默认值 `"www.example.com"`,需要两端 `"host"` 值一致才能连接成功。`"host": [""]` 不是值留空。
:::
> `path`: string
2021-03-15 23:59:11 +08:00
HTTP 路径,由 `/` 开头, 客户端和服务器必须一致。
默认值为 `"/"`
2021-09-30 01:13:53 +08:00
> `read_idle_timeout`: number
2021-09-30 01:13:53 +08:00
单位秒,当这段时间内没有接收到数据时,将会进行健康检查。
健康检查默认**不启用**。
2022-08-07 12:57:55 +08:00
::: tip
**只需**在**出站****客户端**)配置。
:::
::: tip
可能会解决一些“断流”问题。
:::
2021-09-30 01:13:53 +08:00
> `health_check_timeout`: number
2021-09-30 01:13:53 +08:00
单位秒,健康检查的超时时间。如果在这段时间内没有完成健康检查,即认为健康检查失败。默认值为 `15`
2022-08-07 12:57:55 +08:00
::: tip
**只需**在**出站****客户端**)配置。
:::
> `method`: string
HTTP 方法。默认值为 `"PUT"`
设置时应参照[此处](https://developer.mozilla.org/en-US/docs/Web/HTTP/Methods)列出值。
> `headers`: map{ string: \[string\] }
2024-07-29 12:21:57 +00:00
仅客户端,自定义 HTTP 头,一个键值对,每个键表示一个 HTTP 头名称,对应值为一个数组。