2024-11-12 14:57:15 +00:00
---
icon: material/new-box
---
!!! quote "Changes in sing-box 1.11.0"
:material-plus: [network_strategy ](#network_strategy )
2024-11-13 13:42:00 +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 14:57:15 +00:00
2022-08-31 04:50:26 +00:00
### Structure
```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 14:57:15 +00:00
"network_strategy": "default",
2024-11-13 13:42:00 +00:00
"network_type": [],
"fallback_network_type": [],
2022-08-31 04:50:26 +00:00
"fallback_delay": "300ms"
}
```
2024-11-13 13:42:00 +00:00
!!! note ""
You can ignore the JSON Array [] tag when the content is only one item
2022-08-31 04:50:26 +00:00
### Fields
#### detour
The tag of the upstream outbound.
2024-11-12 14:57:15 +00:00
If enabled, all other fields will be ignored.
2022-08-31 04:50:26 +00:00
#### bind_interface
The network interface to bind to.
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
The IPv4 address to bind to.
#### inet6_bind_address
The IPv6 address to bind to.
2022-08-31 04:50:26 +00:00
#### routing_mark
2023-11-09 09:04:08 +00:00
!!! quote ""
2022-08-31 04:50:26 +00:00
Only supported on Linux.
Set netfilter routing mark.
#### reuse_addr
Reuse listener address.
2022-09-09 07:40:35 +00:00
#### tcp_fast_open
Enable TCP Fast Open.
2023-08-08 08:14:03 +00:00
#### tcp_multi_path
!!! warning ""
Go 1.21 required.
Enable TCP Multi Path.
2022-09-09 07:40:35 +00:00
#### udp_fragment
Enable UDP fragmentation.
2022-08-31 04:50:26 +00:00
#### connect_timeout
Connect timeout, in golang's Duration format.
A duration string is a possibly signed sequence of
decimal numbers, each with optional fraction and a unit suffix,
such as "300ms", "-1.5h" or "2h45m".
Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h".
#### domain_strategy
2024-11-12 14:57:15 +00:00
Available values: `prefer_ipv4` , `prefer_ipv6` , `ipv4_only` , `ipv6_only` .
2022-08-31 04:50:26 +00:00
If set, the requested domain name will be resolved to IP before connect.
2022-09-03 05:02:41 +00:00
| Outbound | Effected domains | Fallback Value |
|----------|--------------------------|-------------------------------------------|
| `direct` | Domain in request | Take `inbound.domain_strategy` if not set |
| others | Domain in server address | / |
2022-08-31 04:50:26 +00:00
2024-11-12 14:57:15 +00:00
#### network_strategy
!!! question "Since sing-box 1.11.0"
!!! quote ""
2024-11-13 13:42:00 +00:00
Only supported in graphical clients on Android and Apple platforms with `auto_detect_interface` enabled.
2024-11-12 14:57:15 +00:00
Strategy for selecting network interfaces.
Available values:
2024-11-13 13:42:00 +00:00
- `default` (default): Connect to default network or networks specified in `network_type` sequentially.
- `hybrid` : Connect to all networks or networks specified in `network_type` concurrently.
- `fallback` : Connect to default network or preferred networks specified in `network_type` concurrently, and try fallback networks when unavailable or timeout.
2024-11-12 14:57:15 +00:00
2024-11-13 13:42:00 +00:00
For fallback, when preferred interfaces fails or times out,
it will enter a 15s fast fallback state (Connect to all preferred and fallback networks concurrently),
and exit immediately if preferred networks recover.
2024-11-12 14:57:15 +00:00
Conflicts with `bind_interface` , `inet4_bind_address` and `inet6_bind_address` .
2024-11-13 13:42:00 +00:00
#### network_type
!!! question "Since sing-box 1.11.0"
!!! quote ""
Only supported in graphical clients on Android and Apple platforms with `auto_detect_interface` enabled.
Network types to use when using `default` or `hybrid` network strategy or
preferred network types to use when using `fallback` network strategy.
Available values: `wifi` , `cellular` , `ethernet` , `other` .
Device's default network is used by default.
#### fallback_network_type
!!! question "Since sing-box 1.11.0"
!!! quote ""
Only supported in graphical clients on Android and Apple platforms with `auto_detect_interface` enabled.
Fallback network types when preferred networks are unavailable or timeout when using `fallback` network strategy.
All other networks expect preferred are used by default.
2022-08-31 04:50:26 +00:00
#### fallback_delay
2024-11-13 13:42:00 +00:00
!!! question "Since sing-box 1.11.0"
!!! quote ""
Only supported in graphical clients on Android and Apple platforms with `auto_detect_interface` enabled.
2022-08-31 04:50:26 +00:00
The length of time to wait before spawning a RFC 6555 Fast Fallback connection.
2024-11-12 14:57:15 +00:00
For `domain_strategy` , is the amount of time to wait for connection to succeed before assuming
2022-09-03 05:02:41 +00:00
that IPv4/IPv6 is misconfigured and falling back to other type of addresses.
2022-08-31 04:50:26 +00:00
2024-11-12 14:57:15 +00:00
For `network_strategy` , is the amount of time to wait for connection to succeed before falling
back to other interfaces.
Only take effect when `domain_strategy` or `network_strategy` is set.
`300ms` is used by default.