Jenkins | 一键打包部署Vue前端应用

一、前言

1、本文主要内容

​ 将在项目中实际使用到的相关东西整理记录一波,同时可以方便其他同学在使用到的时候参考一下(自己也备忘),有不对的地方,欢迎指出~~

  • 记录下如何使用Jenkins自动打包、部署Vue前端应用(对于所有前后端分离的前端静态项目都通用)
  • 前端代码如何打成Docker镜像

3、本篇环境信息

  • 服务器

    操作系统硬件配置IP说明
    CentOS 74C16G10.133.28.54部署Jenkins
  • Jenkins版本

    Jenkins安装包有两种,一种是LTS,一种是Weekly。LTS是稳定版,Weekly每周会更新一次,一般使用LTS就行了,最新版的LTS:2.235.2

  • Docker

    Docker Engine - Community : 19.03.8

  • Spring Boot应用

    使用的是版本2.2.5.RELEASE,当然只要是一个Spring Boot应用都可以

  • GitLab

    本文演示使用的是社区版12.7.6 也可以使用GitHub 、Gitee或者SVN都可以

二、准备工作

1、Docker 环境安装

在Linux服务器上安装Docker环境,具体可以参考:

2、Jenkins 环境安装

在Linux服务器上安装Jenkins,具体可以参考:

3、GitLab 环境安装

在Linux服务器上安装GitLab,具体可以参考:

三、打包及部署

本文使用的前端是项目是Vue项目,是部署到Nginx进行访问的

Vue项目的打包需要使用Node环境,Jenkins也是可以在插件中心安装NodeJs的插件的,非常简单方便,不了解的同学可以参考这篇文章:

安装完成之后,可以到Global Tool Configuration配置NodeJs的版本,也非常简单,不在说明。

  • 新建一个自由风格的任务

    image-20200812174715703

  • 配置源码管理

    我这边使用的是GitLab,当然你们使用Github、Gitee都是可以的,指定前台的代码路径。

    image-20200812175538984

    增加一个访问GitLab的用户名密码

    image-20200812153319729

  • 配置构建环境

    在构建环境,我们需要选择使用NodeJs的相关信息,具体如下:

    image-20200812175059016

  • 配置构建打包前台代码,点击增加构建步骤–>执行shell,具体配置项参考下图:

    image-20200812180042171

  • 将打好包的静态资源文件传到Nginx服务器。点击增加构建步骤–>Execte shell script on remote host using ssh选项,这个是到远程服务器执行脚本,还有另外一种方式,在一键打包Spring Boot应用那片文章里,有兴趣的可以翻翻看看,具体如下图:

    image-20200812181025511

  • 点击保存,这样就可以了,点击立即构建,就可以实现一键打包部署了

四、前端代码打Docker镜像

现在大部分的项目都采用的前后端分离的开发方式,那么前端代码也就独立出来了,我们也可以将前端的静态资源文件打包成镜像,这样在扩展或者部署的时候,也都会非常方便

  • 准备Dockerfile

    那么前端代码的Dockerfile一般情况应怎么来写呢?

    # 基础镜像
    FROM docker.io/stanleyws/nginx:openresty
    
    # nginx的配置文件
    ADD nginx.conf /usr/local/openresty/nginx/conf/nginx.conf
    # 前台的静态资源文件
    ADD dist/ /usr/local/openresty/nginx/html/dist
    

    OpenResty(又称:ngx_openresty) 是一个基于 NGINX 的可伸缩的 Web 平台,当然这里完全可以换成单纯的nginx

  • 准备执行脚本run.sh

    #!/usr/bin/env bash
    # 时间戳版本
    date=$(date "+%Y.%m.%d-%H.%M.%S")
    echo '----build image----'
    # 打包前端镜像
    docker build . -t 127.0.0.1:2375/cloud/mva-front:${date}
    echo '----push image----'
    # 上传到Docker镜像仓库
    docker push 127.0.0.1:2375/cloud/mva-front:${date}
    echo '----rm image-----'
    # 删除掉刚才打包好的镜像
    docker rmi 127.0.0.1:2375/cloud/mva-front:${date}
    
    
  • 整合

    将准备好的Dockerfilerun.sh静态资源文件(vue打完包之后是在dist文件夹下)nginx.conf放置到同一个文件夹下,然后执行run.sh即可。

有更好的方法的同学,欢迎私信我,一起探讨img

