mirror of
https://github.com/isboyjc/GoProxy.git
synced 2026-05-06 20:02:54 +08:00
- Updated CHANGELOG.md to include version 0.4.1 with fixes related to sing-box, including an upgrade to version 1.13.5 and improvements in configuration validation and error logging. - Modified Dockerfile to reflect the new sing-box version. - Enhanced error handling in the sing-box startup process, including configuration checks and stderr logging for better diagnostics.
197 lines
8.6 KiB
Markdown
197 lines
8.6 KiB
Markdown
# 更新日志
|
||
|
||
所有重要的项目变更都会记录在此文件中。
|
||
|
||
格式基于 [Keep a Changelog](https://keepachangelog.com/zh-CN/1.0.0/),
|
||
版本号遵循 [语义化版本 2.0.0](https://semver.org/lang/zh-CN/)。
|
||
|
||
## [v0.4.1] - 2026-04-04
|
||
|
||
### 修复
|
||
|
||
- 升级 sing-box 从 1.11.8 到 **1.13.5**,修复 anytls 等新协议不支持导致订阅节点启动失败的问题
|
||
- sing-box 启动前新增 `sing-box check` 配置预检,配置无效时输出详细错误而非静默崩溃
|
||
- 捕获 sing-box stderr 输出到 `[sing-box]` 日志,便于排查运行时错误
|
||
- 检测 sing-box 进程启动后立即退出的情况,避免误报"端口未就绪"
|
||
- Docker healthcheck 从 `wget` 改为 `curl`(debian-slim 无 wget),Dockerfile 增加 curl 安装
|
||
- 修复 `docker-compose.dokploy.yml` 服务未加入 `dokploy-network` 的问题
|
||
- 修复中英文切换时订阅池统计模块动态文字未更新的问题
|
||
|
||
## [v0.4.0] - 2026-04-04
|
||
|
||
### 新增
|
||
|
||
- **订阅代理导入**
|
||
- 支持通过 WebUI 添加 Clash/V2ray 订阅 URL 或上传配置文件
|
||
- 格式全自动识别:Clash YAML、V2ray 链接(vmess/vless/trojan/ss/hysteria2/anytls)、Base64 编码、纯文本
|
||
- 内置 sing-box 协议转换:加密协议节点自动转为本地 SOCKS5 代理,Docker 镜像自带 sing-box 二进制
|
||
- 订阅定时刷新:可配置刷新间隔,自动拉取最新节点并替换旧节点
|
||
- 添加订阅时先验证(拉取+解析通过后才入库),失败不产生垃圾数据
|
||
|
||
- **订阅代理保护机制**
|
||
- 软删除:订阅代理健康检查失败不删除只禁用(`status='disabled'`)
|
||
- 探测唤醒:定时探测禁用的订阅代理,恢复可用后自动启用
|
||
- 地理过滤全局化:免费代理删除、订阅代理禁用,探测唤醒时也检查地理规则
|
||
- 自动清理:连续 7 天无可用节点的订阅自动移除
|
||
|
||
- **5 种代理使用模式**
|
||
- 混合·订阅优先:优先使用订阅代理,无可用时降级到免费
|
||
- 混合·免费优先:优先使用免费代理,无可用时降级到订阅
|
||
- 混合·平等:不区分来源,按延迟/随机选择
|
||
- 仅订阅代理:只使用订阅导入的代理
|
||
- 仅免费代理:只使用公开抓取的代理
|
||
|
||
- **访客贡献订阅**
|
||
- 未登录用户可通过「贡献订阅」入口提交订阅 URL 或上传配置文件
|
||
- 提交前自动验证,通过后才入库
|
||
- 管理员可刷新、暂停、删除贡献的订阅
|
||
- 贡献订阅在列表中有橙色「贡献」标记
|
||
|
||
- **WebUI 增强**
|
||
- 免费池 / 订阅池分离展示,各自独立统计
|
||
- 订阅管理面板:订阅列表(名称 + 可用数 + 禁用数)、添加/刷新/暂停/删除
|
||
- 代理列表中订阅代理带黄色标签显示所属订阅名称 + 左侧黄色竖线
|
||
- 系统设置从侧边栏移至顶部齿轮图标,重组为:代理模式 → 免费池 → 订阅池 → 验证检查 → 地理过滤
|
||
- 新增 ~70 个 i18n 翻译 key,覆盖所有新增 UI 元素
|
||
|
||
- **代理使用统计**
|
||
- HTTP/SOCKS5 代理服务在请求成功/失败时记录使用次数(`RecordProxyUse`)
|
||
|
||
### 变更
|
||
|
||
- `Proxy` 结构体新增 `Source`(free/custom)和 `SubscriptionID` 字段
|
||
- `Count()`/`CountByProtocol()` 仅统计免费代理(slot 计算不受订阅代理影响)
|
||
- 批量删除方法(`DeleteInvalid`/`DeleteBlockedCountries`/`DeleteNotAllowedCountries`/`DeleteWithoutExitInfo`)仅作用于免费代理
|
||
- `GetWorstProxies` 排除订阅代理,优化器不替换订阅代理
|
||
- Dockerfile 集成 sing-box 二进制(自动检测 amd64/arm64 架构)
|
||
|
||
### 修复
|
||
|
||
- 修复 `AddProxy` 未显式设置 `source='free'` 的问题
|
||
- 修复 WebUI「刷新代理」「刷新延迟」对订阅代理执行硬删除的问题(改为禁用)
|
||
- 修复 `validateCustomProxies` 将所有代理硬编码为 socks5 协议导致 HTTP 直连代理验证失败
|
||
- 修复 `CustomPriority` 和 `CustomFreePriority` 可同时为 true 的互斥问题
|
||
|
||
## [v0.3.0] - 2026-04-01
|
||
|
||
### 新增
|
||
|
||
- **地理过滤增强**
|
||
- 支持国家白名单(`ALLOWED_COUNTRIES`)和黑名单(`BLOCKED_COUNTRIES`)配置
|
||
- 白名单优先级高于黑名单:白名单非空时仅允许指定国家,否则使用黑名单屏蔽
|
||
- 支持通过环境变量、配置文件、WebUI 动态配置地理过滤规则
|
||
- 启动时自动清理违反当前过滤规则的已入池代理
|
||
- 详细文档:`GEO_FILTER.md`
|
||
|
||
- **项目指南文档**
|
||
- 新增 `CLAUDE.md`,提供项目架构、设计模式、代码规范的完整指导
|
||
- 包含模块依赖流程图、后台协程说明、端口映射表等
|
||
|
||
- **HTTPS 可用性验证增强**
|
||
- HTTP 协议代理入池前增加 HTTPS CONNECT 隧道验证
|
||
- 随机访问真实 HTTPS 网站(Google/GitHub/OpenAI 等)确认可用性
|
||
- 失败自动切换验证站点重试,确保入池的 HTTP 代理都能访问 HTTPS
|
||
- 新增测试脚本:`test/test_http_https.sh` 用于持续测试 HTTPS 访问能力
|
||
|
||
### 变更
|
||
|
||
- 默认 HTTP 协议占比从 50% 调整为 30%(配置 `PoolHTTPRatio: 0.3`)
|
||
- 地理过滤配置优先级:`config.json` > 环境变量
|
||
- WebUI 地理过滤设置界面支持动态修改白名单/黑名单
|
||
|
||
### 修复
|
||
|
||
- 修复地理过滤在验证器和存储层的逻辑一致性问题
|
||
- 修复启动时地理过滤清理逻辑,正确处理白名单优先场景
|
||
- 修复代理池补充逻辑:当 HTTP 和 SOCKS5 协议都缺失时,同时补充两个协议,而非先后补充
|
||
- 修复槽位计算问题:调整默认配置比例为 0.3(3:7),符合 HTTP/SOCKS5 实际使用场景
|
||
|
||
## [v0.2.0] - 2026-03-30
|
||
|
||
### 新增
|
||
|
||
- **SOCKS5 协议支持**
|
||
- 实现完整的 SOCKS5 代理服务器(支持 CONNECT 命令)
|
||
- 提供两个 SOCKS5 端口:`:7779`(随机轮换)+ `:7780`(最低延迟)
|
||
- SOCKS5 服务仅使用 SOCKS5 上游代理,避免 HTTP 代理不支持 CONNECT 的问题
|
||
- 协议并发验证:SOCKS5 和 HTTP 分组并发验证,SOCKS5 无额外检测,优先填充
|
||
- 新增测试脚本:`test/test_socks5.sh` 用于测试 SOCKS5 代理
|
||
|
||
- **配置增强**
|
||
- 新增 `SOCKS5Port` 和 `StableSOCKS5Port` 配置项
|
||
- 支持通过环境变量配置 SOCKS5 端口
|
||
- 优化代理池槽位分配逻辑,支持 HTTP/SOCKS5 比例配置
|
||
|
||
### 变更
|
||
|
||
- 存储层新增协议筛选方法 `CountByProtocol`、`GetRandomByProtocol`、`GetLowestLatencyByProtocol`
|
||
- 代理池管理器适配双协议槽位计算
|
||
- Docker Compose 配置新增 SOCKS5 端口映射
|
||
|
||
## [v0.1.0] - 2026-03-29
|
||
|
||
### 新增
|
||
|
||
- **代理认证功能**
|
||
- HTTP 和 SOCKS5 代理服务支持可选的用户名密码认证
|
||
- 环境变量配置:`PROXY_AUTH_ENABLED`、`PROXY_AUTH_USERNAME`、`PROXY_AUTH_PASSWORD`
|
||
- 默认关闭,开启后可保护代理服务不被未授权访问
|
||
|
||
- **环境变量支持**
|
||
- `WEBUI_PASSWORD`:自定义 WebUI 管理密码(默认 `goproxy`)
|
||
- `DATA_DIR`:自定义数据目录路径(默认当前目录)
|
||
- `BLOCKED_COUNTRIES`:屏蔽特定国家的代理(如 `CN,RU,KP`)
|
||
|
||
- **数据目录集中管理**
|
||
- 支持通过 `DATA_DIR` 环境变量指定数据存储位置
|
||
- 配置文件 `config.json` 和数据库 `proxy.db` 统一存放在数据目录
|
||
|
||
- **智能抓取机制**
|
||
- 智能状态监控:Healthy / Warning / Critical / Emergency 四级状态
|
||
- 按需抓取:根据池子状态自动选择合适的抓取模式
|
||
- 源断路器:连续失败的代理源自动降级或禁用,冷却后恢复
|
||
|
||
- **WebUI 增强**
|
||
- 实时日志流显示:支持查看最近 1000 条系统日志
|
||
- 代理质量分布图表:S/A/B/C 各等级代理数量可视化
|
||
- 延迟趋势图:HTTP 和 SOCKS5 平均延迟变化趋势
|
||
|
||
### 变更
|
||
|
||
- 验证超时从 8 秒增加到 10 秒,适应较慢的代理网络
|
||
- 健康检查批次大小从 10 个增加到 20 个,提高检查效率
|
||
- 优化配置参数命名,统一使用 `MaxLatency` 前缀
|
||
|
||
### 文档
|
||
|
||
- 完善 README.md,新增快速导航、Docker 部署、测试指南等章节
|
||
- 新增 `.env.example` 示例环境变量文件
|
||
- 更新 Docker Compose 配置示例
|
||
- 新增 GitHub Container Registry 镜像源说明
|
||
|
||
## [v0.0.1] - 2026-03-27
|
||
|
||
### 新增
|
||
|
||
- 项目初始化
|
||
- 基础 HTTP 代理池功能
|
||
- WebUI 管理界面
|
||
- SQLite 数据持久化
|
||
- 代理验证和健康检查
|
||
- Docker 支持
|
||
|
||
---
|
||
|
||
## 版本说明
|
||
|
||
- **主版本号**:不兼容的 API 变更
|
||
- **次版本号**:向下兼容的功能新增
|
||
- **修订号**:向下兼容的问题修复
|
||
|
||
## 相关链接
|
||
|
||
- [项目仓库](https://github.com/isboyjc/GoProxy)
|
||
- [Docker Hub](https://hub.docker.com/r/isboyjc/goproxy)
|
||
- [GitHub Container Registry](https://github.com/isboyjc/GoProxy/pkgs/container/goproxy)
|
||
- [问题反馈](https://github.com/isboyjc/GoProxy/issues)
|