最近用到weblogic。之前一直用的是tomcat。。对于weblogic早有耳闻,也知道它的使用相对tomcat来说复杂得多。但早晚要用到,所以今天就折腾了一天来熟悉weblogic部署web项目。
【版本】wls1036
【weblogic】——weblogic是一个强大的集成工具,他具有“域”的概念。一个weblogic server可以包含若干个“域”,一个“域”又可以部署多个web项目。相对tomcat的单一,它更为体现”集成“的概念。
weblogic安装成功后,会有一个QUICKSTART的向导,我们可以利用该向导建立自己的第一个”域“(第一个Getting started with Weblogic Server),向导走完之后,会发现在%WLS_HOME%(该路径指的是weblogic安装路径,我的是e:/weblogic)。之后会发现在%WLS_HOME%\user_projects\domains下会有一个名为base_domain的”域“!
有了第一个”域“之后,我们就开始部署项目的探索。
正式开始之前,先要理解weblogic会有2中模式——开发模式(weblogic安装成功之后默认的模式)、生产模式(生产模式是指项目上线时的部署模式)。以及这2种模式的相互转换:(摘自:http://blog.csdn.net/cuihaiyang/article/details/8289148)
1、生产模式--》开发模式
将domain路径下%DOMAIN_HOME%\bin\setDomainEnv.cmd文件set PRODUCTION_MODE=true 更改为 set PRODUCTION_MODE=false 或set PRODUCTION_MODE=
将%DOMAIN_HOME%\config\config.xml文件中<production-mode-enabled>true</production-mode-enabled>更改为<production-mode-enabled>false</production-mode-enabled>或者直接删掉。
2、开发模式--》生产模式
将domain路径下%DOMAIN_HOME%\bin\setDomainEnv.cmd文件set PRODUCTION_MODE= 更改为 set PRODUCTION_MODE=true
ps:上面是Windows环境下更改配置的方法,linux环境下很类似。
第一种:自动部署——开发模式部署
(先通过相关域下的startWebLogic.cmd(Windows),startWebLogic.sh(Linux)命令开启weblogic Server)
在%DOMAIN_HOME%\user_projects\domains\base_domain\autodeploy下,把相关web项目的war包或者web项目下webRoot下的文件直接拷贝进去。(强调一下:在此之前weblogic Server必须是开启的状态),会发现日志文件%DOMAIN_HOME%\user_projects\domains\base_domain\servers\AdminServer\logs会有项目部署的日志。。部署完毕即可成功启动项目
【注】在”非“war包的方式时,拷贝进autodeploy目录下的必须是项目对应的webRoot下的文件,而非整个项目!!否则会编译不成功!
登录http://localhost:7001/console输入你安装weblogic时设置的管理用户名和密码,即可打开默认的”域“,
注意左上角会有一个更改中心(如果没有打开方式为: “首选项” --> “用户首选项” --> 去掉“自动获取锁并激活更改”前面的勾,点击“保存”,然后在控制台的左上角就能看到)——可以看到有2个按钮。。【锁定并编辑】是指通过控制台部署方式时,用户不能再通过自动部署的方式来部署项目,必须先【释放配置】之后吗,才能通过自动部署方式部署。这也是为啥我再还未释放配置操作时,试图通过自动部署方式部署项目时,报的如下错误:
weblogic.management.ManagementException: weblogic.management.ManagementException: [Deployer:149164]The domain edit lock is owned by another session in exclusive mode - hence this deployment operation cannot proceed.
at weblogic.management.deploy.ApplicationsDirPoller.doActivate(ApplicationsDirPoller.java:246)
at weblogic.management.deploy.GenericAppPoller.doit(GenericAppPoller.java:275)
at weblogic.management.deploy.GenericAppPoller$PollerTimerListener.timerExpired(GenericAppPoller.java:476)
at weblogic.timers.internal.TimerImpl.run(TimerImpl.java:273)
at weblogic.work.SelfTuningWorkManagerImpl$WorkAdapterImpl.run(SelfTuningWorkManagerImpl.java:545)
at weblogic.work.ExecuteThread.execute(ExecuteThread.java:256)
at weblogic.work.ExecuteThread.run(ExecuteThread.java:221)
对这2个按钮可与【数据库的事务控制】联想起来,如果需要在控制台操作部署项目时,必须先点【锁定并编辑】来锁住事务,修改完毕之后,必须点【释放配置】来释放事务,以便用户可以在自动部署里do something。。
点开左侧”域结构“【部署】选项,可以看到如下所示:
会看到有一个自动部署的标识,该标志表示该web项目是是通过【自动部署】的方式来部署的,从而在控制台无权删除:
自动部署完毕之后,%DOMAIN_HOME%\user_projects\domains\base_domain\config\config.xml会自动在<configuration-version>和<admin-server-name>添加如下内容:
<app-deployment> <name>_appsdir_itmon_demo_war</name> <target>AdminServer</target> <module-type>war</module-type> <source-path>autodeploy\itmon_demo.war</source-path> <security-dd-model>DDOnly</security-dd-model> <staging-mode>stage</staging-mode> </app-deployment>
【注意】如果拷贝的war包,module-type即为war。如果是拷贝的webRoot下的东东,module-type即为dir
——因此:还有一种方式,可以不拷贝war包或webRoot,直接手工在config.xml下添加如上所示内容,再启动weblogic Server(是先添加再启动!!),也是可以部署成功的!!!(不过这种好像体现不出”自动“了。。。。。。。。)
第二种:控制台部署——生产模式部署
这种方式就是在控制台走流程了。。。。。(其实并不需要切换到生产模式再部署)
域结构->部署->安装->路径(填war包路径或者dir路径(dir时,是webRoot对应的路径而非整个web项目。。。))->N多下一步->完成保存(然后还必须记得激活)
此时就没有了(自动部署)的字样,当然就可以在控制台删除已部署的项目了
完了记得释放配置……
还有些小问题,也记录下吧。。
------------------------
因为通过dir的形式时,为了在控制台显示web名比较好看,我把webRoot改成跟项目名一样了,于是。。一堆问题出现。因为项目中src下的类是默认是去webRoot\WEB-INF\lib下找要用到的jar包,但你改了webRoot之后,这些类并不能如此”智能“地在你改过名字之后的webRoot(比如此时是abc)即abc下找jar包。。所以就会报错。
【注意】如果不改WebRoot的话,成功部署后访问web项目就必须是(eg).http://localhost:7001/WebRoot
解决办法:build path下default output folder要改现在的路径,重点是workspace下项目中的.settings/org.eclipse.wst.common.component也要改<wb-resource deploy-path="/" source-path="abc"
还有<property name="java-output-path" value="/xxx/abc/WEB-INF/classes"/>然后再refresh项目即可……
【总结】:
weblogic部署项目有三种方式——先启动server再自动部署,修改config.xml之后再启动server部署,和先启动server再在控制台部署。