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 回车就不需要密码了。