Linux下搭建jenkins+svn+http+maven自动化部署

Posted 时光列车!

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux下搭建jenkins+svn+http+maven自动化部署相关的知识,希望对你有一定的参考价值。

      Linux下搭建jenkins+svn+http+maven自动化部署

服务器设置:

卸载redhatyum,安装centosyum,配置第三方yum

1.删除redhat原有的rpm -qa |grep yum |xargs rpm -e yum --nodeps

2.下载yum安装文件,如果下载时找不到文件,http://mirrors.163.com/centos/6/os/x86_64/

wget http://mirrors.163.com/centos/6/os/x86_64/Packages/yum-3.2.27-14.el6.centos.noarch.rpm

wget http://mirrors.163.com/centos/6/os/x86_64/Packages/yum-metadata-parser-1.1.2-14.1.el6.x86_64.rpm

wget http://mirrors.163.com/centos/6/os/x86_64/Packages/yum-plugin-fastestmirror-1.1.26-11.el6.noarch.rpm

wget http://mirrors.163.com/centos/6/os/x86_64/Packages/python-iniparse-0.3.1-2.1.el6.noarch.rpm

3.进行安装yum

rpm -ivh python-iniparse-0.3.1-2.1.el6.noarch.rpm --nodeps

rpm -ivh yum-metadata-parser-1.1.2-16.el6.x86_64.rpm --nodeps

rpm -ivh yum-3.2.29-73.el6.centos.noarch.rpm --nodeps

rpm -ivh yum-plugin-fastestmirror-1.1.30-37.el6.noarch.rpm --nodeps

4.下载第三方yum源,这里是网易wget http://mirrors.163.com/.help/CentOS6-Base-163.repo 

下载到/etc/yum.repos.d/

5.注意事项:

(1)如果你的baseurl不能访问则会出现

(2)http://mirrors.163.com/centos/%24releasever/os/x86_64/repodata/repomd.xml: [Errno 14] PYCURL ERROR 22 - “The requested URL returned error: 404 Not Found” 说明baseurl有问题。将下载后的repo文件中所baseurl=http://mirrors.163.com/centos/releasever/os/basearch/中的所有$releasever改成6

(注意:这里改成“6”,是指redhat版本号是6.0的) 

(3)机器要能联网,ping www.baidu.com试下

(4)执行命令 yum clean all

yum  install httpd  安装成功则证明yum源成功

 

 

 

(1)下载erel源当作yum源来使用

rpm -ivh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm 

yum  makecache

yum  clean all

 

(2)下载lrzsz软件包

Wget ftp://195.220.108.108/linux/centos/5.11/os/x86_64/CentOS/lrzsz-0.12.20-22.1.x86_64.rpm

将要用到的软件包用rz”传输到服务器上

 

 

1.搭建svn+http

Svn分为两种方式访问(1)借助于apache

                   2svn独立服务器

这里,我们借助于apache来实现svn访问

 

1.首先,我们来安装svn apache软件包

yum   install  httpd   httpd-devel   subversion  mod_dav_svn

 

 

***mod_dav_svn**//SubversionApache之间的接口(通过它,Apache就可以访问版本库,可以让客户端也使用HTTP的扩展协议 WebDAV/DeltaV进行访问)

 

验证 svn模块(mod_dav_svn)是否正确安装
ls /etc/httpd/modules | grep svn
系统提示:
mod_authz_svn.so
mod_dav_svn.so

验证安装:
svn --version
显示如下表明正确安装

svn,版本 1.4.2(r22196)
   编译于 Aug 10 200918:00:04

