记录初衷:
由于每次项目部署非常痛苦,很麻烦,遂使用jenkins来部署项目,只需点击即可,但是网上不论是百度还是google关于jenkins集成weblogic部署项目的资料非常少,至少通过我的搜索没有找到一篇非常完整的,所以以次来记录,给大家提供一点参考。(此次记录包含了集成weblogic和tomcat)
整合过程:
Jenkins搭建环境
CentOS6.5(系统环境)
JDK6u45(由于系统用的是weblogic10.3.5只能用JDK6了,官方提供了升级JDK7的方法,先不折腾了)
SVN
Jenkins-1.596.3(貌似是JDK6u45能支持到的最高版本,有兴趣的可以继续升级试试)
Jenkins官网:https://jenkins.io/index.html
Jenkins资源地址(各个版本及插件):http://mirrors.jenkins.io
Tomcat7.x(随便一个版本即可)
Weblogic10.3.5(坑爹的版本,跟weblogic集成各种坑)
Maven3.2.5(JDK6u45最高支持到该版本,否则就得升级为JDK7.x)
Ant1.9.7(这个好像没啥要求,主要用来编译打包非Maven项目,非Maven项目的Ant编译也有问题,再此做记录!!!)
Jenkins启动
将jenkins的war包部署到应用服务器(我用的是Tomcat7)启动即可
jenkins启动完成后会生成一个目录:/用户/.jenkins
.jenkins目录中会有workspace这么个目录(执行构建后会从svn上down下来文件并根据项目类型执行具体的编译打包如Ant或Maven [该目录下也会按项目分目录 如:ECP])
Jenkins基础配置
主界面(就这个熊样子)
1. 系统设置
里面的配置项非常多,截图显示不全,只需要配置我们关心的配置!!!
其他的都不管,直接找到这里,全部配好!!!省的别的地方报错!别管用不用得到,配上再说(一定要保证配对!!!)。
JDK配置
ANT配置(规则同上)
MAVEN配置(规则同上)
最后别忘了保存!!!
2. 权限配置
Jenkins1.596.3+Jdk6u45+Maven3.2.5+Tomcat7.x+SVN自动部署项目(很简单只要步骤对都能成功)
在这之前,需要先在Jenkins里新增一个插件(deploy-1.10.hpi)
直接选<高级>即可,<可更新>和<可选插件>可能报错,用不到不用管。
开始新建
配置svn地址(此处svn地址最后需要跟上@HEAD:https://10.2.254.79/svn/CCI/EBT1/02-Engineering_工程/04-Code_实现/ECP@HEAD否则jenkins同步svn代码会有延迟!)
设置svn用户名密码,设置完后回到项目配置页面重新配置svn地址即可
构建后操作(只有当deploy-1.10.hpi插件安装后才会有该选项!!!)
选择完tomcat后需要配置tomcat的用户名密码!!!
在tomcat目录(此处的tomcat目录一定是你要把项目发布到的tomcat的目录!!!)/conf/tomcat-users.xml中配置用户名密码,省事儿直接copy下面这段
执行构建 会在.jenkins/workspace目录下生成一个文件夹ECP(jenkins中建的项目叫啥就生成啥)会把项目从svn上全down下来进行构建
Jenkins1.596.3+Jdk6u45+Ant+Weblogic10.3.5+SVN自动部署项目(巨TM费劲,weblogic需要单独插件才能部署,并且插件的使用方法非常模糊,关于jenkins部署weblogic的文档网上资源稀少,特此记录)
在这之前,需要先在Jenkins里新增一个插件(weblogic-deployer-plugin-3.6.hpi)
添加插件步骤跟之前一样,不重复了
非Maven项目选这个吧
和之前一样
非Maven项目需要用Ant编译打包
Ant Version:只有在jenkins系统设置里配过,这里才能选择!!!
Targets:ant构建时默认会执行 ant 命令,如果需要另外的参数写到这里就行
选这个(只有安装了weblogic-deployer-plugin-3.6.hpi插件才有该选项)
此时你会毛都没看到,页面上没有任何显示,也不报错,第一个坑来了
看jenkins所在tomcat的日志catalog.out文件
点击这个选项时报了这么个错
2017-1-10 13:51:27hudson.widgets.RenderOnDemandClosure$1 generateResponse
警告: Failed toevaluate the template closure
org.apache.commons.jelly.JellyTagException:jar:file:/root/.jenkins/plugins/weblogic-deployer-plugin/WEB-INF/lib/classes.jar!/org/jenkinsci/plugins/deploy/weblogic/WeblogicDeploymentPlugin/config.jelly:17:138:
atorg.apache.commons.jelly.tags.core.InvokeStaticTag.createLoadClassFailedException(InvokeStaticTag.java:177)
atorg.apache.commons.jelly.tags.core.InvokeStaticTag.doTag(InvokeStaticTag.java:139)
atorg.apache.commons.jelly.impl.TagScript.run(TagScript.java:269)
at org.apache.commons.jelly.impl.ScriptBlock.run(ScriptBlock.java:95)
atorg.apache.commons.jelly.tags.core.CoreTagLibrary$2.run(CoreTagLibrary.java:105)
atorg.kohsuke.stapler.jelly.JellyViewScript.run(JellyViewScript.java:95)
at org.kohsuke.stapler.jelly.IncludeTag.doTag(IncludeTag.java:147)
atorg.apache.commons.jelly.impl.TagScript.run(TagScript.java:269)
atorg.kohsuke.stapler.jelly.CallTagLibScript$1.run(CallTagLibScript.java:99)
atorg.apache.commons.jelly.tags.define.InvokeBodyTag.doTag(InvokeBodyTag.java:91)
atorg.apache.commons.jelly.impl.TagScript.run(TagScript.java:269)
atorg.apache.commons.jelly.impl.ScriptBlock.run(ScriptBlock.java:95)
atorg.apache.commons.jelly.TagSupport.invokeBody(TagSupport.java:161)
atorg.apache.commons.jelly.tags.core.OtherwiseTag.doTag(OtherwiseTag.java:41)
atorg.apache.commons.jelly.impl.TagScript.run(TagScript.java:269)
atorg.apache.commons.jelly.impl.ScriptBlock.run(ScriptBlock.java:95)
atorg.apache.commons.jelly.TagSupport.invokeBody(TagSupport.java:161)
atorg.apache.commons.jelly.tags.core.ChooseTag.doTag(ChooseTag.java:38)
atorg.apache.commons.jelly.impl.TagScript.run(TagScript.java:269)
at org.apache.commons.jelly.impl.ScriptBlock.run(ScriptBlock.java:95)
atorg.apache.commons.jelly.tags.core.CoreTagLibrary$2.run(CoreTagLibrary.java:105)
atorg.kohsuke.stapler.jelly.CallTagLibScript.run(CallTagLibScript.java:120)
at org.kohsuke.stapler.jelly.CallTagLibScript$1.run(CallTagLibScript.java:99)
atorg.kohsuke.stapler.jelly.DefaultScriptInvoker.invokeScript(DefaultScriptInvoker.java:63)
atorg.kohsuke.stapler.jelly.DefaultScriptInvoker.invokeScript(DefaultScriptInvoker.java:53)
athudson.widgets.RenderOnDemandClosure$1.generateResponse(RenderOnDemandClosure.java:99)
atorg.kohsuke.stapler.HttpResponseRenderer$Default.handleHttpResponse(HttpResponseRenderer.java:124)
at org.kohsuke.stapler.HttpResponseRenderer$Default.generateResponse(HttpResponseRenderer.java:69)
atorg.kohsuke.stapler.Function.renderResponse(Function.java:113)
atorg.kohsuke.stapler.Function.bindAndInvokeAndServeResponse(Function.java:98)
at org.kohsuke.stapler.MetaClass$JavaScriptProxyMethodDispatcher.doDispatch(MetaClass.java:470)
atorg.kohsuke.stapler.NameBasedDispatcher.dispatch(NameBasedDispatcher.java:53)
atorg.kohsuke.stapler.Stapler.tryInvoke(Stapler.java:746)
at org.kohsuke.stapler.Stapler.invoke(Stapler.java:876)
atorg.kohsuke.stapler.MetaClass$12.dispatch(MetaClass.java:391)
atorg.kohsuke.stapler.Stapler.tryInvoke(Stapler.java:746)
atorg.kohsuke.stapler.Stapler.invoke(Stapler.java:876)
atorg.kohsuke.stapler.Stapler.tryInvoke(Stapler.java:813)
atorg.kohsuke.stapler.Stapler.invoke(Stapler.java:876)
atorg.kohsuke.stapler.Stapler.invoke(Stapler.java:649)
atorg.kohsuke.stapler.Stapler.service(Stapler.java:199)
atjavax.servlet.http.HttpServlet.service(HttpServlet.java:722)
atorg.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:306)
atorg.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
athudson.util.PluginServletFilter$1.doFilter(PluginServletFilter.java:96)
athudson.util.PluginServletFilter.doFilter(PluginServletFilter.java:88)
atorg.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:244)
atorg.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at hudson.security.csrf.CrumbFilter.doFilter(CrumbFilter.java:48)
atorg.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:244)
atorg.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
athudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:84)
athudson.security.UnwrapSecurityExceptionFilter.doFilter(UnwrapSecurityExceptionFilter.java:51)
athudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:87)
atjenkins.security.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:117)
athudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:87)
atorg.acegisecurity.providers.anonymous.AnonymousProcessingFilter.doFilter(AnonymousProcessingFilter.java:125)
athudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:87)
atorg.acegisecurity.ui.rememberme.RememberMeProcessingFilter.doFilter(RememberMeProcessingFilter.java:142)
athudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:87)
atorg.acegisecurity.ui.AbstractProcessingFilter.doFilter(AbstractProcessingFilter.java:271)
at hudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:87)
atjenkins.security.BasicHeaderProcessor.doFilter(BasicHeaderProcessor.java:93)
athudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:87)
at org.acegisecurity.context.HttpSessionContextIntegrationFilter.doFilter(HttpSessionContextIntegrationFilter.java:249)
athudson.security.HttpSessionContextIntegrationFilter2.doFilter(HttpSessionContextIntegrationFilter2.java:67)
at hudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:87)
athudson.security.ChainedServletFilter.doFilter(ChainedServletFilter.java:76)
athudson.security.HudsonFilter.doFilter(HudsonFilter.java:168)
atorg.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:244)
atorg.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
atorg.kohsuke.stapler.compression.CompressionFilter.doFilter(CompressionFilter.java:49)
atorg.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:244)
atorg.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at hudson.util.CharacterEncodingFilter.doFilter(CharacterEncodingFilter.java:81)
atorg.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:244)
atorg.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
atorg.kohsuke.stapler.DiagnosticThreadNameFilter.doFilter(DiagnosticThreadNameFilter.java:30)
atorg.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:244)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
atorg.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:240)
atorg.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:161)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:589)
atorg.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:164)
atorg.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
atorg.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:541)
atorg.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
atorg.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:383)
atorg.apache.coyote.http11.Http11Processor.process(Http11Processor.java:243)
atorg.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:188)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:166)
atorg.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:288)
atjava.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:895)
atjava.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:918)
atjava.lang.Thread.run(Thread.java:662)
Caused by:java.lang.NoSuchMethodException:org.jenkinsci.plugins.deploy.weblogic.jdk.JdkToolService.getJDKHomeByName(java.lang.Object)
atjava.lang.Class.getMethod(Class.java:1607)
atorg.apache.commons.jelly.tags.core.InvokeStaticTag.doTag(InvokeStaticTag.java:124)
... 93 more
这个错误在网上根本查不到解决办法,遂想到是不是刚刚安装的weblogic插件需要设置什么东西没设导致的错误,重新进到<系统设置>一直往下拉发现有个weblogic的设置。。。设置吧,不知道咋设置吧,找官网!!!
有了,有些选项设置起来依然费劲,猜着来吧
configuration.xml官网给的参考
我的configuration.xml文件内容及格式(注意:该文件内容修改后需要重启jenkins)
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://org.jenkinsci.plugins/WeblogicDeploymentPluginplugin-configuration.xsd"> 重新选择该项,发现页面有反应了,第一个坑至此算解决完了!!! 别忘了检查前面的设置对不对,有可能没保存 看到下面这个配置项中的Environment项我突然明白上面配置的configuration.xml中的 保存成功后执行构建(跟之前一样),去看jenkins控制台吧! 若上图中的Targets参数不为空,则jenkins控制台输出为(一部分): /opt/jdk1.6.0_45/bin/java-Xms256M -Xmx1024M -cp /bea/wlserver_10.3/server/lib/weblogic.jarweblogic.Deployer -debug -stage -remote -verbose -upload -name EBT-WX-UAT-source /root/.jenkins/workspace/EBT-WX-UAT/target/EBT.war -targets AdminServer(或其他文本框中输入的值) -adminurl t3://10.1.1.66:7001-user weblogic -password 123QWe!@# -deploy (由此看出jenkins往weblogic部署war包是直接通过命令部署) 不知道为啥,只要带上Targets参数就部署报错,一开始也不知道是因为这个参数导致部署失败,所以查了一下weblogic用命令部署war包的命令,都没有用targets参数的,所以尝试清空上图中的Targets的值,可以看到jenkins控制台输出的命令为: /opt/jdk1.6.0_45/bin/java-Xms256M -Xmx1024M -cp /bea/wlserver_10.3/server/lib/weblogic.jarweblogic.Deployer -debug -stage -remote -verbose -upload -name EBT-WX-UAT-source /root/.jenkins/workspace/EBT-WX-UAT/target/EBT.war -targets -adminurl t3://10.1.1.66:7001 -user weblogic-password 123QWe!@# -deploy 可以看到-targets参数后面已经没值了,部署成功!!! 注意:weblogic控制台这里一定要是释放配置的状态!!!否则你别想用jenkins部署成功! 这算是第二个坑吧 Ant编译遇到的坑 build.xml尽量用eclipse或者其他开发工具倒出来! 此时项目下会生成一个build.xml文件,执行ant命令时默认是build,只编译,不会打war包,需要加上这种配置。 我的配置 上面红色字体需要特别注意,在Ant编译时遇到的坑: 1. 如果java代码中用到了Sun内部的api时会编译报错 需要该配置 2. Ant编译时报GBK乱码错误需要增加该参数 encoding="UTF-8" 3. Ant编译时报什么“泛型无法转换无法确定 注意,想用JDT编译有两种方法,推荐方法一和方法二,更简单 方法一: 直接把tomcat安装目录lib目录下的ecj开头的jar包copy到ant安装目录的lib目录 方法二: 去maven仓库搜索ecj,选择Eclipse ECJ 一开始我用的是4.5版本,copy到ant下的lib目录执行ant命令还是报错,思路是对的,可能版本不对,试着降低版本直接用了4.2.2版本copy进去,重新执行ant命令,成功!!! 方法二: 需要去eclipse或者Myeclipse的安装目录的plugin目录中找到以下几个jar) 1. org.eclipse.jdt.compiler.tool开头jar包 2. org.eclipse.jdt.core开头jar包 3. org.eclipse.jdt.debug.ui开头jar包 4. jdtCompilerAdapter.jar这个jar包需要从org.eclipse.jdt.core开头jar包中找到(麻烦) 注:这几个jar包当时从我机器上的eclipse安装目录的pulugin中找这几个jar包copy到ant安装目录的lib目录下执行ant命令还是报错,后来又从别人Myeclipse2014安装目录的pulugin中找到,重复copy步骤,重新执行ant命令编译,成功!!! 如何修改该编译Bug: 1. 将方法一中的ecj-4.2.2.jar或方法二中的几个jar包copy到ant安装目录的lib目录下 2. build.xml中增加 好了,用ant重新编译吧,再有错你来找我!!! 现在只想静静。。。 至此所有的坑都没了。。。