CI/CD 流水线性能优化:从构建到部署
CI/CD 流水线性能优化从构建到部署前言哥们别整那些花里胡哨的理论。今天直接上硬菜——我在大厂一线优化 CI/CD 流水线性能的真实经验总结。作为一个白天写前端、晚上打鼓的硬核工程师我对效率的追求就像对鼓点节奏的把控一样严格。背景最近我们团队的 CI/CD 流水线运行缓慢构建时间长、部署过程复杂、资源利用不合理。经过一系列优化我们将构建时间从 30 分钟缩短到 5 分钟部署时间从 10 分钟缩短到 1 分钟。今天就把这些干货分享给大家。构建优化1. 缓存优化问题依赖安装时间长每次构建都需要重新安装依赖。解决方案直接上代码# .gitlab-ci.yml variables: DOCKER_DRIVER: overlay2 CACHE_DIR: ${CI_PROJECT_DIR}/.cache cache: paths: - ${CACHE_DIR} - node_modules/ - .npm/ - .yarn/ build: stage: build image: docker:20.10.16 services: - docker:20.10.16-dind script: - mkdir -p ${CACHE_DIR} - docker login -u $DOCKER_USER -p $DOCKER_PASSWORD $DOCKER_REGISTRY - docker build --cache-from $DOCKER_REGISTRY/$IMAGE_NAME:latest -t $DOCKER_REGISTRY/$IMAGE_NAME:$CI_COMMIT_SHORT_SHA . - docker push $DOCKER_REGISTRY/$IMAGE_NAME:$CI_COMMIT_SHORT_SHA only: - main - develop2. 并行构建问题构建任务串行执行时间长。解决方案# .gitlab-ci.yml stages: - lint - test - build - deploy lint: stage: lint image: node:16-alpine script: - npm ci - npm run lint only: - main - develop - merge_requests # 并行测试 test-unit: stage: test image: node:16-alpine script: - npm ci - npm run test:unit only: - main - develop - merge_requests test-integration: stage: test image: node:16-alpine script: - npm ci - npm run test:integration only: - main - develop - merge_requests # 并行构建 build-frontend: stage: build image: docker:20.10.16 services: - docker:20.10.16-dind script: - docker build -t $DOCKER_REGISTRY/frontend:$CI_COMMIT_SHORT_SHA ./frontend - docker push $DOCKER_REGISTRY/frontend:$CI_COMMIT_SHORT_SHA only: - main - develop build-backend: stage: build image: docker:20.10.16 services: - docker:20.10.16-dind script: - docker build -t $DOCKER_REGISTRY/backend:$CI_COMMIT_SHORT_SHA ./backend - docker push $DOCKER_REGISTRY/backend:$CI_COMMIT_SHORT_SHA only: - main - develop3. 多阶段构建问题镜像体积大构建时间长。解决方案# 多阶段构建 FROM node:16-alpine as builder WORKDIR /app COPY package*.json ./ RUN npm ci --onlyproduction COPY . . RUN npm run build FROM nginx:alpine COPY --frombuilder /app/build /usr/share/nginx/html COPY nginx.conf /etc/nginx/conf.d/default.conf EXPOSE 80 CMD [nginx, -g, daemon off;]测试优化1. 测试并行化问题测试用例执行时间长。解决方案# .gitlab-ci.yml test: stage: test image: node:16-alpine script: - npm ci - npm run test -- --parallel only: - main - develop - merge_requests2. 测试缓存问题测试依赖安装时间长。解决方案# .gitlab-ci.yml test: stage: test image: node:16-alpine cache: paths: - node_modules/ - .jest/cache/ script: - npm ci - npm run test only: - main - develop - merge_requests3. 测试选择性执行问题每次都运行所有测试时间长。解决方案# .gitlab-ci.yml test: stage: test image: node:16-alpine script: - npm ci - if [ $CI_PIPELINE_SOURCE merge_request_event ]; then npm run test:changed; else npm run test; fi only: - main - develop - merge_requests部署优化1. 滚动更新问题部署过程中服务中断。解决方案apiVersion: apps/v1 kind: Deployment metadata: name: frontend spec: replicas: 3 strategy: type: RollingUpdate rollingUpdate: maxSurge: 1 maxUnavailable: 0 selector: matchLabels: app: frontend template: metadata: labels: app: frontend spec: containers: - name: frontend image: our-registry/frontend:v1.0.0 ports: - containerPort: 80 readinessProbe: httpGet: path: /health port: 80 initialDelaySeconds: 5 periodSeconds: 10 livenessProbe: httpGet: path: /health port: 80 initialDelaySeconds: 15 periodSeconds: 202. 蓝绿部署问题部署风险高回滚困难。解决方案# 部署蓝色版本 apiVersion: apps/v1 kind: Deployment metadata: name: frontend-blue spec: replicas: 3 selector: matchLabels: app: frontend version: blue template: metadata: labels: app: frontend version: blue spec: containers: - name: frontend image: our-registry/frontend:v1.0.0 ports: - containerPort: 80 # 部署绿色版本 apiVersion: apps/v1 kind: Deployment metadata: name: frontend-green spec: replicas: 0 selector: matchLabels: app: frontend version: green template: metadata: labels: app: frontend version: green spec: containers: - name: frontend image: our-registry/frontend:v2.0.0 ports: - containerPort: 80 # 服务配置 apiVersion: v1 kind: Service metadata: name: frontend spec: selector: app: frontend version: blue ports: - port: 80 targetPort: 803. 灰度发布问题直接部署新版本风险高。解决方案apiVersion: networking.istio.io/v1alpha3 kind: VirtualService metadata: name: frontend namespace: default spec: hosts: - frontend http: - route: - destination: host: frontend subset: v1 weight: 90 - destination: host: frontend subset: v2 weight: 10 --- apiVersion: networking.istio.io/v1alpha3 kind: DestinationRule metadata: name: frontend namespace: default spec: host: frontend subsets: - name: v1 labels: version: v1 - name: v2 labels: version: v2最佳实践构建优化使用缓存加速依赖安装并行执行构建任务采用多阶段构建减小镜像体积使用 Docker 层缓存测试优化并行执行测试用例缓存测试依赖和结果选择性执行测试只运行变更相关的测试使用测试覆盖率工具指导测试优化部署优化使用滚动更新减少服务中断采用蓝绿部署降低部署风险实现灰度发布逐步放量配置健康检查和就绪探针监控与反馈监控 CI/CD 流水线执行时间收集构建和部署的 metrics建立流水线执行时间告警机制定期分析和优化流水线常见问题与解决方案1. 构建时间长问题构建过程耗时过长。解决方案使用缓存加速依赖安装并行执行构建任务采用多阶段构建优化 Dockerfile2. 测试失败率高问题测试用例经常失败导致流水线中断。解决方案修复不稳定的测试用例增加测试环境的稳定性实现测试重试机制优化测试用例的执行顺序3. 部署风险高问题部署过程中服务容易出现故障。解决方案使用滚动更新实现蓝绿部署配置健康检查和就绪探针建立自动回滚机制4. 流水线维护困难问题流水线配置复杂难以维护。解决方案模块化流水线配置使用模板和变量建立流水线配置的版本控制定期审查和优化流水线配置深夜感悟在地下室敲代码的时候我家猫 Root 跳上键盘不小心按到了git push结果触发了 CI/CD 流水线。这让我意识到自动化是效率的关键CI/CD 流水线可以大大提高开发和部署的效率持续优化是必要的流水线需要不断调整和优化以适应业务的变化监控是保障及时发现和解决流水线中的问题才能保证流水线的稳定运行总结CI/CD 流水线性能优化是一个持续的过程需要从构建、测试到部署的各个环节进行全面优化。就像打鼓一样只有掌握了基本技巧并不断练习和优化才能演奏出更加美妙的音乐。同样只有掌握了 CI/CD 流水线的优化技巧才能构建出高效、可靠的自动化流水线。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2452944.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!