Copyright (C) 2000-2006 CollabNet.
Subversion is open source software, see http://subversion.tigris.org/
This product includes software developed by CollabNet(http://www.Collab.Net/).

2.创建SVN库和项目

mkdir     /home/svn        /创建svn

svnadmin create  /home/svn/project        //创建svn项目

3.添加组及组员权限

groupadd  svn      //创建一个叫subversion的组为拥有仓库所在的目录
usermod -G svn  -a apache     //将自己和Apache 用户加入组成员中


查看:more /etc/group | grep svn
系统提示:svn:x:500:apache


4.修改项目权限

chgrp  -R   svn  /home/svn/project
chmod    -R   777   /home/svn/project

这里根据自己的安全需求配置相应的权限,因我这里是测试环境,所以给的是777权限

5.配置httpd

vim   /etc/httpd/conf/httpd.cof

查看有没有LoadModuledav_svn_module modules/mod_dav_svn.so这一行,如果没有就添加上为了使客户端能够通过Apache来访问SVN档案库,Apache需要加载 mod_dav_svn模块。如果Apache是按照与预设目 录安装的,mod_dav_svn 模块应该会安装在 Apache 安装位置 (默认路径是 /etc/httpd/) modules 子目录内。同时在Apache的配置文件httpd.conf(默认路径为etc/httpd/conf/)中已经使用 LoadModule指令加载了该模块(如果没有,手动添加)注意这个指令必须出现在其它的Subversion 相关指令之前。还要加载mod_authz_svn.so模块


例如: 
LoadModule  dav_svn_module  modules/mod_dav_svn.so
LoadModule  authz_svn_module  modules/mod_authz_svn.so

一般来时http都已经正常加载了这两个模块

启动apache

/etc/init.d/httpd  start

配置防火墙

iptables -A INPUT -p tcp -s 0/0 --dport 80 -j ACCEPT /*允许所有IP访问80端口*/

iptables-save > /etc/sysconfig/iptables /*保存配置或者使用命令 service iptables save */

 

打开浏览器查看是否能够访问到apache的页面(注意:如果开了防火墙一定要开放80端口)

http://ip地址 

 

6.配置SVN

编辑subversion.conf配置文件

svnserve.conf 文件, 该文件配置项分为以下5项:
       anon-access: 控制非鉴权用户访问版本库的权限。
       auth-access: 控制鉴权用户访问版本库的权限。
       password-db: 指定用户名口令文件名。
       authz-db:指定权限配置文件名,通过该文件可以实现以路径为基础的访问控制。
       realm:指定版本库的认证域,即在登录时提示的认证域名称。若两个版本库的认证域相同,建议使用相同的用户名口令数据文件

 
vim /etc/httpd/conf.d/subversion.conf
按以下代码更改(栗红为修改的代码):
LoadModule  dav_svn_module  modules/mod_dav_svn.so
LoadModule  authz_svn_module  modules/mod_authz_svn.so
 
<Location /svn>
DAV svn
SVNPath   /home/svn/projcet      ---指定SVN路径
#
#   # Limit write permission to list of valid users.
#   <LimitExcept GET PROPFIND OPTIONS REPORT>
#      # Require SSL connection for passwordprotection.
#      # SSLRequireSSL
#
AuthType  Basic
AuthName  "Authorization Realm"
AuthUserFile  /home/svn/projcet/conf/passwd    ---svn用户路径

Require valid-user
#   </LimitExcept>
</Location>
七步:建立用户

#cd  /home/svn/projcet/conf/    ---进入到svn目录

htpasswd   -c   passwd  username   ---创建svn用户密码

Apache  htpasswd参数说明

-c 创建一个加密文件

-n  不更新加密文件

-p  不对密码进行加密,即明文密码

-D  删除指定用户

-b  命令行中一并输入用户名与密码而不是根据提示输入密码

注意:借助于apache服务的SVN如果要创建多个用户与密码的话,具体操作如下

htpasswd   passwd   username       --创建用户名

密码直接在authz里加入你所添加用户的权限即可

 

 

Vim  /home/svn/projcet/conf/authz

test  = rw

通过http访问的账号是Apache http验证的。

通过svn://访问的账号是svn仓库conf目录下passwd指定的

两个是独立的认证方式。

 

重启apache                                    
通过web页面访问,弹出用户登录验证,访问成功 (注意开放防火墙的3690端口)

 

客户端连接SVN服务端时报错

1[Thu Mar 30 09:41:42 2017] [error] [client 172.19.63.36] (13)Permission denied: Could not open password file: /home/svn/project/conf/authz

[Thu Mar 30 09:41:42 2017] [error] [client 172.19.63.36] access to /svn failed, reason: verification of user id ‘admin‘ not configured

解决方法如下:

关掉selinux,不过关闭之后影响服务器安全性

 

(2)[error] [client 172.19.63.36] Access denied: ‘admin‘ GET svn:/

解决方法:这里主要是svn下的authz问题

 vim /home/svn/project/conf/authz

[groups]

admin = admin

[/]

*=r

@admin=rw

[test:/]

* =rw

@admin=rw

接下来输入http://ip地址/svn就可以访问svn服务端了

 

 

Linux下搭建jenkins

1.Jenkins 下载

Jenkins 下载网址: Download Jenkins

Jenkins 最新版本: jenkins_1.514_all.debUbuntu/Debian), 或 jenkins.warwar包)

