sing-box/docs/configuration/shared/dial.zh.md

163 lines
4.1 KiB
Markdown
Raw Normal View History

2024-11-12 11:37:10 +00:00
---
icon: material/new-box
---
!!! quote "sing-box 1.11.0 中的更改"
:material-plus: [network_strategy](#network_strategy)
2024-11-13 11:05:28 +00:00
:material-alert: [fallback_delay](#fallback_delay)
:material-alert: [network_type](#network_type)
:material-alert: [fallback_network_type](#fallback_network_type)
2024-11-12 11:37:10 +00:00
2022-08-31 04:50:26 +00:00
### 结构
```json
{
"detour": "upstream-out",
"bind_interface": "en0",
2022-11-03 04:07:16 +00:00
"inet4_bind_address": "0.0.0.0",
"inet6_bind_address": "::",
2022-08-31 04:50:26 +00:00
"routing_mark": 1234,
"reuse_addr": false,
"connect_timeout": "5s",
"tcp_fast_open": false,
2023-08-08 08:14:03 +00:00
"tcp_multi_path": false,
2022-09-09 07:40:35 +00:00
"udp_fragment": false,
2022-08-31 04:50:26 +00:00
"domain_strategy": "prefer_ipv6",
2024-11-12 11:37:10 +00:00
"network_strategy": "",
2024-11-13 11:05:28 +00:00
"network_type": [],
"fallback_network_type": [],
2022-08-31 04:50:26 +00:00
"fallback_delay": "300ms"
}
```
2024-11-13 11:05:28 +00:00
!!! note ""
当内容只有一项时,可以忽略 JSON 数组 [] 标签
2022-08-31 04:50:26 +00:00
### 字段
#### detour
上游出站的标签。
启用时,其他拨号字段将被忽略。
#### bind_interface
要绑定到的网络接口。
2022-11-03 04:07:16 +00:00
#### inet4_bind_address
2022-08-31 04:50:26 +00:00
2022-11-03 04:07:16 +00:00
要绑定的 IPv4 地址。
#### inet6_bind_address
要绑定的 IPv6 地址。
2022-08-31 04:50:26 +00:00
#### routing_mark
!!! quote ""
2022-08-31 04:50:26 +00:00
仅支持 Linux。
设置 netfilter 路由标记。
#### reuse_addr
重用监听地址。
2022-09-09 07:40:35 +00:00
#### tcp_fast_open
启用 TCP Fast Open。
2023-08-08 08:14:03 +00:00
#### tcp_multi_path
!!! warning ""
需要 Go 1.21。
启用 TCP Multi Path。
2022-09-09 07:40:35 +00:00
#### udp_fragment
启用 UDP 分段。
2022-08-31 04:50:26 +00:00
#### connect_timeout
连接超时,采用 golang 的 Duration 格式。
持续时间字符串是一个可能有符号的序列十进制数,每个都有可选的分数和单位后缀, 例如 "300ms"、"-1.5h" 或 "2h45m"。
有效时间单位为 "ns"、"us"(或 "µs")、"ms"、"s"、"m"、"h"。
#### domain_strategy
可选值:`prefer_ipv4` `prefer_ipv6` `ipv4_only` `ipv6_only`
如果设置,域名将在请求发出之前解析为 IP。
2024-11-12 11:37:10 +00:00
| 出站 | 受影响的域名 | 默认回退值 |
|----------|-----------|---------------------------|
| `direct` | 请求中的域名 | `inbound.domain_strategy` |
| others | 服务器地址中的域名 | / |
#### network_strategy
!!! question "自 sing-box 1.11.0 起"
!!! quote ""
2024-11-13 11:05:28 +00:00
仅在 Android 与 iOS 平台图形客户端中支持,并且需要 `route.auto_detect_interface`
2024-11-12 11:37:10 +00:00
用于选择网络接口的策略。
可用值:
2024-11-13 11:05:28 +00:00
- `default`(默认值):按顺序连接默认网络或 `network_type` 中指定的网络。
- `hybrid`:同时连接所有网络或 `network_type` 中指定的网络。
- `fallback`:同时连接默认网络或 `network_type` 中指定的首选网络,当不可用或超时时尝试回退网络。
2024-11-12 11:37:10 +00:00
2024-11-13 11:05:28 +00:00
对于回退模式,当首选接口失败或超时时,
将进入15秒的快速回退状态同时连接所有首选和回退网络
如果首选网络恢复,则立即退出。
2024-11-12 11:37:10 +00:00
`bind_interface`, `bind_inet4_address``bind_inet6_address` 冲突。
2022-08-31 04:50:26 +00:00
2024-11-13 11:05:28 +00:00
#### network_type
!!! question "自 sing-box 1.11.0 起"
!!! quote ""
仅在 Android 与 iOS 平台图形客户端中支持,并且需要 `route.auto_detect_interface`
当使用 `default``hybrid` 网络策略时要使用的网络类型,或当使用 `fallback` 网络策略时要使用的首选网络类型。
可用值:`wifi`, `cellular`, `ethernet`, `other`
默认使用设备默认网络。
#### fallback_network_type
!!! question "自 sing-box 1.11.0 起"
!!! quote ""
仅在 Android 与 iOS 平台图形客户端中支持,并且需要 `route.auto_detect_interface`
当使用 `fallback` 网络策略时,在首选网络不可用或超时的情况下要使用的回退网络类型。
默认使用除首选网络外的所有其他网络。
2022-08-31 04:50:26 +00:00
#### fallback_delay
在生成 RFC 6555 快速回退连接之前等待的时间长度。
2024-11-12 11:37:10 +00:00
对于 `domain_strategy`,是在假设之前等待 IPv6 成功的时间量如果设置了 "prefer_ipv4",则 IPv6 配置错误并回退到 IPv4。
对于 `network_strategy`,对于 `network_strategy`,是在回退到其他接口之前等待连接成功的时间。
仅当 `domain_strategy``network_strategy` 已设置时生效。
默认使用 `300ms`