lolly/CHANGELOG.md
xfy 08e6e8c003 docs: 更新 CHANGELOG 和 Dockerfile
CHANGELOG 记录 Unreleased 新功能:
- internal 指令
- limit_rate 中间件
- server_tokens 配置
- types 配置块

Dockerfile 更新版本信息路径。

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-04-20 18:09:08 +08:00

7.9 KiB
Raw Blame History

Changelog

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.

[Unreleased]

Added

  • internal 指令:防止外部直接访问特定 location支持 X-Accel-Redirect 内部重定向
  • limit_rate 中间件:响应速率限制,支持令牌桶算法和大文件回退策略
  • server_tokens 配置:控制 Server 响应头是否显示版本号
  • types 配置块:自定义 MIME 类型映射,线程安全实现

[0.2.1] - 2026-04-17

Added

核心功能

  • 多服务器模式支持,可在单个配置中定义多个独立 server
  • Location 匹配引擎,支持 nginx 风格的精确/前缀/正则匹配
  • server_name 通配符和正则匹配支持
  • Unix socket 监听支持
  • 配置引入 (include) 支持,可拆分配置到多个文件
  • 缓存清理 API 端点
  • 状态端点 HTML/Text 输出格式,支持 localhost IP 访问
  • 上游 SSL 配置,支持代理连接使用自定义证书
  • 高并发优化配置项
  • 缓存 TTL 新鲜度验证优化
  • Location/Refresh 头改写功能
  • DNS 缓存 LRU 淘汰机制

Lua 中间件系统

  • 完整 ngx API 实现ngx.var/ngx.ctx/ngx.req/ngx.resp/ngx.log
  • 共享字典 API (ngx.shared.DICT)
  • 定时器 API (ngx.timer),含线程隔离和回调限制
  • 子请求 API (ngx.location.capture)
  • Cosocket API 和响应拦截器
  • balancer_by_lua 动态负载均衡
  • Lua 脚本嵌入支持,含沙箱安全检查

安全与访问控制

  • GeoIP 国家代码访问控制
  • 符号链接安全检查
  • 静态文件处理符号链接安全检查

平台支持

  • Docker 容器化部署支持
  • Windows 平台构建和运行兼容性

可观测性

  • Prometheus 状态输出端点缓存清理 API

Changed

  • 移除旧版单 server 配置,统一使用 servers 数组格式
  • 结构体内存布局优化减少 padding
  • 提取公共模块mimeutil、sslutil、netutil、testutil
  • 使用标准库 slices/maps 替代自定义函数
  • gofumpt 替代 goimports 格式化代码
  • 禁用 govet fieldalignment 检查

Performance

  • 零拷贝字节路径减少内存分配
  • EphemeralGet/PersistentGet 零拷贝变量访问 API
  • LuaContext/协程池对象池化
  • 缓存键哈希计算零分配优化
  • 全局变量惰性加载降低每请求开销
  • 滑动窗口限流器分段锁优化并发性能
  • FileCache.Get() 锁粒度优化
  • HTTP/3 移除冗余 ctxPool 提升性能

Fixed

  • ClientMaxBodySize 默认值设置
  • sendfile 高并发下连接断开处理
  • WebSocket 升级失败时的资源泄漏
  • 代理请求 URI 和 Host 设置
  • BodyStream nil 检查防止空指针
  • 负载均衡器 hostnameOnce 并发安全
  • SSL 证书验证禁用的安全警告
  • 大量 golangci-lint 错误修复

Documentation

  • nginx 源码架构分析文档
  • fasthttp 源码分析任务规划
  • 重构文档目录结构nginx 文档移至子目录
  • Lua 配置示例和示例脚本
  • 更新 README 添加 GeoIP 和 Lua 功能说明

Tests

  • 端到端集成性能基准测试
  • HTTP/2/HTTP/3/WebSocket 性能基准测试
  • Lua 协程和字节编译性能基准测试
  • DNS 解析、状态端点、负载均衡器完整测试
  • 静态文件发送处理测试
  • 基准测试迁移到 Go 1.24 b.Loop() API

Build

  • Docker 构建支持
  • Windows 平台构建兼容性
  • golangci-lint 配置重构,重新启用多项检查

[0.2.0] - 2026-04-10

Added

核心基础设施

  • 变量系统模块支持内置变量、SSL 客户端证书变量、上游变量,自动注入请求上下文
  • DNS 解析器模块,支持自定义 DNS 服务器配置,集成到代理请求处理
  • HTTP/2 协议支持,集成到服务器和应用层