2.jenkins安装

(1)jenkins安装前,先安装tomcat

软件:apache-tomcat-7.0.29.tar.gz
下载地址:http://tomcat.apache.org/

系统环境redhat

[解压jdk]

安装jdk之前先查看

[[email protected] etc]# rpm -qa | grep java

如果有javaopenjdk的安装包那么卸载掉

解压jdk

tar  xf  jdk-7u65-linux-x64.tar.gz  -C  /usr/java/

配置环境变量

 vim  /etc/profile

export JAVA_HOME=/usr/java/jdk1.7.0_65

export PATH=$JAVA_HOME/bin:$PATH

Export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar

执行source profile(在/etc/文件夹下)快速生效

测试

输入java测试

输入java -version测试

[[email protected] etc]# javac -version

javac 1.7.0_65

[[email protected] etc]# java -version

java version "1.7.0_65"

Java(TM) SE Runtime Environment (build 1.7.0_65-b17)

Java HotSpot(TM) 64-Bit Server VM (build 24.65-b04, mixed mode)

 

tomcat安装步骤:

1、下载 Tomcat

下载 apache-tomcat-7.0.29.tar.gz官方网址

2、解压 Tomcat

解压 apache-tomcat-7.0.29.tar.gz

tar -zxvf apache-tomcat-7.0.29.tar.gz   -C   /usr/java/

 

安装,下载jenkins.war

 mv   jenkins.war  /usr/java/apache-tomcat-7.0.54/webapps/

 cd  /usr/java/apache-tomcat-7.0.54/bin

./startup.sh             ---启动tomcat

tail  -f  /usr/java/apache-tomcat-7.0.54/logs/catalina.out     ---查看日志

netstat -anpt | grep :8080

成功启动后,我们就可以通过http://ip地址:端口号/jenkins访问

 

解决方法:在linux虚拟机中

[[email protected] ~]# cd /var/lib/jenkins/secrets/

[[email protected] secrets]# cat  initialAdminPassword

afbe3f8f7d39487f92b02df4df6ef2e6

initialAdminPassword 中的密码复制粘贴到administrator password里

continue

 

点击“install suggested plugins”

等待下载

会出现一个填写

用户名 test

密码test

完成!!!

 

出现上图界面,表示安装成功!

 

安装Maven

Maven的下载地址:http://maven.apache.org/download.cgi
这里以最新的3.2.3版本为例进行安装,在这之前需要确保机器上已经安装了JDK。

首先下载Maven并解压,并移动到usr/local目录下

$ wget http://mirror.bit.edu.cn/apache/maven/maven-3/3.2.3/binaries/apache-maven-3.2.3-bin.tar.gz

$ tar vxf apache-maven-3.2.3-bin.tar.gz

$ mv apache-maven-3.2.3 /usr/local/maven3

修改环境变量,在/etc/profile中添加以下几行

MAVEN_HOME=/usr/local/maven3

export MAVEN_HOME

export PATH=${PATH}:${MAVEN_HOME}/bin

记得执行source /etc/profile使环境变量生效。

最后运行mvn -v验证maven是否安装成功,如果安装成功会打印如下内容

Apache Maven 3.2.3 (33f8c3e1027c3ddde99d3cdebad2656a31e8fdf4; 2014-08-12T04:58:10+08:00)

Maven home: /usr/local/maven3

Java version: 1.7.0_65, vendor: Oracle Corporation

Java home: /usr/lib/jvm/java-7-openjdk-amd64/jre

Default locale: en_US, platform encoding: UTF-8

OS name: "linux", version: "3.13.0-35-generic", arch: "amd64", family: "unix"

 

 

 

 

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

使用Maven创建项目

无论是学习语言还是框架,先来一个Hello World基本上已经是套路了,我们也通过构建一个Hello World项目来了解如何使用Maven。
首先通过maven创建helloworld项目

