需要三台不同环境的服务器,SVN、Jenkins、Tomcat

1.SVN搭建

   1.Subversion服务器(SVN服务器)

   2.项目对应的版本库

   3.版本库中钩子程序(用于触发构建命令)

  在我以前的博文中有介绍这里不多BB,注意以下几点

  1.记住配置账号密码文件 passwd中版本库的访问账号密码(Jenkins从SVN上下载源码需要用到)

  2.配置 SVN 服务综合配置文件 svnserve.conf中,anon-access = none,关闭SVN的匿名访问。

2.Tomcat

  用于跑最终项目的服务器上的Tomcat,需要给Tomcat设置一个账号密码。

  Windows的在这里C:\Program Files\Apache Software Foundation\Tomcat 9.0\conf\tomcat-users.xml。

  Linux的没怎么关注,改天研究到了再补充。

  在用户配置文件(tomcat-users.xml)中添加以下内容

  <role rolename="manager-gui"/>
<role rolename="manager-script"/>
<role rolename="manager-jmx"/>
<role rolename="manager-status"/>
<user username="fanqi" password="admin" roles="manager-gui,manager-script,manager-jmx,manager-status"/>

  *Jenkins通过自身的Maven插件把从SVN上拿到的源码打成WAR包部署到Tomcat上,当Jenkins程序去访问Tomcat时,Tomcat为了防止非授权的访问需要应用提供账号密码。

  上面的配置中我们新建了一个用户,并继承了Tomcat的四个管理角色,因此,我们拥有强大的权限去访问Tomcat。

  在服务配置文件(server.xml)中添加以下内容

    <Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" URIEncoding="UTF-8"/>

  *主要解决Tomcat URL编码的问题

  查看Tomcat日志使用命令:tail -f /opt/tomcat/logs/catalina.out

⒊Jenkins

  1.安装

  Jenkins有很多种安装形式,在我的文章中也有提及,这里也就不多BB了。

  2.配置

  Manage Jenkins(系统管理) => Configure Global Security(全局安全配置) => 安全域 => 勾选"允许用户注册"(万一忘记用户名密码还可以进行其他操作)

  Manage Jenkins(系统管理) => Configure Global Security(全局安全配置) => 授权策略 =>选中" Anyone can do anything" (任何用户可以做任何事-没有任何限制)(学的时候操作方便一些,生产环境慎重操作)

  Manage Jenkins(系统管理)  => Global Tool Configuration(全局工具配置) => Maven 配置 =>"默认 settings 提供"修改为"文件系统中的settings文件",并指定本机的Maven配置文件地址,可以使用echo $MAVEN_HOME命令查看后修改填入(/opt/apache-maven-3.6.1/conf/settings.xml)

  Manage Jenkins(系统管理)  => Global Tool Configuration(全局工具配置) => Maven 配置 =>"默认全局 settings 提供"修改为"文件系统中的settings文件",并指定本机的Maven配置文件地址,可以使用echo $MAVEN_HOME命令查看后修改填入(/opt/apache-maven-3.6.1/conf/settings.xml)

  Manage Jenkins(系统管理)  => Global Tool Configuration(全局工具配置) => JDK => JDK安装 => 新增JDK => 别名:MyJDK(随意) ,取消自动安装的勾选并指定本地的JAVA_HOME地址,可以使用echo $JAVA_HOME命令查看后直接填入(opt/jdk1.8.0_222)

  Manage Jenkins(系统管理)  => Global Tool Configuration(全局工具配置) => Maven => Maven安装 => 新增JMaven=> Name:MyMaven(随意) ,取消自动安装的勾选并指定本地的MAVEN_HOME地址,可以使用echo $MAVEN_HOME命令查看后直接填入(/opt/apache-maven-3.6.1/bin)

  你也可以配置你的Git什么的,有啥就配置啥就可以了。

  因为我们要和SVN做集合,所以需要安装一些SVN的插件。SVN的插件如果选择推荐的插件进行安装的话,一般是默认装上了,插件名:Subversion Plug-in,还需要安装一些其他的SVN需要的插件,Deploy to container等。

  Manage Jenkins(系统管理)  => Manage Plugins(管理插件) => 可选插件 =》 Ctrl + F搜索Deploy to container,勾选后选择"直接安装"。

⒋创建Maven项目及在MVN上创建版本库(使用svnadmin create命令,配置库权限等操作),然后将Maven项目上传到MVN。

