Jenkins+SVN+Maven+Shell 实现项目一键发布

简介:

这才是最好的jenkins教程,maven

  • 前言

众所周知,Jenkins默认情况下可以实现项目更新(通过SVN),和项目发布,通过(MAVEN插件),但是这种情况下发布到一些容器底下(如Tomcat)时,经过多次发布后JVM会报OutOfMemoryError PermGen space,这个原因是由于这些容器在覆盖老项目后并不会释放老项目内存永久区的资源,久而久之,导致系统永久区内存溢出。为解决这个问题,我们只有通过发布后重新启动容器才能解决该问题。那有什么办法可以使容器在发布新项目后自动重启呢?重启过程中,我们希望容器正在处理的作业安全完成后(如quartz作业执行完后),容器再重启,如何做到?本文要与大家分享的便是其中一种便利安全的方法。


  • Jenkins安装与配置

Jenkins是一个开源软件项目,旨在提供一个开放易用的软件平台,使持续集成变成可能。

安装:

官网:http://jenkins-ci.org/

选择一个操作系统版本的安装,我这边选择的是 Red Hat/Fedora/CentOS

安装及启动过程:

 

Ruby代码  收藏代码

  1. rpm -ivh jenkins-1.590-1.1.noarch.rpm     

  2. service jenkins start  

 

 

访问:

http://<ip>:8080/


  • Publish Over SSH插件安装


依次单击“Jenkins->系统管理->管理插件菜单


在可选插件选项卡中找到勾选Publish Over SSH插件,点击界面下方的直接安装按钮。等待jenkins安装完毕即可。


  • Publish Over SSH插件配置

全局配置:


依次点开“Jenkins->系统管理->系统设置菜单

找到Publish over SSH配置项,配置如下配置


底下还有个Test Configuration按钮,点击,如出现Success则表示配置成功。


最后点击页底的保存按钮,完成配置。


  • 创建Jenkins Item

直接点击Jenkins首页的新建按钮,创建一个Maven项目,配置根据大家需要,实际配置,本文仅列出作者的配置,供参考:




如何区分开环境 clean package -Dmaven.test.skip=true -Denv=prod



其中Exec command的脚本是一个shell文件,放置在远程发布机上后,可执行参数有三个,分别如下,第一个参数必填,后面两个选填,默认值是8080和/save/apache-tomcat-7.0.56,大家可以在第六节的SHELL脚本中改成大家项目中自己的默认参数。

Ruby代码  收藏代码

  1. ./publish.sh <项目WEB显示名称> [TOMCAT端口] [tomcat安装主目录]  

 

  • 编写Shell脚本

需要在你发布的目标机器上编写该脚本,你也可以在开发环境编好后,放到目标机器上,以下给出我的脚本:

 