$ mvn archetype:create -DgroupId=helloworld -DartifactId=helloworld

生成的项目目录如下,其中src/main/java是源码目录,src/test/java是测试文件目录。
一共只有三个文件,打开这三个文件,可以看到App.java中已经写好了一个Hello World程序,而AppTest中是Junit单元测试的代码,至于pom.xml,则给出了项目的一些基本信息以及依赖关系。

helloworld/

├── pom.xml

└── src

├── main

│  └── java

│  └── helloworld

│  └── App.java

└── test

└── java

└── helloworld

└── AppTest.java

这里主要看一下pom.xml文件,内容如下

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

<modelVersion>4.0.0</modelVersion>

 

<groupId>helloworld</groupId>

<artifactId>helloworld</artifactId>

<version>1.0-SNAPSHOT</version>

<packaging>jar</packaging>

 

<name>helloworld</name>

<url>http://maven.apache.org</url>

 

<properties>

<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

</properties>

 

<dependencies>

<dependency>

<groupId>junit</groupId>

<artifactId>junit</artifactId>

<version>3.8.1</version>

<scope>test</scope>

</dependency>

</dependencies>

</project>

pom.xml文件中,首先描述了项目的定义,groupId:artifactId:packaging:version这个四元组能够唯一标记一个项目。我们不仅可以用这个四元组来标记我们的项目,也可以用来标记其它的项目,比如用来描述项目依赖关系。perperties中定义了项目的属性,也可以在这里定义变量并在其它的地方引用。至于最后的dependencies,则是描述了项目的依赖关系,Maven会根据依赖关系自动下载相应的文件并在编译时使用。

在大型项目开发中,往往会将其分成若干个子项目,每个子项目都有着自己的的pom.xml,它们与父pom.xml之间相当于继承的关系。

可以说,pom.xml文件的配置是整个Maven的核心重点,也是学习Maven过程中需要详细了解的内容。这里只给出了最简单的配置样例,详细了解可以查看官方文档。

接下来编译并运行Helloworld项目。

如果是第一次编译的话,需要联网,因为Maven会自动下载依赖包。

$ mvn package

下载的依赖包会保存在~/.m2/repository文件夹中,打开这个文件夹,我们会发现里面的包正是按前面所说的四元组目录结构进行存储的。Maven在依赖一个jar包时会先去本地库查找,如果没找到就会从网上下载。当然,并不是所有的包都能从网上下载到,比如我们自己开发的jar包,这时,我们就可以用mvn install命令将一个项目安装到本地仓库。

打包成功后我们会发现项目中多了一个target文件夹,目录结构如下

target/

├── classes

│  └── helloworld

│  └── App.class

├── helloworld-1.0-SNAPSHOT.jar

├── maven-archiver

│  └── pom.properties

├── maven-status

│  └── maven-compiler-plugin

│  ├── compile

│  │  └── default-compile

│  │  ├── createdFiles.lst

│  │  └── inputFiles.lst

│  └── testCompile

│  └── default-testCompile

│  ├── createdFiles.lst

│  └── inputFiles.lst

├── surefire-reports

│  ├── helloworld.AppTest.txt

│  └── TEST-helloworld.AppTest.xml

└── test-classes

└── helloworld

└── AppTest.class

可以看到,在package过程中,maven完成了编译、测试代码,生成测试报告,生成jar包等一系列工作。

最后,我们也可以手动运行jar包查看结果。

$ java -cp target/helloworld-1.0-SNAPSHOT.jar helloworld.App

Hello World!

Maven常用命令

Maven的命令非常多,学习命令首先要了解Maven的生命周期。

Maven首先会验证并处理引用资源,之后进行项目编译,如果没有声明跳过测试,也会编译测试代码并进行测试、以成测试报告。最后,Maven会将编译好的内容进行打包,用于发布。

Maven命令与Maven的生命周期有着对应的关系,一个命令也经常会包含多个生命周期,比如mvn package会完成以上所有步骤。

这里列举几个常用的命令

mvn compile 编译项目

mvn test 编译运行单元测试

mvn package 打包(jar or war)

mvn install 将项目安装到本地仓库

mvn clean 清空项目

mvn eclipse:eclipse 生成eclipse工程

 

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

 

