Sing-box项目中block出站与reject规则动作的演进与解决方案
2025-05-09 19:31:27作者:彭桢灵Jeremy
背景介绍
在Sing-box项目1.11.x版本的更新中,开发团队对路由系统进行了重要调整,将原本的block出站类型替换为新的reject规则动作。这一变更虽然简化了部分配置逻辑,但也带来了一些兼容性问题,特别是与selector出站的交互方式上。
技术变更分析
旧版block出站机制
在早期版本中,Sing-box通过专门的block出站类型来实现连接阻断功能。这种方式允许用户:
- 在
selector出站中直接引用block标签 - 通过路由规则将特定流量定向到阻断出站
- 实现灵活的手动阻断控制
典型的配置示例如下:
{
"outbounds": [
{ "type": "block", "tag": "block" },
{
"type": "selector",
"tag": "ad",
"outbounds": ["block"],
"interrupt_exist_connections": true
}
]
}
新版reject规则动作
1.11.x版本引入了reject作为规则动作,直接内置于路由规则中。这种设计更符合现代网络工具的发展趋势,将阻断逻辑从出站层面提升到路由层面。
主要优势包括:
- 减少不必要的出站对象
- 简化配置结构
- 提高路由决策效率
兼容性问题
虽然新设计有其优势,但也带来了以下使用问题:
- selector兼容性问题:
selector出站无法直接引用规则动作,导致原有的手动阻断方案失效 - 配置迁移困难:用户需要重构原有的阻断逻辑
- 灵活性降低:无法在运行时通过选择器动态切换阻断状态
解决方案演进
临时解决方案
在block出站恢复前,用户可以采用以下替代方案:
- socks中转法:
{
"inbounds": [{ "type": "socks", "tag": "reject-in" }],
"outbounds": [
{ "type": "socks", "tag": "reject-out", "server": "127.0.0.1", "port": 0 },
{
"type": "selector",
"outbounds": ["reject-out"]
}
],
"route": {
"rules": [
{ "inbound": "reject-in", "action": "reject" }
]
}
}
- 规则组合法:通过多级规则实现类似效果
官方解决方案
最新版本中已恢复block出站支持,用户可以直接使用:
{
"outbounds": [
{ "type": "block", "tag": "block" },
{
"type": "selector",
"outbounds": ["block"]
}
]
}
最佳实践建议
- 新项目配置:建议优先使用
reject规则动作 - 旧项目迁移:评估是否真的需要
selector引用阻断功能,再决定是否保留block出站 - 混合使用:可以同时使用两种方式,规则动作处理固定阻断,
block出站处理动态需求
技术思考
这一变更反映了网络工具架构设计的演进趋势:
- 从"万物皆出站"到"职责分离"的转变
- 路由系统的重要性不断提升
- 配置简化与功能强大之间的平衡
未来可能会看到selector和urltest也被整合到规则动作系统中,实现更统一的路由控制模型。
总结
Sing-box项目在1.11.x版本中的这一变更虽然短期内造成了兼容性问题,但从长远看推动了配置逻辑的合理化。用户应根据实际需求选择合适的阻断方案,理解不同设计背后的技术考量,才能更好地利用这一强大的网络工具。
登录后查看全文
热门项目推荐
相关项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5-w4a8GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术,结合vLLM推理优化,高效平衡性能与精度,助力智能应用开发Jinja00
jiuwenclawJiuwenClaw 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。Python0202- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
AtomGit城市坐标计划AtomGit 城市坐标计划开启!让开源有坐标,让城市有星火。致力于与城市合伙人共同构建并长期运营一个健康、活跃的本地开发者生态。01
awesome-zig一个关于 Zig 优秀库及资源的协作列表。Makefile00
热门内容推荐
最新内容推荐
YimMenu技术指南:功能实现与安全实践[弹幕交互系统]解决[实时评论同步难题]:DPlayer状态机驱动架构实践指南openpilot数据安全指南:构建驾驶系统的备份与恢复体系旧设备如何重获新生:OpenCore Legacy Patcher系统焕新全攻略D2RML:彻底解决暗黑2重制版多账号切换难题的3个颠覆认知方案分布式存储架构在WiFi姿态估计系统中的高并发性能优化实践颠覆传统化学合成:智能合成工具AiZynthFinder的技术革命开源CAD自动化建模:FreeCAD脚本开发效率提升指南YimMenu全方位技术指南:从基础到高级应用pi-mono自定义工具开发实战指南:从入门到精通
项目优选
收起
deepin linux kernel
C
27
12
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
606
4.05 K
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
暂无简介
Dart
848
205
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.47 K
829
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
24
0
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
923
771
🎉 基于Spring Boot、Spring Cloud & Alibaba、Vue3 & Vite、Element Plus的分布式前后端分离微服务架构权限管理系统
Vue
235
152
昇腾LLM分布式训练框架
Python
130
156