Xray-docs-next/docs/config/outbound.md

132 lines
4.0 KiB
Markdown
Raw Normal View History

2021-03-15 15:59:11 +00:00
# 出站代理
出站连接用于发送数据,可用的协议请见 [出站协议](./outbounds/)。
2021-03-15 15:59:11 +00:00
## OutboundObject
`OutboundObject` 对应配置文件中 `outbounds` 项的一个子元素。
::: tip
2021-03-26 06:01:07 +00:00
列表中的第一个元素作为主 outbound。当路由匹配不存在或没有匹配成功时流量由主 outbound 发出。
2021-03-15 15:59:11 +00:00
:::
```json
{
"outbounds": [
{
"sendThrough": "0.0.0.0",
"protocol": "协议名称",
"settings": {},
"tag": "标识",
"streamSettings": {},
"proxySettings": {
"tag": "another-outbound-tag"
},
"mux": {}
}
]
}
```
2021-03-26 06:01:07 +00:00
> `sendThrough`: address
2021-03-15 15:59:11 +00:00
用于发送数据的 IP 地址,当主机有多个 IP 地址时有效,默认值为 `"0.0.0.0"`
2021-03-26 06:01:07 +00:00
> `protocol`: string
2021-03-15 15:59:11 +00:00
连接协议名称,可选的协议类型见 [出站协议](./outbounds/)。
2021-03-26 06:01:07 +00:00
> `settings`: OutboundConfigurationObject
2021-03-15 15:59:11 +00:00
具体的配置内容,视协议不同而不同。详见每个协议中的 `OutboundConfigurationObject`
2021-03-26 06:01:07 +00:00
> `tag`: string
2021-03-15 15:59:11 +00:00
此出站连接的标识,用于在其它的配置中定位此连接。
::: danger
当其不为空时,其值必须在所有 `tag`**唯一**。
:::
2021-03-26 06:01:07 +00:00
> `streamSettings`: [StreamSettingsObject](./transport.md#streamsettingsobject)
2021-03-15 15:59:11 +00:00
底层传输方式transport是当前 Xray 节点和其它节点对接的方式
2021-03-26 06:01:07 +00:00
> `proxySettings`: [ProxySettingsObject](#proxysettingsobject)
2021-03-15 15:59:11 +00:00
2021-03-26 06:01:07 +00:00
出站代理配置。当出站代理生效时,此 outbound 的 `streamSettings` 将不起作用。
2021-03-15 15:59:11 +00:00
2021-03-26 06:01:07 +00:00
> `mux`: [MuxObject](#muxobject)
2021-03-15 15:59:11 +00:00
Mux 相关的具体配置。
### ProxySettingsObject
2021-03-26 06:01:07 +00:00
2021-03-15 15:59:11 +00:00
```json
{
"tag": "another-outbound-tag"
}
```
2021-03-26 06:01:07 +00:00
> `tag`: string
2021-03-15 15:59:11 +00:00
2021-03-26 06:01:07 +00:00
当指定另一个 outbound 的标识时,此 outbound 发出的数据,将被转发至所指定的 outbound 发出。
2021-03-15 15:59:11 +00:00
::: danger
2021-03-18 15:32:36 +00:00
这种转发方式**不经过**底层传输方式。如果需要使用支持底层传输方式的转发,请使用 [SockOpt.dialerProxy](./transport.md#sockoptobject)。
2021-03-15 15:59:11 +00:00
:::
::: danger
此选项与 SockOpt.dialerProxy 不兼容
:::
::: tip
兼容 v2fly/v2ray-core 的配置 [transportLayer](https://www.v2fly.org/config/outbounds.html#proxysettingsobject)
:::
### MuxObject
2021-03-26 06:01:07 +00:00
2021-03-24 16:02:40 +00:00
Mux 功能是在一条 TCP 连接上分发多个 TCP 连接的数据。实现细节详见 [Mux.Cool](../../development/protocols/muxcool)。Mux 是为了减少 TCP 的握手延迟而设计,而非提高连接的吞吐量。使用 Mux 看视频、下载或者测速通常都有反效果。Mux 只需要在客户端启用,服务器端自动适配。
2021-03-15 15:59:11 +00:00
`MuxObject` 对应 `OutboundObject` 中的 `mux` 项。
```json
{
2023-04-18 03:20:35 +00:00
"enabled": true,
2023-04-18 01:20:38 +00:00
"concurrency": 8,
2023-04-18 03:20:35 +00:00
"xudpConcurrency": 16,
2023-04-18 01:20:38 +00:00
"xudpProxyUDP443": "reject"
2021-03-15 15:59:11 +00:00
}
```
2021-03-26 06:01:07 +00:00
> `enabled`: true | false
2021-03-15 15:59:11 +00:00
是否启用 Mux 转发请求,默认值 `false`
2021-03-26 06:01:07 +00:00
> `concurrency`: number
2021-03-15 15:59:11 +00:00
2023-04-18 01:53:09 +00:00
最大并发连接数。最小值 `1`,最大值 `1024`。省略或者填 `0` 时都等于 `8`
2021-03-15 15:59:11 +00:00
2023-04-20 00:32:29 +00:00
这个数值表示了一个 TCP 连接上最多承载的子连接数量。比如设置 `concurrency=8` 时,当客户端发出了 8 个 TCP 请求Xray 只会发出一条实际的 TCP 连接,客户端的 8 个请求全部由这个 TCP 连接传输。
2021-03-15 15:59:11 +00:00
::: tip
2023-04-18 03:38:07 +00:00
填负数时,如 `-1`,不使用 Mux 模块承载 TCP 流量。
2021-03-15 15:59:11 +00:00
:::
2023-04-18 01:20:38 +00:00
> `xudpConcurrency`: number
2023-04-20 00:32:29 +00:00
使用新 XUDP 聚合隧道(也就是另一条 Mux 连接)代理 UDP 流量,填写最大并发子 UoT 数量。最小值 `1`,最大值 `1024`
省略或者填 `0` 时,将与 TCP 流量走同一条路,也就是传统的行为。
2023-04-18 01:53:09 +00:00
2023-04-18 03:20:35 +00:00
::: tip
2023-04-18 03:38:07 +00:00
填负数时,如 `-1`,不使用 Mux 模块承载 UDP 流量。将使用代理协议原本的 UDP 传输方式。例如 `Shadowsocks` 会使用原生 UDP`VLESS` 会使用 UoT。
2023-04-18 03:20:35 +00:00
:::
2023-04-18 01:20:38 +00:00
> `xudpProxyUDP443`: string
2023-04-20 00:32:29 +00:00
控制 Mux 对于被代理的 UDP/443QUIC流量的处理方式
2023-04-18 01:20:38 +00:00
2023-04-20 00:32:29 +00:00
- 默认 `reject` 拒绝流量(一般浏览器会自动回落到 TCP HTTP2
- `allow` 允许走 Mux 连接。
-`skip` 时,不使用 Mux 模块承载 UDP 443 流量。将使用代理协议原本的 UDP 传输方式。例如 `Shadowsocks` 会使用原生 UDP`VLESS` 会使用 UoT。