上一次我们讲到了使用Jenkins一键打包部署SpringBoot应用,这一次我们来讲下如何一键打包部署前端应用,以Vue前端应用为例,这里我们使用mall-admin-web中的代码来进行演示。

学前准备

学习本文需要一些Jenkins和Nginx的知识,对这些不熟悉的小伙伴可以参考以下文章。

  • 使用Jenkins一键打包部署SpringBoot应用,就是这么6!
  • Nginx的这些妙用,你肯定有不知道的!

Jenkins中的自动化部署

Vue前端应用的打包需要依赖NodeJS插件,所以我们先安装并配置该插件,然后创建任务来打包部署。

安装NodeJS插件

  • 在系统设置->插件管理中选择安装插件;

图片

  • 搜索NodeJS插件并进行安装;

图片

配置NodeJS插件

  • 在系统设置->全局工具配置中进行插件配置;
  • 选择新增NodeJS,配置好版本号以后,点击保存即可完成设置;

创建任务

我们需要创建一个任务来打包部署我们的前端应用,这里以我的mall-admin-web项目为例。

  • 任务执行流程如下:
  • 构建一个自由风格的软件项目:
  • 在源码管理中添加Git代码仓库相关配置,这里我使用的Gitee上面的代码,地址为:https://gitee.com/macrozheng/mall-admin-web
  • 在构建环境中把我们的node环境添加进去:
  • 添加一个执行shell的构建,用于将我们的前端代码进行编译打包:
  • 构建脚本如下:
# 查看版本信息
npm -v
# 解决存放在Github上的sass无法下载的问题
SASS_BINARY_SITE=https://npm.taobao.org/mirrors/node-sass/ npm install node-sass
# 将镜像源替换为淘宝的加速访问
npm config set registry https://registry.npm.taobao.org
# 安装项目依赖
npm install
# 项目打包
npm run build
  • 添加一个使用ssh执行远程脚本的构建,用于将我们打包后的代码发布到Nginx中去:
  • 远程执行脚本如下:
docker stop nginx
echo '----stop nginx----'
rm -rf /mydata/nginx/html
echo '----rm html dir----'
cp -r /mydata/jenkins_home/workspace/mall-admin-web/dist /mydata/nginx/html
echo '----cp dist dir to html dir----'
docker start nginx
echo '----start nginx----'
  • 点击保存后,直接在任务列表中点击运行即可完成自动化部署:

图片

遇到的坑

node-sass无法下载导致构建失败

由于node-sass的源使用的是Github上面的,经常无法访问,我们构建的时候需要单独设置node-sass的下载地址。

# linux
SASS_BINARY_SITE=https://npm.taobao.org/mirrors/node-sass/ npm install node-sass
# window
set SASS_BINARY_SITE=https://npm.taobao.org/mirrors/node-sass/ && npm install node-sass

有些依赖无法下载导致构建失败

由于npm源访问慢的问题,有些源可能会无法下载,改用淘宝的npm源即可解决。

# 设置为淘宝的镜像源
npm config set registry https://registry.npm.taobao.org
# 设置为官方镜像源
npm config set registry https://registry.npmjs.org

项目地址

https://github.com/macrozheng/mall-admin-web


更多相关文章

  1. 你还在代码里做读写分离么,试试这个中间件吧!
  2. 一行代码的Python GUI弹框
  3. Mybatis框架如何使用分页插件呢?
  4. 使用Maven插件构建Docker镜像
  5. API注入机制及插件启动流程_VSCode插件开发笔记2
  6. ImportNew 一周资讯 : 2018 值得关注的 9 个代码与框架相关趋势
  7. IDEA常用设置及推荐插件
  8. 用最低的成本,提高你的代码稳壮性。
  9. 10 行 Java 代码实现最近被使用(LRU)缓存

随机推荐

  1. Android实现全屏
  2. android ant 打包报错:  [aapt] invalid
  3. Android键盘属性
  4. FAQ_05_查看 android 设备 ip
  5. android studio 打包 so 库
  6. Android SDK和最新ADT下载地址 + 环境搭
  7. Mono for Android—初体验之“电话拨号器
  8. 关于Android(安卓)Pie(Android(安卓)9.0),你
  9. 全屏、小屏、横屏、竖屏的切换
  10. android listview的divider分割线的宽度