使用jekins自动构建部署java maven项目的方法步骤
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
到此这篇关于使用jekins自动构建部署java maven项目的方法步骤的文章就介绍到这了,更多相关jekins自动构建部署java maven项目内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!