# CHANGELOG ## v1.0.10 (2026-05-09) - **API Redesign (Elegant API)**: - 引入包级泛型便捷调用:`Get[T]`, `Post[T]`, `Put[T]`, `Delete[T]`。 - 引入 `From(r *http.Request)` 包装器,优雅实现微服务 Header 自动透传。 - 统一 API 入口,区分服务端(`Start`/`Stop`)与客户端(`Get`/`Post`/`Do`)模式。 - 移除晦涩的 `CallT` 泛型辅助函数。 - 增加 `SetApp`, `SetRegistry`, `SetWeight` 便捷配置接口。 - **Infrastructure Alignment**: - 耗时统计切换至 `go/timer` 高性能引擎。 - 服务令牌(Token)采用 `go/safe.SafeBuf` 内存安全保护。 - 依赖更新:`go/http` 升级至 `v1.0.10`。 - **Stability**: - 优化 `Stop()` 逻辑:彻底重置实例状态,支持在单进程多次启动/停止(如单元测试场景)。 - 优化 `Init()` 逻辑:支持程序化配置与文件配置的智能合并。 - 修复 `AddExternalApp` 可能导致的订阅死锁问题。 ## v1.0.9 (2026-05-05) - **Stability & Testing**: - 修复 `AddExternalApp` 在新客户端场景下可能遗漏同步拉取节点的问题。 - 优化测试用例性能:将 Mock Server 默认超时导致的 100s 阻塞通过强制 HTTP/1.1 配置解决。 - 增强测试健壮性:全面改用动态端口(Port 0)避开冲突,并利用 Redis URL 唯一 ID 隔离多实例间的 PubSub 干扰。 - 改进守护进程退出逻辑:使用 `select` 非阻塞模式确保 `Stop()` 后能立即响应并优雅关闭。 ## v1.0.4 (2026-05-05) - 稳定性增强:在 `addApp` 中引入“写时复制”(Copy-on-Write)机制,通过对配置 Map 进行深拷贝,彻底消除了高并发下配置读取与修改导致的 `concurrent map read and map write` 崩溃风险。 - 状态一致性优化:确保默认实例在动态添加应用后,能够同步更新包级别的全局 `Config` 变量,保证业务代码通过不同路径读取配置的一致性。 ## v1.0.3 (2026-05-05) - 架构深度优化:将 HTTP 客户端连接池(`appClientPools`)移入 `Discoverer` 实例,实现完全的资源隔离。 - 并发安全增强:引入读写锁保护 `Config` 结构,防止高并发下的配置读写冲突。 - 生命周期管理优化:使用 `atomic.Bool` 管理 `daemonRunning` 状态,确保线程安全。 - 资源回收机制:在 `Stop()` 方法中新增 HTTP 连接池清理逻辑(调用 `Destroy` 释放闲置连接),防止内存与句柄泄漏。 - 接口严谨性:将 `Discoverer` 内部字段(如 `config`)设为私有,通过 `GetConfig`/`SetConfig` 统一访问。 ## v1.0.2 - 架构重构:支持多 Discoverer 实例,消灭包级全局状态。 - 兼容性:保留包级 API 转发至 `DefaultDiscoverer`。 ## v1.0.1 - 优化代码规范:修复变量名冲突,改进命名语义。 - 性能优化:优化 `AppClient` 类型,减少寻址开销。 - 故障隔离:实现本地隔离机制,不再篡跨全局 Redis 状态。 - 压力缓解:心跳间隔优化至 5 秒。 ## v1.0.0 - 初始版本:从 `ssgo/discover` 迁移并重构。