CI/CD 坑点 记录

1. Docker build 504 超时 --- goproxy.cn sumdb 偶发故障

国内经典问题,Go 默认强制校验模块哈希(防供应链攻击),但国内访问不了 sum.golang.org,只能依赖 goproxy.cn 做中转。goproxy.cn 本身不是 100% 可用,一旦它的 sumdb 代理抽风,构建就挂。 CI 执行 docker build 时,在安装 grpc-health-probe 步骤卡住后报错:

go 复制代码
go: downloading github.com/spiffe/go-spiffe/v2 v2.x.x
verifying github.com/spiffe/go-spiffe/v2@v2.x.x: 504 Gateway Timeout

解决方案:

ini 复制代码
RUN CGO_ENABLED=0 GOOS=linux \
    GOPROXY=https://goproxy.cn,direct \
    GOSUMDB=off \
    go install github.com/grpc-ecosystem/grpc-health-probe@v0.4.25

风险点:投毒了你就完蛋了,但是当前版本已经上传到内部的镜像里面了。

2. Go 版本不匹配导致 CI 编译失败

小问题,统一所有服务 Dockerfile 的 builder 阶段为 golang:1.25-alpine:(go-zero 要求版本)

3. ImagePullBackOff --- cnb-registry-secret 权限不足

问题现象: Pod 状态卡在 ImagePullBackOff,describe pod 显示:

vbnet 复制代码
Failed to pull image "docker.cnb.cool/xxxx.com-2025/xxxl:latest": 
rpc error: code = Unknown desc = failed to pull and unpack image: 
unauthorized: authentication required

因为 docker pull 的时候没有 personal access token

markdown 复制代码
解决方案
1.  去 cnb.cool 后台 → 组织设置 → 给 `cnb-registry-secret` 对应用户添加 `docker:pull` 权限
2.  重新生成 token
3.  重建 k8s secret:  
ini 复制代码
kubectl -n production delete secret cnb-registry-secret
kubectl -n production create secret docker-registry cnb-registry-secret \
  --docker-server=docker.cnb.cool \
  --docker-username=cnb \
  --docker-password=<新token> \
  --docker-email=dev@cnb.cool
kubectl -n production rollout restart deploy/money-controll

碎碎念: 现在职责变得模糊化,不过也是好事,从单单写业务然后去做一些运维相关的东西

相关推荐
Oneslide20 分钟前
机械革命 单系统纯净重装Ubuntu(全盘覆盖,清空原有Windows)
后端
GetcharZp22 分钟前
告别OOM!用Go+libvips实现30000×50000超大图片的流式瓦片服务
后端·go
IT_陈寒1 小时前
JavaScript项目实战经验分享
前端·人工智能·后端
用户47949283569152 小时前
6w star,GitHub 趋势第一的 Ponytail,这个agent插件到底在火什么
前端·后端
神奇小汤圆3 小时前
2026一线大厂Java八股文精选(附答案,高质量整理)
后端
Warson_L4 小时前
LangGraph入门学习资料
后端
神奇小汤圆4 小时前
Spring Boot → Solon 注解迁移实战指南:一张对照表说清楚
后端
kfaino4 小时前
码农的AI翻身(四)你好,我叫 Attention
人工智能·后端
lwx572804 小时前
探秘InnoDB:搞懂它的内存、线程、磁盘与日志刷盘策略
java·后端
云技纵横5 小时前
Spring Boot Actuator 被打穿:线上开了这些端点,等于裸奔
后端