⒌创建Jenkins任务

  在Jenkins首页点击"开始创建一个新任务" => 输入任意的任务名称 => 选择"Freestyle project"(构建一个自由风格的软件项目) ,点击确定=>源码管理(就是指在那里把源代码下载下载) ,选择Subversion(SVN)=> 在”Repository URL“输入MVN仓库地址+项目名称(注意要加项目名称),例如mvn://192.168.227.128/coreqi/coreqi_pc_server(注意,受服务器时间影响,Jenkins可能拿不到SVN的最新代码,可以在URL后追加@HEAD拿到最新源码,上面的例子为mvn://192.168.227.128/coreqi/coreqi_pc_server@HEAD) =>在”Credentials“点击添加,Jenkins然后SVN的账号及密码(注意添加完还要在下拉列表选择一下),源码管理配置完成。

  在构建,单击”增加构建步骤“,选择”Invoke top-level Maven targets“(调用顶层Meven目标),在”Maven Version“选择我们步骤2中配置的Maven,在”Goals“中输入”clean install“命令,即执行清理安装命令,构建配置完成。点击保存。

  返回任务列表,点击我们刚刚添加的任务,点击”立即构建“。(可以在Build History查看构建历史,点击构建任务,选择控制台输入即可查看打印信息)

⒍自动部署到Tomcat上

  在Jenkins的工程配置中点击我们新增的任务 => 构建后操作,点击“增加构建后操作步骤”,选中"Deploy war/ear to a container"(注意:这一项一定要有步骤3中我们安装的Deploy to container插件,没有安装的话是没有这个选项的) => 在“WAR/EAR files”中填入war包路径(这里是以工作区为根目录的一个相对路径,例如:target/Coreqi-0.0.1-SNAPSHOT.war)=> 在“Context Path”中填入"coreqi"(指在浏览器中访问项目的名称,此示例为coreqi) => 在"Containers"点击“Add Container”选中"Tomcat 9.x",在“Credentials”点击“Add”选中"Jenkins"输入我们在步骤2Tomcat中配置的用户名密码(注意,添加完还需要选择一些我们刚添加的用户名密码),在"Tomcat URL"中填入“http://192.168.227.128:8080”后点击保存。再次点击“立即构建”进行测试。

⒎配置SVN钩子程序,一旦有新代码提交,自动执行Jenkins“立即构建”命令

  在Jenkins的工程配置中点击我们新增的任务 =>构建触发器,勾选“触发远程构建(例如,使用脚本)”,在“身份验证令牌”中填入一个指定的Token指,当我们访问Jenkins特定的URL地址再加上我们指定的Token的时候,Jenkins将自动触发该任务的“立即构建”命令,例如,我们在“身份验证令牌”中填入“Coreqi_token”,当我们在浏览器中访问http://192.168.227.128:8080/jenkins/job/coreqi/build?token=Coreqi_token,Jenkins将自动执行coreqi任务的“立即构建”命令。

  ****Jenkins默认开启了防止跨站点请求伪造

  在Manage Jenkins(系统管理) => Configure Global Security(全局安全配置) => CSRF Protection => 默认是勾选了“防止跨站点请求伪造”。则当我们向Jenkins发送请求时需要带上Crumbs的值。

  如何获取Crumbs的值?

  官网中有说明:https://wiki.jenkins.io/display/JENKINS/Remote+access+API

  我们访问http://192.168.227.128:8080/crumbIssuer/api/xml拿到Crumbs的值

  我们将利用SVN的Hooks(钩子程序)中的post-commit(提交之后)来触发以上操作

  在SVN的版本库/项目名称/hooks下新建post-commit文件(注意没有扩展名),将shell命令复制进去保存即可。

curl -X post -v -u fanqi:admin -H "Jenkins-Crumb:6023e1d965a7c88eb38d7567ce9f123a" http://192.168.227.128:8080/jenkins/job/coreqi/build?token=Coreqi_token

  保存后修改权限为755

chmod 755 post-commit

  curl命令介绍:

    -X参数:指定请求方式
    -v参数:指定相应结果
    -u参数:携带用户名/密码
    -H参数:携带请求消息头信息

⒏测试

  请自行测试

  

  

