sing-box常见问题排查:99%的用户都会遇到的坑
引言
sing-box作为一款功能强大的通用代理平台(The universal proxy platform),在使用过程中难免会遇到各种问题。本文将针对用户最常遇到的配置错误、连接失败、日志分析等问题提供系统性的排查方案,帮助你快速定位并解决99%的常见故障。官方配置文档可参考docs/configuration/index.zh.md。
一、配置文件错误:新手最容易踩的坑
1.1 JSON格式校验失败
配置文件采用JSON格式,任何语法错误都会导致启动失败。典型错误包括缺少逗号、引号不匹配或括号未闭合。
解决方法:使用官方提供的配置检查工具:
sing-box check -c config.json
该命令会验证配置文件的语法正确性,对应源码实现见box.go中的New函数,它会在初始化阶段解析并验证配置。
1.2 必选字段缺失
sing-box配置有严格的结构要求,缺少必选字段会触发明确的错误提示。例如入站(inbounds)和出站(outbounds)配置是核心必填项。
常见错误示例:
{
"inbounds": [], // 缺少具体入站配置
"outbounds": [] // 缺少具体出站配置
}
正确配置参考:
{
"inbounds": [
{
"type": "socks",
"listen": "127.0.0.1",
"port": 1080
}
],
"outbounds": [
{
"type": "direct"
}
]
}
完整配置结构说明见docs/configuration/index.zh.md。
二、连接失败:网络问题的诊断流程
2.1 "Connection refused"错误排查
当出现连接拒绝错误时,通常有以下三种可能:
- 服务未启动:检查sing-box进程是否正常运行
- 端口被占用:使用
netstat -tulpn | grep sing-box查看端口占用情况 - 防火墙拦截:确保系统防火墙允许对应端口通信
2.2 超时问题(Timeout)
超时错误通常与网络延迟或目标服务器不可达有关。可通过以下方式定位:
增加日志 verbosity 级别: 在配置文件中设置详细日志:
{
"log": {
"level": "debug",
"timestamp": true
}
}
日志系统实现见log/目录下的相关文件,调试模式下会输出详细的网络交互过程。
启用调试HTTP服务器:
sing-box内置调试HTTP服务,可通过源码debug_http.go中的ServeDebugHTTP函数启用,访问http://127.0.0.1:9090/debug查看实时连接状态。
三、日志分析:故障排查的核心工具
3.1 日志级别配置
日志级别从低到高分为:trace、debug、info、warn、error、fatal。默认级别为info,排查问题时建议设为debug。
配置示例:
{
"log": {
"level": "debug",
"output": "sing-box.log",
"timestamp": true
}
}
日志工厂实现见log/factory.go,可通过log/level.go查看详细的日志级别定义。
3.2 关键错误日志解析
| 错误关键词 | 可能原因 | 解决方案 |
|---|---|---|
invalid config |
JSON语法错误或字段缺失 | 使用sing-box check验证配置 |
failed to dial |
网络连接问题 | 检查目标服务器可达性 |
certificate verify failed |
TLS证书问题 | 配置insecure: true临时绕过(生产环境不建议) |
address already in use |
端口冲突 | 更换监听端口或终止占用进程 |
四、高级调试:开发者模式技巧
4.1 启用内存调试
通过设置调试选项可以监控内存使用情况,相关代码见debug.go:
debug.SetGCPercent(100) // 调整GC频率
debug.SetMaxStack(1 << 20) // 设置最大栈大小
debug.SetMemoryLimit(1 << 30) // 设置内存限制
4.2 运行时调试HTTP服务
启用内置的调试HTTP服务器:
sing-box run -c config.json --debug http://127.0.0.1:6060
实现代码见debug_http.go,启动后可访问/debug/pprof查看性能分析数据。
五、常见问题速查表
5.1 启动问题
| 症状 | 检查项 | 参考文档 |
|---|---|---|
| 进程立即退出 | 日志文件权限、配置格式 | docs/configuration/index.zh.md |
| 无任何输出 | 日志级别设置过高 | log/level.go |
| 权限错误 | 监听端口是否需要root权限 | constant/os.go |
5.2 网络问题
| 症状 | 检查项 | 参考代码 |
|---|---|---|
| 所有网站无法访问 | 路由规则配置、DNS设置 | route/router.go |
| 部分网站无法访问 | 分流规则错误 | rule/conds.go |
| 速度慢 | 启用mux多路复用 | common/mux/client.go |
六、总结与社区支持
遇到本文未覆盖的问题时,可通过以下途径获取帮助:
- 查阅官方完整文档:docs/
- 检查现有GitHub Issues(搜索关键词)
- 提交新Issue时务必附上详细日志和配置文件
通过系统的排查流程和工具链,绝大多数sing-box问题都能在几分钟内定位并解决。记住:详细的日志是排查问题的关键,善用sing-box check和调试模式可以大幅提高排障效率。
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5-w4a8GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术,结合vLLM推理优化,高效平衡性能与精度,助力智能应用开发Jinja00
请把这个活动推给顶尖程序员😎本次活动专为懂行的顶尖程序员量身打造,聚焦AtomGit首发开源模型的实际应用与深度测评,拒绝大众化浅层体验,邀请具备扎实技术功底、开源经验或模型测评能力的顶尖开发者,深度参与模型体验、性能测评,通过发布技术帖子、提交测评报告、上传实践项目成果等形式,挖掘模型核心价值,共建AtomGit开源模型生态,彰显顶尖程序员的技术洞察力与实践能力。00
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
MiniMax-M2.5MiniMax-M2.5开源模型,经数十万复杂环境强化训练,在代码生成、工具调用、办公自动化等经济价值任务中表现卓越。SWE-Bench Verified得分80.2%,Multi-SWE-Bench达51.3%,BrowseComp获76.3%。推理速度比M2.1快37%,与Claude Opus 4.6相当,每小时仅需0.3-1美元,成本仅为同类模型1/10-1/20,为智能应用开发提供高效经济选择。【此简介由AI生成】Python00
Qwen3.5Qwen3.5 昇腾 vLLM 部署教程。Qwen3.5 是 Qwen 系列最新的旗舰多模态模型,采用 MoE(混合专家)架构,在保持强大模型能力的同时显著降低了推理成本。00- RRing-2.5-1TRing-2.5-1T:全球首个基于混合线性注意力架构的开源万亿参数思考模型。Python00