news 2026/6/10 13:40:39

前端——自动化部署与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/6/10 5:37:08

NGA论坛优化摸鱼体验插件完整指南

NGA论坛优化摸鱼体验插件完整指南 【免费下载链接】NGA-BBS-Script NGA论坛增强脚本,给你完全不一样的浏览体验 项目地址: https://gitcode.com/gh_mirrors/ng/NGA-BBS-Script 还在为NGA论坛繁杂的界面而烦恼吗?想要在浏览论坛时获得更清爽、更高…

作者头像 李华
网站建设 2026/6/10 5:35:03

Proteus安装步骤图解:零基础实现仿真平台搭建

零基础也能装好Proteus?一张图、一步一提示,手把手带你搞定仿真平台搭建你是不是也遇到过这种情况:刚下载完Proteus安装包,双击setup.exe却弹出一堆错误提示——“缺少VC库”、“无法启动License Manager”、“找不到许可证”………

作者头像 李华
网站建设 2026/6/10 5:43:23

5分钟掌握ESP32文件上传:嵌入式开发者终极操作手册

5分钟掌握ESP32文件上传:嵌入式开发者终极操作手册 【免费下载链接】arduino-esp32fs-plugin Arduino plugin for uploading files to ESP32 file system 项目地址: https://gitcode.com/gh_mirrors/ar/arduino-esp32fs-plugin ESP32文件上传插件是专为Ardui…

作者头像 李华
网站建设 2026/6/10 5:40:04

南京大学学位论文模板终极指南:从零到一的完整使用教程

还在为论文格式烦恼吗?🤔 南京大学njuthesis模板帮你解决所有排版难题!无论你是本科生、硕士生还是博士生,这篇指南将带你快速上手这个强大的学术写作助手。 【免费下载链接】NJUThesis 南京大学学位论文模板 项目地址: https:/…

作者头像 李华
网站建设 2026/6/9 19:51:40

Zotero文献管理高效配置:完整掌握国家标准格式设置

Zotero文献管理高效配置:完整掌握国家标准格式设置 【免费下载链接】Chinese-STD-GB-T-7714-related-csl GB/T 7714相关的csl以及Zotero使用技巧及教程。 项目地址: https://gitcode.com/gh_mirrors/chi/Chinese-STD-GB-T-7714-related-csl 在学术写作中&…

作者头像 李华
网站建设 2026/6/10 6:44:17

基于SpringBoot的送货上门系统【2026最新】

作者:计算机学姐 开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等,“文末源码”。 专栏推荐:前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏:…

作者头像 李华