【项目部署】使用Jenkins一键打包部署前端Vue应用


前言

嗨,大家好,我是希留,一个被迫致力于全栈开发的老菜鸟。

上一篇文章我们讲到了使用Jenkins一键打包部署SpringBoot应用,这一次我们来讲下如何一键打包部署前端应用,以Vue前端应用为例。


一、准备工作

1、安装nginx

因为前端项目通常是放在nginx里面,所以需要安装好nginx。为了方便,我们这里使用Docker来安装nginx。(若已安装好nginx,则跳过此步骤)

1.1 下载nginx的docker镜像

docker pull nginx:1.10

在这里插入图片描述

1.2 从容器中拷贝nginx配置

  • (1)先运行一次容器(为了拷贝配置文件):
docker run -p 80:80 --name xiliu-nginx \
-v /mydata/nginx/html:/usr/share/nginx/html \
-v /mydata/nginx/logs:/var/log/nginx  \
-d nginx:1.10

在这里插入图片描述

  • (2)将容器内的配置文件拷贝到指定目录:
docker container cp xiliu-nginx:/etc/nginx /mydata/nginx/

在这里插入图片描述

  • (3)进入/mydata/nginx/目录下,修改文件名称:
mv nginx conf

在这里插入图片描述

  • (4)终止并删除容器:
docker stop xiliu-nginx
docker rm xiliu-nginx

在这里插入图片描述

1.3 使用docker命令启动

docker run -p 80:80 --name xiliu-nginx \
-v /mydata/nginx/html:/usr/share/nginx/html \
-v /mydata/nginx/logs:/var/log/nginx  \
-v /mydata/nginx/conf:/etc/nginx \
-d nginx:1.10

在这里插入图片描述
输入 docker ps 命令,可以看到正在运行的 docker 容器
在这里插入图片描述

1.4 测试

前面我们已经部署了一个SpringBoot的项目,且用ip可以访问项目。现在有nginx,就可以通过nginx动态代理,使用域名访问了。(前提是要有自己的域名)

  • 在/mydata/nginx/conf/conf.d文件夹中添加配置文件api.conf,对将请求代理到远程的xiliu-admin服务上去:
server {
    listen       80;
    server_name  你的域名; #修改域名

    location / {
    	proxy_pass   http://你的ip:端口; #修改为代理服务地址
        index  index.html index.htm;
    }

    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }

}

在这里插入图片描述

  • 重启动nginx服务后,通过http://api.xiliu.online/doc.html即可访问到xiliu-admin的API文档页面了:
    在这里插入图片描述

二、安装NodeJS插件

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

  • 在系统设置->插件管理中选择安装插件,搜索NodeJS插件并进行安装;

在这里插入图片描述

三、配置NodeJS插件

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

在这里插入图片描述

四、创建任务

我们需要创建一个任务来打包部署我们的前端应用。任务执行流程如下:
在这里插入图片描述

1、构建一个自由风格的软件项目

在这里插入图片描述
在这里插入图片描述

2、源码管理

  • 在源码管理中添加Git代码仓库相关配置,这里我使用的Gitee上面的代码;
    在这里插入图片描述
  • 在构建环境中把我们的node环境添加进去:
    在这里插入图片描述

添加一个执行shell的构建,用于将我们的前端代码进行编译打包:
在这里插入图片描述

  • 构建脚本如下:
# 查看版本信息
npm -v
# 将镜像源替换为淘宝的加速访问
npm config set registry https://registry.npm.taobao.org
# 安装项目依赖
npm i
# 项目打包
npm run build:prod
  • 添加一个使用ssh执行远程脚本的构建,用于将我们打包后的代码发布到Nginx中去:
    在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

五、测试

1. 配置nginx

  • 在/mydata/nginx/conf/conf.d文件夹中添加配置文件lms.conf,进行反向代理。:
server {
    listen       80;
    server_name  lms.xiliu.online; #修改域名

    location / {
        root   /usr/share/nginx/html; #代理目录,(注意下是源目录,不是映射目录)
        index  index.html index.htm;
        try_files $uri $uri/ /index.html;
    }
    location /prod-api { #反向代理接口服务
        rewrite ^.+prod-api/?(.*)$ /$1 break;
        proxy_pass http://api.xiliu.online;
            
   }

    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }

}
  • 添加好后,重启nginx容器,就可以正常访问到页面了,也可以正常调用接口进行登录。
    在这里插入图片描述
    在这里插入图片描述

总结

以上就是本文的全部内容了,感谢大家的阅读。本文介绍了docker安装nginx,以及Jenkin配置node环境来打包部署前端应用。

如果觉得文章对你有帮助,还不忘帮忙点赞、收藏、关注、评论哟,您的支持就是我创作最大的动力!

  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Java升级之路

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值