项目测试环境自动化部署[jenkins前后端配置、Nginx配置]
持续部署:关注点在于项目功能部署到服务器后可以正常运行,为下一步测试环节或最终用户正式使用做准备。(问题点:一个环节有问题,其他环节跟着有问题)
持续集成:关注点是在于尽早发现项目整体运行问题,尽早解决。(问题点:经常性、频繁的把所有模块集成在一起进行测试,有问题尽早发现)
持续交付:关注点在于研发团队的最新代码能够尽快让最终用户体验到。(问题点:各个升级版本之间间隔时间太长,用户反馈感知迟钝,无法精确改善用户体验,用户流失严重,所以用小版本不断进行快速迭代,不断收集用户反馈信息,用最快的速度改进优化)
1、什么是持续集成
持续集成:简称CI,指的是,频繁地(一天多次)将代码集成到主干。
持续集成的优点:减少风险;减少重复过程;任何时间、任何地点生成可部署的软件;增强项目的可见性;建立团队对开发产品的信心。
持续集成的特点:自动完成、保证每个时间点上团队成员提交的代码是成功集成的、需求不明确或频繁变更的情景、帮助企业减少管理风险。
持续集成的应用场景:
持续集成(CI)系统组成部分:
主要包含如下3个部分:
- 版本控制系统,SVN
- CI SERVER
- Web服务器,tomcat
2、Jenkins概述
Jenkins是一个开源的持续集成工具,使用jenkins搭建持续集成环境,可以进行自动构建、自动编译、自动部署。
Jenkins使用安装:
1、安装插件:比如git
2、全局配置(gloable):git配置、mvn配置、JDK配置。
3、系统配置:主目录(.jenkins)、jenkins location、邮件、邮件通知。
4、管理用户:新建用户
5、任务操作:General-源码管理-构建服务器-构建-构建执行的shell
General:丢弃旧的构建:保持构建的天数、保持构建的最大个数、发布包保留天数、发布包最大保留XX个构建
源码管理:git地址
构建触发器:构建时间表达式包含5部分数据:minute(分钟)、hour(小时)、dom(天)、month(月)、dow(星期)。每部分数据的取值可以是具体数字,星号(*)和Hash(H),星号(*)表示任意取值,Hash(H)表示随机时间或取值范围。
比如:
H/10 * * * * 表示当前时间每隔10分钟构建一次
H(0-29)/10 * * * *表示每个小时的前一半时间中每隔10分钟构建一次
构建:maven goals:设置maven执行命令:clean package(清理、编译、打包)
3、项目部署方式
项目部署方式分2种方式:手动部署、自动化部署。
自动部署实现方式:
自动化部署实现方式:
4、jenkins部署实例--XXX项目测试环境部署
原理:“自动化”的具体体现:向版本库提交新的代码后,应用服务器上自动部署,用户或测试人员使用的马上就是最新的应用程序。
前提:jenkins已经在服务器搭建成功
4.1 jenkins配置
4.2 后端脚本配置
4.3 前端脚本配置
4.4 Nginx服务器配置
4.1 jenkins后端环境配置
step by step:
A.打开jenkins,点击新建任务
B.输入一个任务名称,与开发环境对应的任务名称
C.General:点击左边树形结构的配置,添加General信息,描述项目基本信息
D.源码管理:输入源码管理,Repositories URL是git上对应后端代码地址,Branches to build 指master始终是合并后的最新的代码。
Ps:在构建之前,需要去git上把其他分支代码合并到master上。
E.构建触发器:指定时间进行轮询添加 eg:H/3 8-23 * * *
PS:构建环境可以不需要,按需使用
F.构建后操作:
A.构建后操作->增加构建步骤->执行shell,弹框显示,添加构建动作,编写shell文件,执行脚本文件,需要开发配合,编写对应的脚本。比如使用gradlew进行打包,执行python脚本
目的:通过gradlew对程序进行打包
eg:chmod 777 /home/hl/.jenkins/workspace/${JOB_NAME}/gradlew
B.由于是gradlew对程序进行打包,构建后操作->增加构建步骤->Invoke Gradle Script,勾选Use Gradle Wrapper,task中添加如下命令:clean springCloudJar -x test
C.构建后操作:构建后操作->增加构建步骤->执行shell,弹框显示,添加构建动作,编写shell文件,执行脚本文件,需要开发配合,在对应的脚本配置文件进行信息编辑。比如添加工程对应的信息,去启动工程。具体脚本执行如下:
#工程名称,变量${JOB_NAME}是jenkins中自带的固定写法
PROJECT_NAME=${JOB_NAME}
#运行的jar程序
APP_NAME=application.jar
#日志文件输出路径
LOG_PATH=/logs/app
#应用部署路径
APP_PATH=/xxx/be
#配置文件路径(默认部署路径下的application.properties),传入参数,执行命令
CONFIG_PATH=application.properties
python2.7 /xxx/app/deploy.py $PROJECT_NAME $APP_NAME $LOG_PATH $APP_PATH $CONFIG_PATH
H.Jenkins列表页查看已经新建的工程任务
I.进入工程后,点击立即构建,开始对脚本进行自动操作,构建完成后,输入对应网址,能正常打开。
4.2 后端脚本配置文件
HOSTS:部署服务器IP账号,即存放后端代码所在的服务器IP
APP_PATH:部署到服务器的路径
VERSION_CONFIG_PATH:路径是jenkins对应目录创建的任务名称
#部署到服务器的路径(需要更改)
#APP_PATH = '/xx/be'
JOB_NAME = sys.argv[1]
APP_NAME = sys.argv[2]
LOG_PATH = sys.argv[3]
APP_PATH = sys.argv[4]+'/'+sys.argv[1]
CONFIG_PATH = sys.argv[5]
JAR_PATH = '/jenkins存放的空间目录/.jenkins/workspace/' + JOB_NAME + '/main/build/libs/' + APP_NAME PROPERTIES_FILE = '/xxx/脚本的配置文件目录/application.properties'
AUTO_SHELL = '/xxx/脚本的配置文件目录/autoShell.sh'
def scripts():
run('mkdir -p '+APP_PATH)
if not exists(APP_PATH+'/application.properties'):
put(PROPERTIES_FILE, APP_PATH)
put(JAR_PATH, APP_PATH)
put(AUTO_SHELL,APP_PATH)
with cd(APP_PATH):
run('chmod +x autoShell.sh')
if not exists(APP_PATH + '/start.sh'):
run('sh autoShell.sh '+JOB_NAME+' '+APP_NAME+' '+LOG_PATH+' '+CONFIG_PATH)
run('sh stop.sh')
run('sleep 1')
run('ls')
run('$(sh start.sh &) && sleep 1')
run('cat start.sh') def deploy(hosts):
execute(scripts, hosts=hosts) if __name__=="__main__":
deploy(HOSTS)
问题一:查看变量的所在目录位置
问题二:如何判断jenkins后端环境已成功
1.可以通过后端的接口文档进行判断是否成功。
2.如果不成功,解决问题的方式:通过配置文件去找到日志文件,然后根据日志文件去看问题,排查问题。
4.3 jenkins前端环境配置
PS:与后端配置一致,区别就是脚本的不同,需要前端人员提供
A-G的步骤都是一致的,与后端的区别是从H开始:
F.构建后操作:
A.构建后操作->增加构建步骤->执行shell,弹框显示,添加构建动作,编写shell文件,执行脚本文件,需要开发配合,编写对应的脚本。比如前端打包的方式是yarn安装
目的:按打包方式的命令进行安装
ex:
#前端打包
rm -rf dist/*
yarn
yarn build
B.构建后操作:构建后操作->增加构建步骤->执行shell,弹框显示,添加构建动作,编写shell文件,执行脚本文件,需要开发配合,在对应的脚本配置文件进行信息编辑。比如添加工程对应的信息,去启动工程。具体脚本执行如下:
ex:
#工程名称
JOB_NAME=${JOB_NAME}
#部署路径
APP_PATH=/xxx/test
python2.7 /存放文件的目录/fe-deploy.py $JOB_NAME $APP_PATH
4.4 前端脚本配置文件
HOSTS:部署服务器IP账号,即存放后端代码所在的服务器IP
APP_PATH:部署到服务器的路径
from fabric.api import *
from fabric.contrib.files import exists
import os
import sys #部署服务器ip 账号(需要更改)
HOSTS = ['haishu@127.0.0.1']
#部署服务器密码(需要更改)
env.password='xxx' # 部署到服务器的路径(需要更改)
JOB_NAME = sys.argv[1]
APP_PATH = sys.argv[2]+'/'+sys.argv[1]
DIST_PATH = '/jenkins存放空间的目录/.jenkins/workspace/' + JOB_NAME + '/dist' def scripts():
run('mkdir -p '+APP_PATH)
run('echo 1---')
with cd(APP_PATH):
if exists(APP_PATH +'/dist'):
run('rm -rf dist')
run('echo 2----')
put(DIST_PATH, APP_PATH) def deploy(hosts):
execute(scripts, hosts=hosts) if __name__=="__main__":
deploy(HOSTS)
4.5 Nginx配置
Nginx配置目的:后端与前端进行端口关联,保证前端页面能调用后端的接口信息,同时添加前端的监听端口。
PS:nginx服务器一般放在部署文件存放所在的服务器上
1.找到部署服务器所在的Nginx路径,比如:/xx/nginx/conf.d
2.进入配置页,添加测试服务器地址文件(添加后端网址-对应的应用服务器地址,即测试服务器,我们只需要配置测试环境的地址).
问题一:查找Nginx的具体目录位置[nginx的位置一般放在应用部署服务器下]
nginx -V
//找到--conf-path=/etc/nginx/nginx.conf
cat /etc/nginx/nginx.conf
//找到存放的路径,对应的include路径就是我们要找的路径
/etc/nginx/conf.d/*.conf
问题二:Nginx配置后,如何生效
//查看nginx是否配置成功
sudo nginx -t
//nginx配置后,使配置生效[不是root,都需要使用sudo]
sudo nginx -s reload
目的:添加后端服务器IP+端口、前端监听端口、前端root目录、后端api等信息,根据实际需要进行添加。
upstream xxx.test.local {
server 后端IP:后端端口;
}
server {
listen 前端端口;
server_name localhost;
#charset koi8-r;
#access_log /var/log/nginx/host.access.log main;
access_log /xx/portal_access.log;
error_log /xx/portal_error.log;
client_max_body_size 250m;
proxy_redirect off;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $host;
root /xxx/前端存放代码的路径/dist; location / {
try_files $uri /index.html =404;
}
location /example/api {
proxy_set_header Remote_Addr $remote_addr;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass xxx.test.local;
}
}
5、代码质量分析工具Sonar
Sonar是一个用于代码质量管理的开源平台,用于管理源代码的质量,可以通过插件形式从七个维度检测代码质量,可以支持Java、C#、C/C++、PL/SQL、Cobol、JavaScript、Groovy等二十几种编程语言的代码质量管理与检测。
Sonar可以检测代码中的以下七大问题:
a.糟糕的复杂度分析:如果文件、类、方法等复杂度过高将难以改变,这会使开发人员难以理解它们,而且如果没有自动化的单元测试,对于程序中的任何组件的改变都将导致全面的回归测试。
b.重复:如果代码中包含大量复制粘贴的代码则质量是低下的,Sonar可以展示源码中重复严重的地方。
c.缺乏单元测试:Sonar可以很方便的统计并展示单元测试覆盖率。
d.没有代码标准:Sonar可以通过PMD、CheckStyle、Findbugs等代码规则检测工具规范代码编写。
e.没有足够的注释或注释过多
f.潜在的bug:Sonar可以通过PMD、CheckStyle、Findbugs等代码规则检测工具检测出潜在的bug。
g.糟糕的设计:通过Sonar可以找出循环,展示包与包、类与类之间的相互依赖关系,检测耦合。
项目测试环境自动化部署[jenkins前后端配置、Nginx配置]的更多相关文章
- 自动化部署 jenkins 插件简介
一.什么是持续集成? (1)Continuous integration(CI) 持续集成是一种软件开发实践,即团队开发成员经常集成他们的工作,通常每个成员至少集成一次,也就意味着每天可能会发生多次集 ...
- jekins测试环境自动化
最近搭建测试环境自动化,之前都是用机器猫.机器猫的流程大概是这样,开发打包上传到svn,给测试一个svn地址,测试到机器猫上传文件,然后再运行启动. 为了减去开发打包这个环节,所以专用jenkins. ...
- java项目测试环境搭建
java项目测试环境搭建 2019-03-06 13:45:26 木瓜小少年 阅读数 691更多 分类专栏: 测试 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原 ...
- webpack正式、测试环境接口地址本地运行及打包命令配置
声明:本文由w3h5原创,转载请注明出处:<webpack正式.测试环境接口地址本地运行及打包命令配置> https://www.w3h5.com/post/521.html 为了方便开发 ...
- 后端必备 Nginx 配置
后端必备 Nginx 配置 概要 防盗链 根据文件类型设置过期时间 静态资源访问 日志配置 日志字段说明 access_log 访问日志 error_log 日志 日志切割 反向代理 禁止指定user ...
- node+vue进阶【课程学习系统项目实战详细讲解】打通前后端全栈开发(1):创建项目,完成登录功能
第一章 建议学习时间8小时·分两次学习 总项目预计10章 学习方式:详细阅读,并手动实现相关代码(如果没有node和vue基础,请学习前面的vue和node基础博客[共10章]) 视频教程地 ...
- jar包自动化部署---jenkins
B.Application Server SVN账号:svn://192.168.1.49/svn/keenyoda-trunk/xxxxxcht=xxxxx 安装jenkins:安装目录:/usr/ ...
- 自动化部署-Jenkins+SVN+MSBuild
这篇文章主要介绍下使用Jenkins实现自动化部署 下载 https://jenkins.io/download/ 安装 按步骤安装即可,下载的是windows版本,安装完成后,会看到这样一个正在运行 ...
- Django 1.6 最佳实践: django项目的服务器自动化部署(转)
原文:http://www.weiguda.com/blog/41/ 当我们设置服务器时, 不应该每次都使用ssh登录服务器, 再按照记忆一步一步的配置. 因为这样实在是太容易忘记某些步骤了. 服务器 ...
随机推荐
- parted命令采用gpt分区过程
Gpt无分区限制,故只有主分区,无扩展分区和逻辑分区.分区直接按容量算,不按柱面算. 查看分区:parted -l 将分区表类型转换为gpt.: 主要命令mklabel gpt 对sdc盘分区: [r ...
- symbol lookup error /usr/lib/x86_64-linux-gnu/libstdc++.so.6错误的解决办法
当出现 $ apt-get: symbol lookup error: /usr/lib/x86_64-linux-gnu/libstdc++.so.6: undefined symbol: _ZNS ...
- 分布式监控系统之Zabbix宏、模板和自定义item
前文我们聊了下zabbix的基础使用,包括主机的添加.监控项.触发器.action以及告警通知的配置,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/140073 ...
- 学习搭建 Consul 服务发现与服务网格-有丰富的示例和图片
目录 第一部分:Consul 基础 1,Consul 介绍 2,安装 Consul Ubuntu/Debian 系统 Centos/RHEL 系统 检查安装 3,运行 Consul Agent 启动 ...
- sync_with_stdio(false)和cin.tie(NULL)
std::ios::sync_with_stdio(false) 这个函数相当于是否兼容stdio的开关,默认为true C++为了兼容C,保证程序在使用了std::printf和std::cout的 ...
- DOM XSS详解
DOM XSS简介 DOM XSS与反射性XSS.存储型XSS的主要区别在于DOM XSS的XSS代码不需要服务端解析响应的直接参与,触发XSS的是浏览器端的DOM解析. DOM XSS复现 环境搭建 ...
- php 抛出异常
<?php //try里面执行的东西如果不成立,可直接 throw new Exception('异常信息'),那么try里面的程序将会被停止执行,直接执行catch里面的程序 try { if ...
- Vue3.0 响应式数据原理:ES6 Proxy
Vue3.0 开始用 Proxy 代替 Object.defineProperty了,这篇文章结合实例教你如何使用Proxy 本篇文章同时收录[前端知识点]中,链接直达 阅读本文您将收获 JavaSc ...
- 面试官:小伙子,说一说Java多线程有哪些创建方式吧
第一种 继承Thread类 自定义类,继承Thread类,并重写run()方法. class MyThread1 extends Thread { @Override public void run( ...
- 不是吧!做了两年java还没弄懂JVM堆?进来看看你就明白了
堆的核心概述 一个JVM实例只存在一个堆内存,堆也是java内存管理的核心区域Java堆区在jvm启动的时候被创建,其空间大小也就确定了.是jvm管理的最大一块内存空间.(堆内存的大小可以调节)< ...