Ruby代码  收藏代码

  1. #!/bin/bash  

  2. #defined   

  3. TOMCAT_HOME="/save/apache-tomcat-7.0.56"  

  4. TOMCAT_PORT=8080  

  5. PROJECT="$1"  

  6. #param validate  

  7. if [ $# -lt 1 ]; then    

  8.   echo "you must use like this : ./publish.sh <projectname> [tomcat port] [tomcat home dir]"    

  9.   exit    

  10. fi   

  11. if [ "$2" != "" ]; then  

  12.    TOMCAT_PORT=$2  

  13. fi  

  14. if [ "$3" != "" ]; then  

  15.    TOMCAT_HOME="$3"  

  16. fi  

  17. #shutdown tomcat  

  18. "$TOMCAT_HOME"/bin/shutdown.sh  

  19. echo "tomcat shutdown"  

  20. #check tomcat process  

  21. tomcat_pid=`/usr/sbin/lsof -n -P -t -i :$TOMCAT_PORT`  

  22. echo "current :" $tomcat_pid  

  23. while [ -n "$tomcat_pid" ]  

  24. do  

  25.  sleep 5  

  26.  tomcat_pid=`/usr/sbin/lsof -n -P -t -i :$TOMCAT_PORT`  

  27.  echo "scan tomcat pid :" $tomcat_pid  

  28. done  

  29. #publish project  

  30. echo "scan no tomcat pid,$PROJECT publishing"  

  31. rm -rf "$TOMCAT_HOME"/webapps/$PROJECT*  

  32. cp /save/$PROJECT*.war "$TOMCAT_HOME"/webapps/$PROJECT.war  

  33. #bak project  

  34. BAK_DIR=/save/bak/$PROJECT/`date +%Y%m%d`  

  35. mkdir -p "$BAK_DIR"  

  36. cp "$TOMCAT_HOME"/webapps/$PROJECT.war "$BAK_DIR"/"$PROJECT"_`date +%H%M%S`.war  

  37. #remove tmp  

  38. rm -rf /save/$PROJECT*.war  

  39. #start tomcat  

  40. "$TOMCAT_HOME"/bin/startup.sh  

  41. echo "tomcat is starting,please try to access $PROJECT conslone url"   


该脚本具有自动安全停Tomcat,自动发布项目,自动备份已发布项目版本的功能。

需要注意的是你连上来的admin用户需要具有执行该文件的权限,如果没有可以

chmod 600(755) publish.sh

具体权限给多少,根据你们的需要,决定权在你们手上。


如果shell执行出现如下错误,则可能是你在etc/profile中设置了JAVA_HOME,同时您还需要在/etc/bashrc也设置JAVA_HOME。


 

原因:远程机器的java_home在配置在/etc/profile中的,这个只给shell用户使用的;

但对于ssh 这种非login shell(non-login shell)用户,需要配置在/etc/bashrc中。

参考配置:

 

Ruby代码  收藏代码

  1. export JAVA_HOME=/usr/java/jdk1.6.0_45  

  2. export JAVA_BIN=/usr/java/jdk1.6.0_45/bin  

  3. export PATH=$PATH:$JAVA_HOME/bin  

如果以上配置还不能解决你的问题,尝试下去的做法:

---------------------------------------------修改.bash_profile文件开始----------------------------------

修改.bash_profile文件方式是用户级的,对当前用户可用,其它用户无法使用。这种方式一般用于生产。.bash_profile文件在用户的根目录,比如说www用户的根目录是/home/www。

具体配置如下:

Java代码  收藏代码

  1. cd /home/www/  

  2. vim .bash_profile  

 

 

插入下面3行配置后保存退出:

Ruby代码  收藏代码

  1. export JAVA_HOME=/usr/java/jdk1.6.0_45/  

  2. export PATH=$JAVA_HOME/bin:$PATH  

  3. export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar  

 

---------------------------------------------修改.bash_profile文件结束----------------------------------



本文转自 liqius 51CTO博客,原文链接:http://blog.51cto.com/szgb17/1956416,如需转载请自行联系原作者
相关文章
|
14小时前
|
Java Apache Maven
Maven 项目文档
在C:/MVN下,使用命令`mvn archetype:generate -DgroupId=com.companyname.bank -DartifactId=consumerBanking -DarchetypeArtifactId=maven-archetype-quickstart -DinteractiveMode=false`创建Maven Java项目。确保`pom.xml`包含`maven-site-plugin`和`maven-project-info-reports-plugin`配置,版本分别至少为3.3和2.7,以避免`NoClassDefFoundError`。
|
1天前
|
前端开发 JavaScript Java
Maven实战 Item3 -- Maven项目构建2_构建一个maven2 3项目
Maven实战 Item3 -- Maven项目构建2_构建一个maven2 3项目
|
1天前
|
JavaScript 安全 前端开发
Maven实战 Item2 -- Maven项目构建(手动)_term2 配置maven(2)
Maven实战 Item2 -- Maven项目构建(手动)_term2 配置maven(2)
|
1天前
|
前端开发 Java Maven
Maven实战 Item2 -- Maven项目构建(手动)_term2 配置maven(1)
Maven实战 Item2 -- Maven项目构建(手动)_term2 配置maven(1)
|
2天前
|
Java Maven
SpringBoot项目的用maven插件打包报Test错误
SpringBoot项目的用maven插件打包报Test错误
|
3天前
|
存储 Java Maven
Maven 构建 Java 项目
使用 Maven 的 `maven-archetype-quickstart` 插件在 `C:\MVN` 创建 Java 应用项目 `consumerBanking`,命令行参数包括 `-DgroupId`, `-DartifactId` 和 `-DarchetypeArtifactId`。项目包含 src/main/java 和 src/test/java 目录,分别存放 Java 代码和测试代码,以及 src/main/resources 用于存储资源文件。默认生成的 `App.java` 和 `AppTest.java` 分别为应用主类和测试类。
|
3天前
|
jenkins 网络安全 持续交付
新的centos7.9安装docker版本的jenkins2.436.1最新版本-后端项目发布(四)
新的centos7.9安装docker版本的jenkins2.436.1最新版本-后端项目发布(四)
15 3
|
3天前
|
Java 开发工具 git
新的centos7.9安装docker版本的jenkins2.436.1最新版本-项目发布(三)
新的centos7.9安装docker版本的jenkins2.436.1最新版本-项目发布(三)
12 4
|
3天前
|
XML Java 测试技术
Maven 构建 & 项目测试
本文介绍了如何使用Maven构建和测试Java应用。在`C:/MVN/consumerBanking`项目中,`pom.xml`配置了JUnit作为测试框架。执行`mvn clean package`命令进行构建,Maven会清理目标目录,编译源码和测试代码,运行测试用例,最后生成`consumerBanking-1.0-SNAPSHOT.jar`。测试报告位于`surefire-reports`文件夹。添加新Java类`Util.java`到项目后,更新`App.java`以使用`Util`类。
|
3天前
|
Java Apache Maven
Maven 项目文档
在 `C:/MVN` 目录下创建 Maven 项目 `consumerBanking` 使用命令:`mvn archetype:generate -DgroupId=com.companyname.bank -DartifactId=consumerBanking -DarchetypeArtifactId=maven-archetype-quickstart -DinteractiveMode=false`。为解决 `mvn site` 命令执行时的 `NoClassDefFoundError`

推荐镜像

更多