使用jekins自动构建部署java maven项目(jdk1.7+tomcat7.0+jenkins2.19.3)

原文:https://www.cnblogs.com/hdwang/p/6081994.html

 

 

1.下载jenkins

地址:https://jenkins.io/index.html

本人下载了2.19.3版本的war包:jenkins.war

 

2.安装jenkins

  拷贝jenkins.war到tomcat的webapps文件夹下,如果tomcat是启动的,jenkins项目会自动解压启动的,如果tomcat是停止的,需要启动tomcat服务,进入bin文件夹,linux环境下执行 ./startup.sh即可启动服务,windows下双击startup.bat即可。

然后,访问地址:http://192.168.17.155:8080/jenkins ,具体ip为你部署的机器的ip, 看到如下界面,那么恭喜你,jenkins启动了。

为了安全,jenkins要求你填写初始化密码,密码在提示的文件里面,找到该文件,拷贝出密码,填写在下面的文本框中,点击Continue即可。(如果windows下,tomcat的控制台也能看到提示的密码,linux下查看tomcat的catalina.out这个日志文件中也能找到此密码。)

选择安装方式,选择第一种即可,点击一下,进入如下界面

各种插件安装完后,开始设置账户信息,以后用此账户登录jenkins

然后进入首页

 

3.安装插件

上述默认安装的插件还不够

依次点击 系统管理->插件管理-> 可选插件-> 过滤搜索框中 查找如下插件:

Maven Integration plugin

SSH plugin

Deploy to container Plugin

 

4.新建构建任务

 找到代码管理的地方,如果是svn管理的,请选择Subversion,填入项目地址和账号信息,如果是git,填写git信息即可

构建触发器,去掉所有勾选,采用手动点击触发即可

上述信息提示配置一下maven的安装路径,我们照做即可,顺便配置好jdk路径

maven构建命令配置

 

 部署配置

tomcat用户在conf/tomcat-user.xml里面配置即可,下面给出配置

复制代码
<tomcat-users>

 <role rolename="manager-gui" />
 <role rolename="manager-status" />
 <role rolename="manager-jmx" />
 <role rolename="manager-script"/>
 <role rolename="admin-gui"/>
 <role rolename="admin-script"/>

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

</tomcat-users>
复制代码

保存配置

 

5.构建

点击导航jenkins -> My Views -> 点击study项目-> 立即构建

如果发现界面卡死,可能是jdk内存溢出,出现如下

设置一下tomcat的jdk参数即可

windows在catalina.bat 文件里添加如下参数(添加到文件开头):

set JAVA_OPTS=-server -XX:PermSize=512M -XX:MaxPermSize=2048M -Xms512M -Xmx2048M -XX:MaxNewSize=512M

linux在catalina.sh文件里添加如下参数(添加到文件开头):

JAVA_OPTS="-server -XX:PermSize=256M -XX:MaxPermSize=1024m -Xms512M -Xmx1024M -XX:MaxNewSize=256m"

是否添加成功,可以使用 jps -v 命令查看(windows和linux下均可)

 

 

重新启动tomcat,重新点击构建即可,在Console Output里可以看到整个构建的过程,出现如下图就表示整个构建部署成功了

 

6.附上shell脚步部署方式,更加灵活些(jenkins和服务器必须都是linux机器)

 

思路就是,执行远程脚本关闭tomcat,然后执行本地脚本拷贝文件到远程,再执行远程脚本启动tomcat服务。上述scp命令传输文件不用密码,必须配置一下ssh的密钥对,配置方式如下:

 

这里假设主机A(192.168.100.3)用来获到主机B(192.168.100.4)的文件。

在主机A上执行如下命令来生成配对密钥:
ssh-keygen -t rsa

遇到提示回车默认即可,公钥被存到用户目录下.ssh目录,比如root存放在:

/root/.ssh/id_rsa.pub

将 .ssh 目录中的 id_rsa.pub 文件复制到 主机B 的 ~/.ssh/ 目录中,并改名为 authorized_keys,
到主机A中执行命令和主机B建立信任,例(假设主机B的IP为:192.168.100.4):

scp ~/.ssh/id_rsa.pub 192.168.100.4:/root/.ssh/authorized_keys

下面就可以用scp、ssh命令不需要密码来获取主机B的文件了
ssh 192.168.100.4 回车就不需要密码了。

 

如果机器B添加多个别的机器的公钥,则需要在authorized_keys中追加公钥内容,命令如下:
cat id_rsa.pub >> /root/.ssh/authorized_keys
 
 
posted @ 2019-04-11 19:31  panchanggui  阅读(393)  评论(0编辑  收藏  举报