您的位置:首页 > 运维架构 > Tomcat

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

2016-11-20 02:11 801 查看
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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