ShellCrash 搭载 sing-boxp 内核本地配置自定义出站和规则-geodata 方案
此方案适用于 sing-box,搭载 sing-boxp 内核,采用 `geosite` 和 `geoip` 规则搭配 geosite.db 和 geoip.db 路由规则文件
说明
- 本教程只适用于 ShellCrash
- 本教程仅适合白名单模式(没有命中规则的网络流量统统使用代理,适用于服务器线路网络质量稳定、快速,不缺服务器流量的用户)
- 本教程最终效果媲美《生成带有自定义出站和规则的 sing-boxp 配置文件直链-geodata 方案》(出站分组更直观,操作更方便)
- 若仅配置自定义出站和规则,可直接跳过《二》
- 出站提供者 outbound_providers.json、出站 outbounds.json 和规则 route.json 为合并模式(在基础配置上新增)
- 所有步骤完成后,请连接 SSH 后执行命令
$CRASHDIR/start.sh restart
生效 - 推荐使用 Visual Studio Code 等专业编辑器来修改配置文件
一、 导入 sing-box PuerNya 版内核和路由规则文件
可参考《ShellCrash 搭载 sing-boxp 内核的配置-geodata 方案》里的《一》和《二》进行操作
二、 导入配置文件
进入 ShellCrash → 6 导入配置文件 → 1 在线生成 singbox 配置文件 → 4 选取在线配置规则模版,选择 4 ACL4SSR 极简版(适合自建节点)
进入 ShellCrash → 6 导入配置文件 → 1 在线生成 singbox 配置文件,输入订阅链接后回车,再输入
1
并回车即可
三、 自定义出站和规则
1. 自定义出站提供者 outbound_providers.json(用于添加自定义出站提供者 outbound_providers
)
- ① 连接 SSH 后执行命令
mkdir -p $CRASHDIR/providers/
- 注:因出站提供者
outbound_providers
配置的path
路径中含有文件夹providers
,须手动新建此文件夹才能使 .json 订阅文件保存到本地,否则将保存到内存中(每次启动服务都要重新下载)
- 注:因出站提供者
② 继续执行命令
vi $CRASHDIR/jsons/outbound_providers.json
,按一下 Ins 键(Insert 键),编辑如下内容并粘贴:1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45
{ // 出站提供者(获取机场订阅链接内的所有节点) "outbound_providers": [ { "tag": "🛫 我的机场 1", "type": "remote", // 机场订阅链接,使用 Clash 链接 "download_url": "https://example.com/xxx/xxx&flag=clash", "path": "./providers/airport1.yaml", "download_interval": "24h", "download_ua": "clash.meta", // 初步筛选需要的节点,可有效减轻路由器压力,支持正则表达式,若不筛选可删除此配置项 "includes": [ "(?i)港|hk|hongkong|hong kong|台|tw|taiwan|日本|jp|japan|新|sg|singapore|美|us|unitedstates|united states" ], // 初步排除不需要的节点,支持正则表达式,若不排除可删除此配置项 "excludes": "高倍|直连|×10", "healthcheck_url": "https://www.gstatic.com/generate_204", "healthcheck_interval": "10m", "outbound_override": { // 设置出站标签的前缀,如出站标签原为“香港节点”会变成“🛫 我的机场 1-香港节点”;推荐有多个机场时使用 "tag_prefix": "🛫 我的机场 1-", // 设置出站标签的后缀,如出站标签原为“香港节点”会变成“香港节点-🛫 我的机场 1”;推荐有多个机场时使用 "tag_suffix": "-🛫 我的机场 1" } }, { "tag": "🛫 我的机场 2", "type": "remote", // 机场订阅链接,使用 sing-box 链接 "download_url": "https://example.com/xxx/xxx", "path": "./providers/airport2.json", "download_interval": "24h", "download_ua": "sing-box", "includes": [ "(?i)港|hk|hongkong|hong kong|台|tw|taiwan|日本|jp|japan|新|sg|singapore|美|us|unitedstates|united states" ], "excludes": "高倍|直连|×10", "healthcheck_url": "https://www.gstatic.com/generate_204", "healthcheck_interval": "10m", "outbound_override": { // 设置出站标签的前缀,如出站标签原为“香港节点”会变成“🛫 我的机场 2-香港节点”;推荐有多个机场时使用 "tag_prefix": "🛫 我的机场 2-", // 设置出站标签的后缀,如出站标签原为“香港节点”会变成“香港节点-🛫 我的机场 2”;推荐有多个机场时使用 "tag_suffix": "-🛫 我的机场 2" } } ] }
按一下 Esc 键(退出键),输入英文冒号
:
,继续输入wq
并回车
2. 自定义出站 outbounds.json(用于添加自定义出站 outbounds
)
连接 SSH 后执行命令 vi $CRASHDIR/jsons/outbounds.json
,按一下 Ins 键(Insert 键),编辑如下内容并粘贴:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
{
// 出站
"outbounds": [
// 手动选择国家或地区节点;根据“国家或地区出站”的名称对 `outbounds` 值进行增删改,须一一对应
{ "tag": "🈯 节点指定", "type": "selector", "outbounds": [ "🇭🇰 香港节点", "🇹🇼 台湾节点", "🇯🇵 日本节点", "🇸🇬 新加坡节点", "🇺🇸 美国节点", "🆓 免费节点" ] },
// 选择`🎯 全球直连`为测试本地网络(运营商网络速度和 IPv6 支持情况),可选择其它节点用于测试机场节点速度和 IPv6 支持情况
{ "tag": "📈 网络测试", "type": "selector", "outbounds": [ "🎯 全球直连", "🇭🇰 香港节点", "🇹🇼 台湾节点", "🇯🇵 日本节点", "🇸🇬 新加坡节点", "🇺🇸 美国节点", "🆓 免费节点" ] },
{ "tag": "🎮 游戏服务", "type": "selector", "outbounds": [ "🎯 全球直连", "🈯 节点指定" ] },
{ "tag": "🪟 微软服务", "type": "selector", "outbounds": [ "🎯 全球直连", "🈯 节点指定" ] },
{ "tag": "🇬 谷歌服务", "type": "selector", "outbounds": [ "🎯 全球直连", "🈯 节点指定" ] },
{ "tag": "🍎 苹果服务", "type": "selector", "outbounds": [ "🎯 全球直连", "🈯 节点指定" ] },
{ "tag": "🇨🇳 直连域名", "type": "selector", "outbounds": [ "🎯 全球直连", "🈯 节点指定" ] },
{ "tag": "🇨🇳 直连 IP", "type": "selector", "outbounds": [ "🎯 全球直连", "🈯 节点指定" ] },
{ "tag": "🧱 代理域名", "type": "selector", "outbounds": [ "🈯 节点指定", "🎯 全球直连" ] },
{ "tag": "📲 电报信息", "type": "selector", "outbounds": [ "🈯 节点指定" ] },
{ "tag": "🔒 私有网络", "type": "selector", "outbounds": [ "🎯 全球直连" ] },
{ "tag": "🛑 广告拦截", "type": "selector", "outbounds": [ "REJECT" ] },
// 单个出站节点(以 vless 为例)
{
"tag": "🆓 免费节点",
"type": "vless",
"server": "example.com",
"server_port": 443,
"uuid": "{uuid}",
"network": "tcp",
"tls": { "enabled": true, "server_name": "example.com", "insecure": false },
"transport": { "type": "ws", "path": "/?ed=2048", "headers": { "Host": "example.com" } }
},
// -------------------- 国家或地区出站 --------------------
// 自动选择节点,即按照 url 测试结果使用延迟最低的节点;测试后容差大于 50ms 才会切换到延迟低的那个节点;筛选出“香港”节点,支持正则表达式
{ "tag": "🇭🇰 香港节点", "type": "urltest", "tolerance": 50, "use_all_providers": true, "includes": [ "(?i)港|hk|hongkong|hong kong" ] },
{ "tag": "🇹🇼 台湾节点", "type": "urltest", "tolerance": 50, "use_all_providers": true, "includes": [ "(?i)台|tw|taiwan" ] },
{ "tag": "🇯🇵 日本节点", "type": "urltest", "tolerance": 50, "use_all_providers": true, "includes": [ "(?i)日本|jp|japan" ] },
{ "tag": "🇸🇬 新加坡节点", "type": "urltest", "tolerance": 50, "use_all_providers": true, "includes": [ "(?i)新|sg|singapore" ] },
{ "tag": "🇺🇸 美国节点", "type": "urltest", "tolerance": 50, "use_all_providers": true, "includes": [ "(?i)美|us|unitedstates|united states" ] }
]
}
按一下 Esc 键(退出键),输入英文冒号 :
,继续输入 wq
并回车
3. 自定义规则 route.json(用于添加自定义路由和规则 route
)
连接 SSH 后执行命令 vi $CRASHDIR/jsons/route.json
,按一下 Ins 键(Insert 键),编辑如下内容并粘贴:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
{
// 路由
"route": {
// 规则
"rules": [
// 自定义规则优先放前面
{ "geosite": [ "private" ], "outbound": "🔒 私有网络" },
{ "geosite": [ "ads" ], "outbound": "🛑 广告拦截" },
{ "geosite": [ "microsoft-cn" ], "outbound": "🪟 微软服务" },
{ "geosite": [ "apple-cn" ], "outbound": "🍎 苹果服务" },
{ "geosite": [ "google-cn" ], "outbound": "🇬 谷歌服务" },
{ "geosite": [ "games-cn" ], "outbound": "🎮 游戏服务" },
{ "geosite": [ "networktest" ], "outbound": "📈 网络测速" },
{ "geosite": [ "proxy" ], "outbound": "🧱 代理域名" },
{ "geosite": [ "cn" ], "outbound": "🇨🇳 直连域名" },
{ "geoip": [ "telegram" ], "outbound": "📲 电报信息", "skip_resolve": true },
{ "geoip": [ "private" ], "outbound": "🔒 私有网络", "skip_resolve": true },
{ "geoip": [ "cn" ], "outbound": "🇨🇳 直连 IP" }
],
// geosite 配置项
"geosite": {
"path": "./geosite.db",
"download_url": "https://cdn.jsdelivr.net/gh/DustinWin/ruleset_geodata@sing-box/geosite.db"
},
// geoip 配置项
"geoip": {
"path": "./geoip.db",
"download_url": "https://cdn.jsdelivr.net/gh/DustinWin/ruleset_geodata@sing-box/geoip.db"
},
"auto_detect_interface": true,
"concurrent_dial": true
}
}
按一下 Esc 键(退出键),输入英文冒号 :
,继续输入 wq
并回车
贴一张面板效果图(举个例子:我手动选择 🇹🇼 台湾节点
出站,而该出站是将机场内所有台湾节点按照 url 测试结果自动选择延迟最低的台湾节点):
四、 修改出站或规则
举例:我的机场包含有 2 个节点,分别是新加坡节点和日本节点,我想让 Netflix 自动选择延迟最低的新加坡节点,哔哩哔哩可以手动选择日本任一节点
一定要保证缩进对齐!一定要保证缩进对齐!一定要保证缩进对齐!
1. 修改 outbounds.json 文件
连接 SSH 后执行命令 vi $CRASHDIR/jsons/outbounds.json
,按一下 Ins 键(Insert 键),编辑如下内容并粘贴:
1
2
3
4
5
6
7
8
9
10
11
12
13
{
// 出站
"outbounds": [
// 默认选择新加坡节点
{ "tag": "🎥 奈飞视频", "type": "selector", "outbounds": [ "🇸🇬 新加坡节点" ] },
// 默认选择日本节点,也可切换到直连
{ "tag": "📺 哔哩哔哩", "type": "selector", "outbounds": [ "🇯🇵 日本节点", "🎯 全球直连" ] },
// 自动选择延迟最低的新加坡节点;容差大于 50ms 才会切换到延迟低的那个节点
{ "tag": "🇸🇬 新加坡节点", "type": "urltest", "tolerance": 50, "use_all_providers": true, "includes": [ "(?i)(新|sg|singapore)" ] },
// 手动选择日本任一节点
{ "tag": "🇯🇵 日本节点", "type": "selector", "use_all_providers": true, "includes": [ "(?i)日本|jp|japan" ] }
]
}
按一下 Esc 键(退出键),输入英文冒号 :
,继续输入 wq
并回车
2. 修改 route.json 文件
连接 SSH 后执行命令 vi $CRASHDIR/jsons/route.json
,按一下 Ins 键(Insert 键),优先在最上方编辑如下内容并粘贴:
1
2
3
4
5
6
7
8
9
10
11
12
{
// 路由
"route": {
// 规则
"rules": [
// 自定义规则优先放前面
{ "geosite": [ "netflix" ], "outbound": "🎥 奈飞视频" },
{ "geoip": [ "netflix" ], "outbound": "🎥 奈飞视频", "skip_resolve": true },
{ "geosite": [ "bilibili" ], "outbound": "📺 哔哩哔哩" }
]
}
}
按一下 Esc 键(退出键),输入英文冒号 :
,继续输入 wq
并回车
若有其它需求,可导入 MetaCubeX/meta-rules-dat 路由规则文件,并分别进入 MetaCubeX/meta-rules-dat/sing/geo 的 geosite 和 geoip 目录搜索关键字,通过能够搜索到的关键字来编写规则
五、 添加小规则
仅添加特定网址走直连或走代理,连接 SSH 后执行命令 vi $CRASHDIR/jsons/route.json
,按一下 Ins 键(Insert 键),在最上方编辑如下内容并粘贴:
注:
- ① 以下内容只是举例,请根据自身需要进行增删改
- ② 其它规则请参考《sing-box Wiki》
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
{
// 路由
"route": {
// 规则
"rules": [
// 以 googleapis.cn 为后缀(包括 googleapis.cn)的所有域名走代理
{ "domain_suffix": [ "googleapis.cn" ], "outbound": "🈯 节点指定" },
// 与哔哩哔哩相关的所有域名走直连
{ "geosite": [ "bilibili" ], "outbound": "DIRECT" },
// 含有 ipv6 关键字的所有域名走直连
{ "domain_keyword": [ "ipv6" ], "outbound": "DIRECT" }
],
// geosite 配置项
"geosite": {
"path": "./geosite.db",
"download_url": "https://cdn.jsdelivr.net/gh/DustinWin/ruleset_geodata@sing-box/geosite.db"
}
}
}
按一下 Esc 键(退出键),输入英文冒号 :
,继续输入 wq
并回车