在 Go 中启用 HTTP 响应 gzip 压缩可显著减小 JSON、HTML 等文本响应体积,需通过自定义中间件检查 Accept-Encoding、设置 Content-Encoding,并仅对 text/*、application/json 等类型压缩,避开图片 /PDF 等已压缩格式,推荐使用 gzip.DefaultCompression(6)及 4KB–32KB 缓冲区。

在 Go 中启用 HTTP 响应的 gzip 压缩,能显著减小文本类响应(如 JSON、HTML、CSS、JS)的体积,加快页面加载和 API 响应速度。关键是正确配置压缩中间件,并避免对已压缩或不适宜压缩的内容重复处理。
使用 gzip 包实现标准压缩中间件
Go 标准库 net/http 本身不内置压缩,但 net/http/pprof 和第三方库常用 compress/gzip 手动封装。推荐使用官方维护的 golang.org/x/net/http2/h2c 配合 net/http,或更稳妥地引入轻量中间件如 rs/cors 同源生态中的 alexedwards/scs 不直接提供压缩,但社区广泛采用 labstack/echo 或 gin-gonic/gin 的内置支持。不过,纯标准库方案更可控:
- 创建一个包装
http.ResponseWriter的结构体,重写WriteHeader和Write方法,在首次写入前检查Accept-Encoding请求头是否含gzip - 若匹配,用
gzip.NewWriter包装底层响应体,并设置Content-Encoding: gzip响应头 - 注意:必须在调用
WriteHeader前决定是否启用 gzip,否则 header 已发送无法修改
避免压缩二进制或已压缩内容
不是所有响应都适合 gzip。盲目压缩可能适得其反:
- 图片(JPEG、PNG)、视频、PDF、ZIP 等本身已是高压缩格式,再套 gzip 可能增大体积或毫无收益
- 响应 Content-Type 是
image/*、video/*、application/pdf、application/zip时应跳过压缩 - 可维护一个白名单,仅对
text/*、application/json、application/javascript、application/xml等类型启用
设置合适的压缩等级与缓冲区
gzip 压缩等级影响 CPU 开销与压缩率。生产环境通常不需要最高压缩比:
- 使用
gzip.BestSpeed(1)或gzip.DefaultCompression(6)平衡性能与效果;避免gzip.BestCompression(9),它显著增加延迟 - 为
gzip.Writer设置合理缓冲区(如 4KB–32KB),太小会频繁 flush,太大则增加 内存占用 和首 字节 延迟 - 对小响应(
客户端兼容性与调试要点
确保压缩真正生效且被客户端正确解码:
- 检查请求中是否带
Accept-Encoding: gzip—— 某些旧客户端或测试工具(如早期 curl)默认不发该头 - 响应中必须包含
Content-Encoding: gzip,且Content-Length应为压缩后字节数(若提前知道);若流式写入,可省略Content-Length,改用Transfer-Encoding: chunked - 用
curl -H "Accept-Encoding: gzip" -I http://localhost:8080/api查看响应头;用-v查看实际传输大小






























