sing-box常见问题排查:99%的用户都会遇到的坑

sing-box常见问题排查:99%的用户都会遇到的坑

【免费下载链接】sing-box The universal proxy platform 【免费下载链接】sing-box 项目地址: https://gitcode.com/GitHub_Trending/si/sing-box

引言

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"错误排查

当出现连接拒绝错误时,通常有以下三种可能:

  1. 服务未启动:检查sing-box进程是否正常运行
  2. 端口被占用:使用netstat -tulpn | grep sing-box查看端口占用情况
  3. 防火墙拦截:确保系统防火墙允许对应端口通信

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 日志级别配置

日志级别从低到高分为:tracedebuginfowarnerrorfatal。默认级别为info,排查问题时建议设为debug

配置示例:

{
  "log": {
    "level": "debug",
    "output": "sing-box.log",
    "timestamp": true
  }
}

日志工厂实现见log/factory.go,可通过log/level.go查看详细的日志级别定义。

3.2 关键错误日志解析

错误关键词可能原因解决方案
invalid configJSON语法错误或字段缺失使用sing-box check验证配置
failed to dial网络连接问题检查目标服务器可达性
certificate verify failedTLS证书问题配置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

六、总结与社区支持

遇到本文未覆盖的问题时,可通过以下途径获取帮助:

  1. 查阅官方完整文档:docs/
  2. 检查现有GitHub Issues(搜索关键词)
  3. 提交新Issue时务必附上详细日志和配置文件

通过系统的排查流程和工具链,绝大多数sing-box问题都能在几分钟内定位并解决。记住:详细的日志是排查问题的关键,善用sing-box check和调试模式可以大幅提高排障效率。

【免费下载链接】sing-box The universal proxy platform 【免费下载链接】sing-box 项目地址: https://gitcode.com/GitHub_Trending/si/sing-box

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值