jenkins构建svn源码

 

从网上找的build.xml文件

具体实现步骤如下:

(1)Global  Tool  Configuration 下配置jdkmaven

(2)新建一个项目,我这里选择的是“构建自由的项目”

(3)构建完成后保存,自动会回到你新建的新项目下的配置界面

(4)找到svn,配置svn路径跟用户密码

(5)保存

(6)在做调用build.xml文件之前,先将配置好的jenkins测试一下

(7)jenkins首页,搜索你创建的新项目的名称,点击构建,打开“console control”看下有没有成功。(注意:这里因为配置并未完全搭建完成,属于半成品,所以构建时成功了就可以)

(8)接下来我们要试着去将代码上传到svn服务器上,然后通过jenkins来调用svn服务器下开发所上传的代码是否可以构建成功

(9)首先,先找到你的项目名称(也就是你的svn代码上传到什么项目名下)

(10)找到项目之后,点击“配置”

 

打开之后是这样的界面

(11)接下来我们配置svn代码路径。找到“参数化构建过程”----添加参数

 

配置好之后的页面如下

 

保存,点击构建

 

 

利用jenkins实现自动化部署SVN环境

 

1)下载maven插件“maven integration plugins

安装完成之后就可以创建maven项目了

(2)安装Deploy插件”Deploy to container  plugin

安装完成后会在“构建后”这里出现一个“Deploy war/ear to a container

(3)创建构建项目

1.1配置JDKMAVEN

在配置项目之前先配置JDKMAVEN

点击,系统管理----Global  Tool Configuration,填写JDKMAVEN相关内容

1.2创建构建项目

具体如下

首页点击“新建”-----

这里的报错信息不用管,因为我这个项目是创建完成的

 

接下来配置已创建好的项目

1.

 

2.源码管理

 

Repository URL这个填写svn分支路径

Credentials svn登陆用户与密码

3.Pre  Steps

 

4.Build

.

注意:这里的pom.xml原本是在服务器的这个路径下/root/.jenkins/plugins/workflow-aggregator/META-INF/maven/org.jenkins-ci.plugins.workflow/workflow-aggregator

我将pom.xml下载下来放在了svn目录里

 

就到这里,保存之后点击构建

我们可以点击console control“查看构建信息

 

创建构建好的项目默认放在/root/.jenkins/workspace/

 

 

 

 

Linux下一键安装禅道

禅道官网下载安装包http://www.zentao.net/download/80025.html 

解压安装软件包

tar -zxvf ZenTaoPMS.9.0.1.zbox_64.tar.gz -C /opt/

 

启动apachemysql

/opt/zbox/zbox start

 

如果想要修改apache端口号

/opt/zbox/zbox -ap 82

 

浏览器打开禅道http://ip地址:apache端口号

 

利用禅道来做集成禅道+svn

cd /opt/zbox/app/zentao/module/svn/

vim config.php

修改配置文件

具体如下:

$i = 1;

$config->svn->client = ‘/home/svn/‘;       -----这个是用来客户端存储客户端执行文件svn.exe路径

$config->svn->repos[$i][‘path‘]     = ‘http://svn.zentao.net/zentao/trunk/‘;   ----存储svn代码路径  

$config->svn->repos[$i][‘username‘] = ‘admin‘;   ----存储svn登陆用户

$config->svn->repos[$i][‘password‘] = ‘admin‘;    -----存储svn登陆密码

 

下面这里只要将/*”和*/去掉

$i ++;

$config->svn->client = ‘‘;

$config->svn->repos[$i][‘path‘]     = ‘‘;

$config->svn->repos[$i][‘username‘] = ‘‘;

$config->svn->repos[$i][‘password‘] = ‘‘;

 

 

执行svn同步命令

1.[[email protected] svn]# cd /opt/zbox/app/zentao/bin/

[[email protected] bin]# ls

init.bat  init.sh  php  ztcli

[[email protected] bin]# bash init.sh

Please input your php path:(example: /usr/bin/php)

/opt/zbox/app/zentao/bin/php

php path is error

Please input your php path:(example: /usr/bin/php)

/usr/bin/php            ----php可执行文件的路径