SSL/TLS 增强

  • Session Tickets 支持,含密钥轮换和内存/文件存储后端
  • mTLS 客户端证书验证,支持可选/强制验证模式
  • TCP/UDP Stream SSL/TLS 支持,完整证书配置

中间件与处理

  • auth_request 外部认证中间件,支持子请求验证流程
  • static handler alias 指令,支持路径别名映射
  • 代理响应临时文件处理保护内存避免大响应OOM
  • rate limiting 后台自动清理和优雅关闭

可观测性

  • Prometheus 格式状态输出支持
  • 缓存清理 API 端点
  • 分层性能回归检测策略与基准测试套件

配置与构建

  • Resolver/SSL 默认值完善及 YAML 配置示例输出
  • 负载均衡算法配置验证
  • golangci-lint 静态检查配置
  • 所有构建命令启用静态链接支持
  • goimports 替代 go fmt 格式化代码

Changed

  • resolver/variable/ssl 等核心类型重命名,移除冗余前缀
  • HeadersMiddleware 重命名移除冗余前缀
  • HTTP/2 使用 textproto.CanonicalMIMEHeaderKey 替代手动实现
  • 配置废弃字段标记与移除

Performance

  • 一致性哈希虚拟节点哈希值预计算
  • 代理缓存使用 uint64 哈希键优化性能

Documentation

  • 新增 variable/resolver 等 AGENTS.md 模块文档
  • nginx 健康检查详解与高级模块文档
  • 配置字段完整参考文档

Tests

  • 变量系统单元测试与基准测试
  • SSL Session Tickets/Stream SSL 测试
  • try_files、错误页面、pprof 单元测试

[0.1.0] - 2026-04-07

Added

核心功能

  • 反向代理与负载均衡模块,支持轮询/加权/最少连接/一致性哈希算法
  • 故障转移 (next_upstream) 支持,自动切换备用上游
  • 文件缓存模块,支持缓存元数据管理
  • SSL/TLS 支持,强制 TLS 1.2+,支持证书配置
  • HTTP/3 (QUIC) 支持,含 0-RTT 与性能配置验证
  • 静态文件服务支持多静态目录、路径前缀匹配、try_files 配置

中间件系统

  • URL 重写中间件,含 ReDoS 保护与循环检测
  • gzip/deflate/Brotli 响应压缩中间件
  • 请求体大小限制中间件
  • 自定义错误页面支持
  • 访问日志中间件,支持 nginx combined 格式
  • 安全中间件(访问控制、可信代理配置)

可观测性

  • pprof 性能分析端点
  • 访问/错误日志分离,支持全局格式配置
  • 服务器状态 API

配置与构建

  • 配置加载模块,支持 YAML/CLI 参数
  • 配置验证功能,多项验证函数
  • Makefile 构建脚本,含基准测试基础设施
  • 程序信号处理(优雅关闭、热升级)

Changed

  • 统一错误处理风格,空白标识符忽略明确不关心的返回值
  • 抽取网络工具函数到 netutil 包,移除冗余代码
  • 优化字符串构建方式,使用 fmt.Fprintf 替代冗余写法
  • 增强 FlagLast 语义与循环检测

Fixed

  • 配置与代码实现不一致问题修复
  • Phase 8 问题修复与功能完善

Documentation

  • 添加项目 README 文档
  • 核心模块 GoDoc 文档注释
  • nginx 模块翻译文档 (Lua/安全/API网关/动态配置/ACME 指南)
  • 模块上下文文档 (AGENTS.md)
  • 开发计划文档

Tests

  • handler/logging/middleware/server/proxy/cache/loadbalance/security 等模块单元测试
  • 核心模块基准测试与回归检测

Initial Development - 2026-04-02 to 2026-04-03

Project Initialization

  • 项目初始化,添加 nginx 文档作为参考
  • Makefile 构建脚本与程序入口
  • 配置加载模块与 CLI 参数解析
  • 基础 HTTP 服务器核心功能

Core Modules (Phase 1-4)

  • 应用逻辑抽取到 internal/app 包
  • 信号处理与配置结构完善
  • 反向代理与负载均衡实现
  • SSL/TLS 与安全中间件
  • 日志模块增强
  • 文件缓存实现
  • URL 重写与压缩中间件

Performance & Integration (Phase 5-7)

  • 访问日志中间件
  • 性能优化与热升级
  • 访问控制与可信代理配置
  • Phase 6-7 功能完善与测试覆盖

HTTP/3 & Advanced Features (Phase 8-9)

  • HTTP/3 (QUIC) 支持
  • 配置验证增强
  • Brotli 压缩支持
  • pprof 性能分析端点
  • 故障转移支持
  • 自定义错误页面
  • 请求体大小限制
  • try_files 配置支持