news 2026/5/2 12:29:09

前端——自动化部署与CI/CD实践

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
前端——自动化部署与CI/CD实践

引言

在现代软件开发中,自动化部署和持续集成/持续部署(CI/CD)已成为提高开发效率、保证代码质量和加速交付过程的关键实践。通过自动化的流程,团队可以减少人为错误,加快发布周期,并确保每次部署的一致性和可靠性。

CI/CD基础概念

持续集成(Continuous Integration)

持续集成是一种软件开发实践,开发人员频繁地将代码变更集成到共享仓库中,每次集成都会通过自动化构建和测试来验证。

持续部署(Continuous Deployment)

持续部署是在持续集成的基础上,自动将通过测试的代码变更部署到生产环境。

持续交付(Continuous Delivery)

持续交付确保软件可以随时发布到生产环境,但发布决定仍需人工确认。

主流CI/CD平台

GitHub Actions

# .github/workflows/deploy.ymlname:Deploy Applicationon:push:branches:[main]pull_request:branches:[main]jobs:test:runs-on:ubuntu-lateststrategy:matrix:node-version:[14.x,16.x,18.x]steps:-uses:actions/checkout@v3-name:Use Node.js ${{matrix.node-version}}uses:actions/setup-node@v3with:node-version:${{matrix.node-version}}cache:'npm'-name:Install dependenciesrun:npm ci-name:Run testsrun:npm testenv:CI:true-name:Run lintingrun:npm run lintbuild-and-deploy:needs:testruns-on:ubuntu-latestif:github.ref == 'refs/heads/main'steps:-uses:actions/checkout@v3-name:Setup Node.jsuses:actions/setup-node@v3with:node-version:'18.x'cache:'npm'-name:Install dependenciesrun:npm ci-name:Build applicationrun:npm run buildenv:NODE_ENV:production-name:Deploy to serverrun:|echo "部署应用到服务器" # 部署脚本env:DEPLOY_KEY:${{secrets.DEPLOY_KEY}}

GitLab CI/CD

# .gitlab-ci.ymlstages:-test-build-deployvariables:NODE_VERSION:"18"before_script:-echo "开始执行任务"-npm citest:stage:testimage:node:$NODE_VERSIONscript:-npm run test:unit-npm run test:e2ecoverage:'/Coverage:\s(\d+\.\d+%)/'artifacts:reports:coverage_report:coverage_format:coberturapath:coverage/cobertura-coverage.xmlbuild:stage:buildimage:node:$NODE_VERSIONscript:-npm run buildartifacts:paths:-dist/expire_in:1 weekdeploy_staging:stage:deployimage:node:$NODE_VERSIONscript:-echo "部署到测试环境"-npm run deploy:stagingenvironment:name:stagingurl:https://staging.example.comonly:-developdeploy_production:stage:deployimage:node:$NODE_VERSIONscript:-echo "部署到生产环境"-npm run deploy:productionenvironment:name:productionurl:https://example.comwhen:manualonly:-main

Docker自动化部署

Dockerfile配置

# Dockerfile FROM node:18-alpine AS builder WORKDIR /app # 复制依赖文件 COPY package*.json ./ RUN npm ci --only=production && npm cache clean --force # 复制源代码 COPY . . # 构建应用 RUN npm run build # 生产阶段 FROM nginx:alpine # 复制构建结果 COPY --from=builder /app/dist /usr/share/nginx/html # 复制nginx配置 COPY nginx.conf /etc/nginx/nginx.conf # 暴露端口 EXPOSE 80 # 健康检查 HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \ CMD curl -f http://localhost/health || exit 1 CMD ["nginx", "-g", "daemon off;"]

Docker Compose配置

# docker-compose.ymlversion:'3.8'services:app:build:.ports:-"80:80"environment:-NODE_ENV=production-API_URL=https://api.example.comdepends_on:-redis-dbnetworks:-app-networkrestart:unless-stoppedredis:image:redis:7-alpineports:-"6379:6379"volumes:-redis
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/29 8:37:05

HTML报告生成+Python数据分析|Miniconda-Python3.11整合Pandas/Matplotlib

HTML报告生成与Python数据分析实战:基于Miniconda-Python3.11的自动化工作流 在科研实验室、工程团队或数据中台里,你是否经历过这样的场景?——同事跑来问:“上次那个分析脚本在哪?为什么在我电脑上跑不起来&#xff…

作者头像 李华
网站建设 2026/4/23 14:11:19

Sketch Measure插件完整使用教程:提升设计效率的终极指南

Sketch Measure插件完整使用教程:提升设计效率的终极指南 【免费下载链接】sketch-measure Make it a fun to create spec for developers and teammates 项目地址: https://gitcode.com/gh_mirrors/sk/sketch-measure 在当今快节奏的设计环境中,…

作者头像 李华
网站建设 2026/5/1 8:22:20

Kazumi:构建自定义番剧采集应用的终极指南

Kazumi:构建自定义番剧采集应用的终极指南 【免费下载链接】Kazumi 基于自定义规则的番剧采集APP,支持流媒体在线观看,支持弹幕。 项目地址: https://gitcode.com/gh_mirrors/ka/Kazumi 在数字娱乐内容日益丰富的今天,如何…

作者头像 李华
网站建设 2026/4/28 8:50:51

F3D项目与VTK 9.3版本集成挑战及解决方案

F3D项目与VTK 9.3版本集成挑战及解决方案 【免费下载链接】f3d Fast and minimalist 3D viewer. 项目地址: https://gitcode.com/gh_mirrors/f3/f3d 当快速3D查看器遇上现代可视化库 大家好!今天我们来聊聊F3D这个轻量级3D查看器在集成VTK 9.3版本时遇到的那…

作者头像 李华
网站建设 2026/4/25 12:41:22

OpenMTP:颠覆传统的Mac与Android文件传输神器

在当今多设备共存的时代,Mac用户与Android设备之间的文件传输一直是个技术痛点。OpenMTP作为一款开源的高级Android文件传输应用,彻底解决了这一难题。它通过创新的技术架构和用户友好的界面设计,让跨平台文件管理变得前所未有的简单高效。这…

作者头像 李华
网站建设 2026/4/25 8:07:00

Jupyter Notebook连接远程GPU服务器|Miniconda-Python3.11实战教学

Jupyter Notebook连接远程GPU服务器|Miniconda-Python3.11实战教学 在深度学习模型动辄需要数小时甚至数天训练的今天,你是否也经历过本地笔记本风扇狂转、显存爆满却只跑了个小数据集的窘境?更别提当同事说“我这代码能跑”而你却报错CUDA o…

作者头像 李华