Please input zentao url:(example: http://localhost:88/zentao or http://localhost)

http://172.19.60.100:82/zentao/my/    ---禅道访问的url路径

ztcli.sh ok

backup.sh ok

computeburn.sh ok

dailyreminder.sh ok

checkdb.sh ok

syncsvn.sh ok

syncgit.sh ok

cron.sh ok

 

[[email protected] ~]# cd /home/svn/     ---切换到svn路径

[[email protected] svn]# ls     ---查看svn路径下有没有svn.exe文件

project  测试文件

[[email protected] svn]# mkdir svn.exe     ---新建一个svn.exe文件

 

[[email protected] svn]# cd /opt/zbox/app/zentao/bin/     ----切换到zentao路径下

[[email protected] bin]# php  ./ztcli   "http://172.19.60.100:82/zentao/my/"  

php来执行

./ztcli   -----zentao/bin下游这个脚本文件

 "http://172.19.60.100:82/zentao/my/"           ----zentao访问路径

执行完成的效果如下:

  [[email protected] bin]# php ./ztcli "http://172.19.60.100:82/zentao/my/"

<!DOCTYPE html>

<html lang=‘zh-cn‘>

<head>

  <meta charset=‘utf-8‘>

  <meta http-equiv=‘X-UA-Compatible‘ content=‘IE=edge‘>

  <meta name="renderer" content="webkit">

  <title>我的地盘 - 禅道</title>

<script language=‘javascript‘>var config={"webRoot":"\/zentao\/","appName":"","cookieLife":30,"requestType":"PATH_INFO","requestFix":"-","moduleVar":"m","methodVar":"f","viewVar":"t","defaultView":"html","themeRoot":"\/zentao\/theme\/","currentModule":"my","currentMethod":"index","clientLang":"zh-cn","requiredFields":"","router":".\/ztcli","save":"\u4fdd\u5b58","runMode":"","timeout":30000,"pingInterval":""};

var lang={"submitting":"\u7a0d\u5019...","save":"\u4fdd\u5b58","timeout":"\u8fde\u63a5\u8d85\u65f6\uff0c\u8bf7\u68c0\u67e5\u7f51\u7edc\u73af\u5883\uff0c\u6216\u91cd\u8bd5\uff01"};

 

</script>

<script src=‘/zentao/js/all.js?v=9.0.1‘ type=‘text/javascript‘></script>

<link rel=‘stylesheet‘ href=‘/zentao/theme/default/zh-cn.default.css?v=9.0.1‘ type=‘text/css‘ media=‘screen‘ />

<style>.dropdown-menu.with-search {padding: 0; min-width: 150px; overflow: hidden; max-height: 302px;}

.dropdown-menu > .menu-search .input-group {width:100%;}

.dropdown-menu > .menu-search .input-group-addon {position: absolute; right: 10px; top: 0; z-index: 10; background: none; border: none; color: #666}

.dropdown-menu > .menu-search .form-control {border: none!important; box-shadow: none!important; border-top: 1px solid #ddd!important;}

.dropdown-list {display: block; padding: 0; max-height: 270px; overflow-y: auto;}

.dropdown-list > li > a {display: block; padding: 3px 20px; clear: both; font-weight: normal; line-height: 1.53846154; color: #141414; white-space: nowrap;}

.dropdown-list > li > a:hover,

.dropdown-list > li > a:focus {color: #1a4f85;text-decoration: none;}

</style><link rel=‘icon‘ href=‘/zentao/favicon.ico‘ type=‘image/x-icon‘ />

<link rel=‘shortcut icon‘ href=‘/zentao/favicon.ico‘ type=‘image/x-icon‘ />

<!--[if lt IE 9]>

<script src=‘/zentao/js/html5shiv/min.js?v=9.0.1‘ type=‘text/javascript‘></script>

<script src=‘/zentao/js/respond/min.js?v=9.0.1‘ type=‘text/javascript‘></script>

<![endif]-->

<!--[if lt IE 10]>

<script src=‘/zentao/js/jquery/placeholder/min.js?v=9.0.1‘ type=‘text/javascript‘></script>

<![endif]-->

</head>

<body>

<script>

var noResultsMatch       = ‘没有匹配结果‘;

var chooseUsersToMail    = ‘选择要发信通知的用户...‘;

var defaultChosenOptions = {no_results_text: noResultsMatch, width:‘100%‘, allow_single_deselect: true, disable_search_threshold: 1, placeholder_text_single: ‘ ‘, placeholder_text_multiple: ‘ ‘, search_contains: true};

$(document).ready(function()

{

    $("#mailto").attr(‘data-placeholder‘, chooseUsersToMail);

    $("#mailto, .chosen, #productID").chosen(defaultChosenOptions).on(‘chosen:showing_dropdown‘, function()

    {

        var $this = $(this);

        var $chosen = $this.next(‘.chosen-container‘).removeClass(‘chosen-up‘);

        var $drop = $chosen.find(‘.chosen-drop‘);

        $chosen.toggleClass(‘chosen-up‘, $drop.height() + $drop.offset().top - $(document).scrollTop() > $(window).height());

    });

});

</script>

<header id=‘header‘>

  <div id=‘topbar‘>

    <div class=‘pull-right‘ id=‘topnav‘><div class=‘dropdown‘ id=‘userMenu‘><a href=‘javascript:;‘ data-toggle=‘dropdown‘><i class=‘icon-user‘></i> guest <span class=‘caret‘></span></a><ul class=‘dropdown-menu‘><li class=‘dropdown-submenu left‘><a href=‘javascript:;‘>主题</a><ul class=‘dropdown-menu‘><li class=‘theme-option active‘><a href=‘javascript:selectTheme("default");‘ data-value=‘default‘>默认</a></li><li class=‘theme-option‘><a href=‘javascript:selectTheme("green");‘ data-value=‘green‘>绿色</a></li><li class=‘theme-option‘><a href=‘javascript:selectTheme("red");‘ data-value=‘red‘>红色</a></li><li class=‘theme-option‘><a href=‘javascript:selectTheme("lightblue");‘ data-value=‘lightblue‘>亮蓝</a></li><li class=‘theme-option‘><a href=‘javascript:selectTheme("blackberry");‘ data-value=‘blackberry‘>黑莓</a></li></ul></li><li class=‘dropdown-submenu left‘><a href=‘javascript:;‘>Language</a><ul class=‘dropdown-menu‘><li class=‘lang-option active‘><a href=‘javascript:selectLang("zh-cn");‘ data-value=‘zh-cn‘>简体</a></li><li class=‘lang-option‘><a href=‘javascript:selectLang("zh-tw");‘ data-value=‘zh-tw‘>繁體</a></li><li class=‘lang-option‘><a href=‘javascript:selectLang("en");‘ data-value=‘en‘>English</a></li></ul></li></ul></div><a href=‘/zentao/user-login.html‘ >登录</a>

<div class=‘dropdown‘><a href=‘javascript:;‘ data-toggle=‘dropdown‘>帮助 <span class=‘caret‘></span></a><ul class=‘dropdown-menu pull-right‘><li><a href=‘javascript:;‘ class=‘open-help-tab‘>手册</a>

</li><li><a href=‘/zentao/misc-changeLog.html‘ class=‘iframe‘ data-width=‘800‘ data-headerless=‘true‘ data-backdrop=‘true‘ data-keyboard=‘true‘>修改日志</a>

</li></ul></div><a href=‘/zentao/misc-about.html‘ class=‘about iframe‘ data-width=‘900‘ data-headerless=‘true‘ data-backdrop=‘true‘ data-keyboard=‘true‘ data-class=‘modal-about‘>关于</a>

</div>

    <h5 id=‘companyname‘>

      易软天创项目管理系统    </h5>

  </div>

  <nav id=‘mainmenu‘>

    <ul class=‘nav‘>

<li class=‘active‘ data-id=‘my‘><a href=‘/zentao/my/‘ class=‘active‘><i class="icon-home"></i><span> 我的地盘</span></a></li>

<li  data-id=‘product‘><a href=‘/zentao/product/‘ >产品</a></li>

<li  data-id=‘project‘><a href=‘/zentao/project/‘ >项目</a></li>

<li  data-id=‘qa‘><a href=‘/zentao/qa/‘ >测试</a></li>

<li  data-id=‘doc‘><a href=‘/zentao/doc/‘ >文档</a></li>

<li  data-id=‘report‘><a href=‘/zentao/report/‘ >统计</a></li>

<li  data-id=‘company‘><a href=‘/zentao/company/‘ >组织</a></li>

<li class=‘custom-item‘><a href=‘/zentao/custom-ajaxMenu-my-index.html?onlybody=yes‘ data-toggle=‘modal‘ data-type=‘iframe‘ title=‘自定义导航‘ data-icon=‘cog‘ data-width=‘80%‘><i class=‘icon icon-cog‘></i></a></li></ul>

<div class=‘input-group input-group-sm‘ id=‘searchbox‘><div class=‘input-group-btn‘ id=‘typeSelector‘><button type=‘button‘ class=‘btn dropdown-toggle‘ data-toggle=‘dropdown‘><span id=‘searchTypeName‘>Bug</span> <span class=‘caret‘></span></button><input type=‘hidden‘ name=‘searchType‘ id=‘searchType‘ value=‘bug‘  />

<ul class=‘dropdown-menu‘><li><a href=‘javascript:;‘ data-value=‘bug‘>Bug</a></li><li><a href=‘javascript:;‘ data-value=‘story‘>需求</a></li><li><a href=‘javascript:;‘ data-value=‘task‘>任务</a></li><li><a href=‘javascript:;‘ data-value=‘testcase‘>用例</a></li><li><a href=‘javascript:;‘ data-value=‘project‘>项目</a></li><li><a href=‘javascript:;‘ data-value=‘product‘>产品</a></li><li><a href=‘javascript:;‘ data-value=‘user‘>用户</a></li><li><a href=‘javascript:;‘ data-value=‘build‘>版本</a></li><li><a href=‘javascript:;‘ data-value=‘release‘>发布</a></li><li><a href=‘javascript:;‘ data-value=‘productplan‘>产品计划</a></li><li><a href=‘javascript:;‘ data-value=‘testtask‘>测试版本</a></li><li><a href=‘javascript:;‘ data-value=‘doc‘>文档</a></li></ul></div><input type=‘text‘ name=‘searchQuery‘ id=‘searchQuery‘ value=‘‘ onclick=‘this.value=""‘ onkeydown=‘if(event.keyCode==13) shortcut()‘ class=‘form-control‘ placeholder=‘编号(ctrl+g)‘ />

<div id=‘objectSwitcher‘ class=‘input-group-btn‘><a href=‘javascript:shortcut();‘ class=‘btn‘>GO! </a></div></div>

  </nav>

  <nav id="modulemenu">

    <ul class=‘nav‘>

<li data-id=‘account‘><span id="myname"><i class="icon-user"></i> guest <i class="icon-angle-right"></i> </span></li>

<li class=‘ active‘ data-id=‘index‘><a href=‘/zentao/my/‘ >首页</a>

</li>

</ul>

  </nav>

</header>

 

<div id=‘wrap‘>

  <div class=‘outer‘>

<link rel=‘stylesheet‘ href=‘/zentao/theme/default/index.css?v=9.0.1‘ type=‘text/css‘ media=‘screen‘ 9.0.1 />

<html><meta charset=‘utf-8‘/><style>body{background:white}</style><script>self.location.reload(true);

 

</script>

 

接下来我们去zentao网页上去建立发布计划

具体流程请访问一下链接http://www.zentao.net/book/zentaopmshelp/38.html  

进入页面之后直接左边下拉找到你要看的流程就可以了。

 

 

自动部署的思路,使用jenkins作为任务的总调度师

1.jenkins首先调用svn更新代码

2.Jenkins再调用ant将工程打成war。并a拷贝到指定目录,这里的指定目录指web server读取源文件的目录(这个过程可由antbuild.xml完成,也可由一个单独的脚本完成)

3.jenkins再调用一个写好的脚本触发webserver更新应用程序。

 
















































以上是关于Linux下搭建jenkins+svn+http+maven自动化部署的主要内容,如果未能解决你的问题,请参考以下文章

linux+jenkins+svn环境搭建以及自动部署django项目构建配置

搭建持续集成单元测试平台(Jenkins+Ant+Java+Junit+SVN)

dubbo+dubbo-monitor+nexus+sonar+svn+jenkins+linux-dash搭建项目开发平台

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

Jenkins+sonar+tomcat+SVN集成搭建

Jenkins+Maven+SVN快速搭建持续集成环境