Jenkins+SVN持续环境搭建的更多相关文章

  1. Jenkins+Github持续环境搭建

    ⒈前提要求 Jenkins与Github配合实现持续集成需要注意以下几点: 1.Jenkins需要部署在外网上,因为内网地址是无法访问Github的.这一点可以通过租用阿里云.腾讯云等云平台提供的云服 ...

  2. 使用Maven+Nexus+Jenkins+Svn+Tomcat+Sonar搭建持续集成环境(二)

    前言     上一篇随笔Maven+Nexus+Jenkins+Svn+Tomcat+Sonar搭建持续集成环境(一)介绍maven和nexus的环境搭建,以及如何使用maven和nexus统一管理库 ...

  3. Maven+Nexus+Jenkins+Svn+Tomcat+Sonar搭建持续集成环境(二)

    上一篇随笔Maven+Nexus+Jenkins+Svn+Tomcat+Sonar搭建持续集成环境(一)介绍maven和nexus的环境搭建,以及如何使用maven和nexus统一管理库文件和版本,以 ...

  4. 使用Maven+Nexus+Jenkins+Svn+Tomcat+Sonar搭建持续集成环境

    前言 但凡一个略有规模的项目都需要一个持续集成环境的支撑,为什么需要持续集成环境,我们来看一个例子.假如一个项目,由A.B两位程序员来协作开发,A负责前端模块,B负责后端模块,前端依赖后端.A和B都习 ...

  5. Maven+Nexus+Jenkins+Svn+Tomcat+Sonar搭建持续集成环境

    使用Maven+Nexus+Jenkins+Svn+Tomcat+Sonar搭建持续集成环境(一) 2015-01-14 20:28 by 飘扬的红领巾, 4322 阅读, 5 评论, 收藏, 编辑 ...

  6. 使用Maven+Nexus+Jenkins+Svn+Tomcat+Sonar搭建持续集成环境(一)

    前言     但凡一个略有规模的项目都需要一个持续集成环境的支撑,为什么需要持续集成环境,我们来看一个例子.假如一个项目,由A.B两位程序员来协作开发,A负责前端模块,B负责后端模块,前端依赖后端.A ...

  7. 持续集成-jenkins介绍与环境搭建

    什么是持续集成? 转自:https://blog.csdn.net/tanshizhen119/article/details/80328523 持续集成,俗称CI, 大师Martin Fowler对 ...

  8. jmeter + ant + jenkins 自动化集成环境搭建

    所需工具 一.jmeter 工具下载 https://jmeter.apache.org/  配置环境JDK等及各种插件 二.Ant安装(http://ant.apache.org/) 安装Ant是为 ...

  9. jenkins安装及环境搭建

    Jenkins 是基于Java开发的一种持续集成工具,所以,Jenkins需要Java环境. Jenkins版本是: JAVA版本是: Tomcat版本是: 或者 Jenkins版本是:2.10.2 ...

随机推荐

  1. Combine String HDU - 5707 dp or 广搜

    Combine String HDU - 5707 题目大意:给你三个串a,b,c,问a和b是不是恰好能组成c,也就是a,b是不是c的两个互补的子序列. 根据题意就可以知道对于c的第一个就应该是a第一 ...

  2. 洛谷 U5122 T2-power of 2(费马小定理)

    U5122 T2-power of 2 题目提供者胡昊 题目描述 是一个十分特殊的式子. 例如: n=0时 =2 然而,太大了 所以,我们让对10007 取模 输入输出格式 输入格式: n 输出格式: ...

  3. MySQL 5.7半同步复制技术

    一.复制架构衍生史 在谈这个特性之前,我们先来看看MySQL的复制架构衍生史. 在2000年,MySQL 3.23.15版本引入了Replication.Replication作为一种准实时同步方式, ...

  4. [Vue] : vue-resource 实现 get, post, jsonp请求

    vue-resource 实现 get, post, jsonp请求 常见的数据请求类型:get,post,jsonp 除了vue-resource之外,还可以使用axios的第三方包实现实现数据的请 ...

  5. 关于bert+lstm+crf实体识别训练数据的构建

    一.在实体识别中,bert+lstm+crf也是近来常用的方法.这里的bert可以充当固定的embedding层,也可以用来和其它模型一起训练fine-tune.大家知道输入到bert中的数据需要一定 ...

  6. Flask-特殊的装饰器

    视图函数中的装饰器 -----------------------视图中的装饰器---------------------- 1.如果使用的是函数视图,那么自己定义的装饰器必须放在`app.route ...

  7. 【洛谷4542】 [ZJOI2011]营救皮卡丘(最小费用最大流)

    传送门 洛谷 Solution 这是一道神仙题! 考虑这个东西是个啥. emmm,如果两个点要到达,一定不能经过比他们大的. 所以Floyd搞定两点距离然后费用流跑一遍就是答案了! 代码实现 /* m ...

  8. Laravel 配置

    首页 问答社区 中文文档 API Composer Github 配置说明 框架下载好了,但是想要很好的使用,可能我们还有一些东西需要知道,这就是配置.和项目有关的配置是在 app/config 文件 ...

  9. Netfilter 之 iptable_filter

    概述 本文主要对filter表的初始化流程,以及钩子函数的规则match流程的源码进行分析: 源码分析 所在钩子点: /* 在LOCAL_IN,FORWARD, LOCAL_OUT钩子点工作 */ # ...

  10. FreeMarker学习(常用表达式)

    直接指定值 字符串: "Foo" 或者 'Foo' 或者 "It's \"quoted\"" 或者 'It\'s "quoted& ...