使用Jenkins持续集成前端项目并自动化部署到Nginx服务器

栏目: 服务器 · Nginx · 发布时间: 6年前

内容简介:上午折腾了一下Jenkins持续集成,由于公司使用自己搭建的svn服务器来进行代码管理,因此这里Jenkins是针对svn服务器来进行的配置,后面稍微介绍了下针对Github管理的项目的Jenkins配置之前项目每次修改之后都需要本地声明:

上午折腾了一下Jenkins持续集成,由于公司使用自己搭建的svn服务器来进行代码管理,因此这里Jenkins是针对svn服务器来进行的配置,后面稍微介绍了下针对Github管理的项目的Jenkins配置

之前项目每次修改之后都需要本地 npm run build 一次手动发布到服务器上方便测试和产品查看,有了Jenkins持续集成之后只要svn或者git提交之后就会自动打包,很方便,此次记录以备后询。

声明:

em-mes

1. 安装

1.1 安装Nginx

可以直接去官网下直接下载,解压缩 start nginx 就可以使了,常用命令:

start nginx  # 启动
nginx -s reload  # 修改配置后重新加载生效
nginx -s reopen  # 重新打开日志文件
nginx -t  # 配置文件检测是否正确
复制代码

教程网上不少,就不赘述了

1.2 安装Jenkins

从官网下载文件安装之后,我这里安装到 C:\Jenkins ,默认端口8080,这时候浏览器访问 localhost:8080 就能访问Jenkins首页,这里注意如果不安装到C盘根目录有些插件安装会出错

使用Jenkins持续集成前端项目并自动化部署到Nginx服务器

这里会让你去某个地方找一个初始密码文件打开并填到下面的密码框里,验证成功之后进入页面,选择 Install suggested plugins 推介安装的插件

使用Jenkins持续集成前端项目并自动化部署到Nginx服务器

插件都安装完成之后进入用户登录界面,设定用户名、密码及邮箱。

然后提示 Jenkins is ready! → Start using Jenkins ~

使用Jenkins持续集成前端项目并自动化部署到Nginx服务器

注意这里因为要使用node的命令来执行创建后操作,所以还需要安装插件: NodeJS PluginDeploy to containerGithubPost build task

这里顺便记录一下启动和关闭Jenkins服务的命令行:

net start jenkins            // 启动Jenkins服务
net stop jenkins             // 停止Jenkins服务
复制代码

2. 创建svn项目的Jenkins任务

2.1 新建

左边栏新建一个任务,输入一个任务名称,这里随便写一个

使用Jenkins持续集成前端项目并自动化部署到Nginx服务器

2.2 配置

General

这里才是重头戏,进入刚刚创建的任务的配置页面的 General

使用Jenkins持续集成前端项目并自动化部署到Nginx服务器

丢弃旧的构建就是检测到新的版本之后把旧版本的构建删除

源码管理

这里采用的是svn来管理代码,

使用Jenkins持续集成前端项目并自动化部署到Nginx服务器

构建触发器

使用Jenkins持续集成前端项目并自动化部署到Nginx服务器

这里的Poll SCM表示去检测是否更新构建的频率, ***** 表示每分钟, H**** 表示每小时

构建

cd cd C:\Jenkins\workspace\em-mes
node -v
npm -v
cnpm i
npm run build
复制代码

构建后操作

安装插件 Post build task 后,可以在 增加构建后操作步骤中选择 Post build task 选项,增加构建后执行的script,具体可以参考文章: jenkins部署maven项目构建后部署前执行 shell 脚本

我这里的 Log textBuild complete

Script:

rmdir /q/s C:\nginx-1.14.0\html\em-mes
xcopy /y/e/i C:\Jenkins\workspace\em-mes\em-mes C:\nginx-1.14.0\html\em-mes
复制代码

复制生成好的文件到Nginx的目录下,路径自行修改

3. 创建Github项目的Jenkins任务

Jenkins不仅可以持续集成svn项目,Git项目也是可以的,这里以Github上的项目为例

其他配置和上面一章一样

这样如果github有新的push请求,都会自动化部署到之前的服务器上,可以说很方便了

试一试

配置好了我们试一试吧~ 在刚刚github项目中随便commit一版到github

使用Jenkins持续集成前端项目并自动化部署到Nginx服务器

稍等片刻去本地Jenkins地址 http://localhost:8080/job/vue-element-template/ 就能看到Jenkins已经在构建中了

使用Jenkins持续集成前端项目并自动化部署到Nginx服务器

50秒之后

使用Jenkins持续集成前端项目并自动化部署到Nginx服务器

构建成功!构建用时54秒,现在访问本地地址 http://localhost:8282/vue-element-template ,已经能看到编译后的发布版本啦~如果你希望发布的是测试版本,可以自行修改构建后操作的script

网上的帖子大多深浅不一,甚至有些前后矛盾,在下的文章都是学习过程中的总结,如果发现错误,欢迎留言指出~

参考:


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

无处不在的算法

无处不在的算法

[德]贝特霍尔德·弗金、赫尔穆特·阿尔特 / 机械工业出版社 / 2018-1-1

本书以简单易懂的写作风格,通过解决现实世界常见的问题来介绍各种算法技术,揭示了算法的设计与分析思想。全书共有41章,分为四大部分,图文并茂,把各种算法的核心思想讲得浅显易懂。本书可作为高等院校算法相关课程的本科生教材,也可作为研究人员、专业技术人员的常备参考书。一起来看看 《无处不在的算法》 这本书的介绍吧!

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具