​ 更多文章请扫描下方二维码关注公众号获取,或者微信搜索【HughPro】关注


<think>好的,我现在需要帮助用户了解如何在Vue项目中实现一键打包并自动部署到服务器,特别是通过自动化构建与部署流程和CI/CD实现方案。首先,我需要回忆一下相关的知识,并结合提供的引用内容来构建一个合理的回答。 首先,用户的问题是关于Vue项目的自动化构建和部署,所以我要考虑常见的工具和流程。通常,CI/CD流程包括代码提交、自动测试、构建打包部署到服务器等步骤。引用中提到的GitLab CI/CD可能是一个合适的工具,因为引用[2]和[3]都提到了GitLab的持续集成和部署功能,以及自动化流程的实现。 接下来,我需要确定回答的结构。用户可能需要一个逐步的指导,所以分步骤说明会比较清晰。比如,先讲本地构建脚本,然后引入GitLab CI/CD,再配置服务器自动部署,最后可能提到其他工具如Jenkins或GitHub Actions作为替代方案。 然后,我需要确保每个步骤都有具体的示例,比如编写一个Shell脚本来自动构建,或者编写.gitlab-ci.yml文件。引用[4]提到了job、tags、stage和script,这些在GitLab CI/CD配置中都是关键部分,应该详细说明。 另外,服务器自动部署部分可能需要使用SSH连接,或者通过rsync同步文件。引用[3]提到运行流水线后查看日志,所以可能需要说明如何处理部署后的日志和验证。 还要考虑安全性,比如如何在CI/CD中安全地存储SSH密钥或服务器凭证,可能需要使用GitLab的Variables功能,这部分需要提到。 最后,生成相关问题,可能需要围绕优化CI/CD流程、多环境部署、与其他工具集成等方面提问,确保问题相关且有深度。 需要检查是否所有LaTeX格式都正确,但用户的问题中没有数学公式,可能不需要使用。不过根据系统指令,如果有任何行内公式需要用$...$,但在这个问题中可能不涉及,所以可能可以忽略。 另外,引用需要正确标注。比如引用[2]和[3]关于GitLab CI/CD的部分,引用[1]关于自动化流程的优势,可以在适当的地方引用,比如在解释自动化优势时。 现在,我需要将这些思路整理成一个结构清晰的回答,分步骤说明,并确保每个部分都有示例代码或配置,同时引用相关的内容来支持说明。还要注意使用中文,保持语言自然,避免技术术语过于复杂,让用户容易理解。</think>在Vue项目中实现自动化构建与部署,可以通过以下分步骤方案实现: ### 一、基础本地自动化构建 1. **编写构建脚本** 创建`deploy.sh`脚本实现本地打包和文件传输: ```bash #!/bin/bash npm run build && \ scp -r dist/* user@server:/path/to/webroot ``` ### 二、GitLab CI/CD方案 2. **配置.gitlab-ci.yml** 在项目根目录创建CI/CD配置文件: ```yaml stages: - build - deploy build_job: stage: build image: node:16 script: - npm install - npm run build artifacts: paths: - dist/ deploy_job: stage: deploy image: alpine script: - apk add openssh-client rsync - mkdir -p ~/.ssh - echo "$SSH_PRIVATE_KEY" > ~/.ssh/id_rsa - chmod 600 ~/.ssh/id_rsa - rsync -avz --delete dist/ user@server:/path/to/webroot only: - main ``` *注:需在GitLab项目设置中添加`SSH_PRIVATE_KEY`变量存储服务器密钥[^4]* ### 三、服务器端自动化 3. **Webhook触发部署(进阶方案)** 在服务器部署webhook监听服务,当接收到CI完成通知后自动执行: ```python from flask import Flask, request import subprocess app = Flask(__name__) @app.route('/webhook', methods=['POST']) def webhook(): subprocess.run(['git', 'pull']) subprocess.run(['npm', 'run', 'deploy']) return 'OK' ``` ### 四、完整流程示例 ``` 开发提交代码 → 触发CI流水线 → 自动安装依赖 → 执行单元测试 → 构建生产包 → 安全传输制品 → 部署到服务器 → 发送通知邮件[^3] ``` ### 五、优化建议 - 使用**Docker容器化**构建环境保证一致性 - 配置**多阶段部署**(开发/测试/生产环境) - 集成**SonarQube**代码质量检测 - 添加**自动回滚**机制
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值