SOA On Tomcat专题4--整合步骤之准备

.下载apache-tomcat-6.0.20.zip,解压,设置完环境变量后直接启动,OK

.JBOSS中公共lib包拷贝至${Tomcat}\lib目录,其中el-api.jar覆盖、jsp-api.jar、servlet-api.jar覆盖Tomcat中原始jar

,为了支持Spring+Hibernate需在lib中添加以下三个jar包hibernate-core-3.3.1.GA.jar、hibernate-annotations-3.4.0.GA.jar、hibernate-commons-annotations-3.1.0.GA.jar,这一步每个人都不同

三.应用都要读取*.perperties,这样的目的是保证以可配置的方式,防止写死代码,比如JNDI数据源,还有一些文件路径,个性化需求IP啊,端口啊。

    最开始的时候,我启动了一个应用,然后在这个应用中的web.xml配置一个监听器,,但如何保证这个应用第一个启动呢,网上搜了一些资料,但显得不够优雅,也无法保证一定第一个启动,而且最完美的情况是在server.xml中配置,这样容器启动前就能完成准备工作。

    在server.xml中配置一个监听器,第一个就是我自己写的,在这个监听器中只要继承一个Tomcat生命周期的LifecycleListener接口就可以了,构建应用的环境需要用到的jar包,大家可以去${tomcat}/lib中寻找,然后将包含这个监听器的JAVA Project用eclipse导出为jar包,放置在${tomcat}/lib中,这个监听器有可能会多次启动,要注意代码控制逻辑


<Server port="8005" shutdown="SHUTDOWN">
  <Listener className="com.shine.zgy.PropertiesListener"/>
  <!--APR library loader. Documentation at /docs/apr.html -->
  <Listener SSLEngine="on" className="org.apache.catalina.core.AprLifecycleListener"/>
  <!--Initialize Jasper prior to webapps are loaded. Documentation at /docs/jasper-howto.html -->
  <Listener className="org.apache.catalina.core.JasperListener"/>
  <!-- JMX Support for the Tomcat server. Documentation at /docs/non-existent.html -->
  <Listener className="org.apache.catalina.mbeans.ServerLifecycleListener"/>
  <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener"/> 

这样所有的准备工作都可用监听器的方式完成

 

下面是这个监听器的代码给大家参考:

package com.shine.zgy;

import org.apache.catalina.LifecycleEvent;
import org.apache.catalina.LifecycleListener;
import org.springframework.util.StringUtils;

import com.shine.util.PropertiesReader;

public class PropertiesListener implements LifecycleListener{

    @Override
    public void lifecycleEvent(LifecycleEvent arg0) {
            //防止多次被读取
            try {
                PropertiesReader.getProperty("com.shine.pub.conf.url");
            } catch (Exception e) {
                //shine.properties要覆盖shine-default.properties
                PropertiesReader.loadProperties("conf/shine","shine-default.properties");
                PropertiesReader.loadProperties("conf/shine","shine.properties");
                //#shine-ehcache.xml缓存地址
                //#com.shine.pub.conf.url=file:/C:/Users/ASUS/Desktop/apache-tomcat-6.0.20/conf/shine
                //com.shine.pub.conf.url=file:/${catalina.home}/conf/shine,在*.properties中无法识别这种方式
                //支持linux识别
                String home = StringUtils.replace(System.getProperty("catalina.home"), "\\", "/");
                System.setProperty("com.shine.pub.conf.url", "file:/"+home+"/conf/shine");
                //寻找ActiveMQ.xml位置,因为在context.xml中配置的brokerURL="vm://localhost?brokerConfig=xbean:file:${activeMQ.home}/conf/activemq.xml" 
                //不支持"\"
                System.setProperty("activeMQ.home", home);
                //org.quartz.properties=C:/Users/ASUS/Desktop/apache-tomcat-6.0.20/conf/shine/quartz.properties
                System.setProperty("org.quartz.properties", home+"/conf/shine/quartz.properties");
                System.out.println("Hello World!");
            }
    }
    
}


 

 

下面附上:Tomcat部署资料

 

注: 1.我在Tomcat6.0.20中在Server.xml未配置Context节点的情况下部署*.war应用不会自动解压,去掉后缀是可以的

         2.在Eclipse中用Tomcat插件去部署应用会在Server.xml中生成如下的Context节点,然后在部署目录下产生一个不带war后缀的文件夹,是可以启动的

<Context docBase="cas" path="/cas.war" reloadable="true" source="org.eclipse.jst.j2ee.server:cas"/>

 

 Tomcat部署Web应用方法总结


在Tomcat中部署Java Web应用程序有两种方式:静态部署和动态部署。

在下文中$CATALINA_HOME指的是Tomcat根目录。

一、静态部署

静态部署指的是我们在服务器启动之前部署我们的程序,只有当服务器启动之后,我们的Web应用程序才能访问。

以下3种方式都可以部署:(以PetWeb项目为例说明,PetWeb目录假设是F:/PetWeb)

1.利用Tomcat自动部署

将PetWeb目录拷贝到$CATALINA_HOME/webapps下,然后启动服务器就可以了,Tomcat启动时将自动加载应用。

访问地址如下:http://localhost:8080/PetWeb/

这种方式比较简单,但是web应用程序必须在webapps目录下。Tomcat的Webapps目录是Tomcat默认的应用目录,当服务器启动时,会加载所有这个目录下的应用。

2.修改Server.xml文件部署

这种方式可以不必将PetWeb目录拷贝到webapps下,直接在F:/部署。方法如下,更改$CATALINA_HOME/conf/server.xml文件,

找到以下内容:

Xml代码:

    <Context  path ="/Pet"  reloadable ="false"  docBase ="F:/PetWeb"  workDir ="d:/Mywebapps/emp"  />

path:是访问时的根地址,表示访问的路径;如上述例子中,访问该应用程序地址如下:http://localhost:8080/Pet/

reloadable:表示可以在运行时在classes与lib文件夹下自动加载类包。其中reloadable="false"表示当应用程序 中的内容发生更改之后服务器不会自动加载,这个属性在开发阶段通常都设为true,方便开发,在发布阶段应该设置为false,提高应用程序的访问速度。

docbase:表示应用程序的路径,注意斜杠的方向“/”。 docBase可以使用绝对路径,也可以使用相对路径,相对路径相对于webapps。

workdir:表示缓存文件的放置地址

3.增加自定义web部署文件(推荐使用,不需要重启Tomcat )

这种方式和方法2差不多,但不是在Server.xml文件中添加Context标签,而是在$CATALINA_HOME/conf /Catalina/localhost中添加一个xml文件,如Pet.xml.在Tomcat安装目录conf/Catalina /localhost下,里面有Tomcat自带的三个应用,随意复制其中的一个XML文件,然后修改docbase指向你自己的应用程序,并把文件名改 名,各参数参见方法2中的<Context>标签的参数,或者你也可以自己新建一个XML文件。(注意此文件名将作为Context中的path属性值,不管文件里的path属性值如何设置也是无效的 ),将以下内容复制过去,修改相应路径即可。

Xml代码:

    <Context  path ="/Pet"  docBase ="F:/PetWeb" 
            debug ="0"  privileged ="true"  reloadable ="false"  > 
    </Context>

访问地址如下:http://localhost:8080/Pet/ 

 

 

注: Web应用以.war文件的形式部署

可以将JSP程序打包成一个war包放在目录下,服务器会自动解开这个war包,并在这个目录下生成一个同名的文件夹。一个war包就是有特性格式的jar包,它是将一个Web程序的所有内容进行压缩得到。

我们刚才是将PetWeb文件夹部署在了服务器中,我们知道可以将Web应用程序的内容打成.war 包,然后在部署在服务器上。打包请参考如下步骤:
    1、打开命令提示符(cmd)
    2、设置jdk环境变量
    3、在命令提示符中进入项目文件夹F:/PetWeb后,键入如下命令:jar cvf Pet.war */ .   (注意最后有个“. ”)。这样在F:/PetWeb下应该有Pet.war文件。 (也可以打包到指定的地方,命令如下:jar cvf d:/Pet.war */ . )

部署Pet.war文件非常简单,将刚才xml文件中的docBase ="F:/PetWeb" 更改为docBase ="F:/Pet.war" 或者直接将其拷贝到webapps目录下就可以。然后重新启动服务器就可以将Pet.war部署为一个Web应用程序了。

如果你够细心的话你会发现,服务器将Pet.war文件解开,并且在webapps下面又生成了一个Pet文件夹,然后把Pet.war的内容拷贝到里面去了。我们可以通过以下方式取消自动解压缩,将xml配置文件中的unpackWAR 属性设置为"false" 即可。

 

 

二、动态部署

动态部署是指可以在服务器启动之后部署web应用程序,而不用重新启动服务器。动态部署要用到服务器提供的manager.war文件,如果 在$CATALINA_HOME/webapps/下没有该文件,你必须去重新下载tomcat,否则不能完成以下的功能。要想使用该管理程序必须首先编 辑$CATALINA_HOME/conf/tomcat-users.xml文件,内容如下:(关于这个文件的更多内容,请参考 Java Web应用程序的安全模型二 )
<tomcat-users>
<role rolename="tomcat"/>
<role rolename="role1"/>
<role rolename="manager"/>
<user username="coresun" password="coresun" roles="manager"/>
<user username="tomcat" password="tomcat" roles="tomcat"/>
<user username="both" password="tomcat" roles="tomcat,role1"/>
<user username="role1" password="tomcat" roles="role1"/>
</tomcat-users>

然后在浏览器中键入如下地址:http://localhost:8080/ ,应该看到一个加菲猫了吧。点击左边的Tomcat Manager链接,提示输入用户名和密码,本文都是coresun ,然后可以看到以下页面:

(1)Context Path(option): 中输入/Pet


(2)XML Configration file URL 中要指定一个.xml文件,比如我们在F:/下建立一个Pet.xml文件,内容如下:<Context   reloadable ="false" / > 。docBase 不用写了,因为要在下一个文本框中填入。或者更简单点,这个文本框什么都不填。


(3)WAR or Directory URL: 中键入F:/PetWet或者F:/Pet.war都可以,然后点击Deploy按钮,看看上面是不是已经看到了你web应用程序,名字就是你Context Path(option):中的名字。


(4)如果你部署.war文件还有更加简单的方式,下面还有个Select WAR file upload 点击浏览选择.war文件,然后点击Deploy也可以。

让tomcat只运行conf/server.xml中指定的web应用

可以有以下2种办法:

实现一:

1)将要部署的WEB应用放在webapps以外的路径, 并在server.xml相应的Context  中的docBase 指定.

2)删除webapps中的所有文件夹, 以及conf/catalina/localhost下所有xml文件.
注: webapps是server.xml中的Host  元素的appBase 属性的值.

实现二:

修改server.xml中Host  元素的属性, 添加或修改: deployXML ="false" deployOnStartup ="false" autoDeploy ="false"

含义:
     deployXML ="false" : 不部署conf/catalina/localhost下的xml相应的WEB应用

     deployOnStartup ="false" :tomcat启动时, 不部署webapps下的所有web应用

     autoDeploy ="false"  :避免tomcat在扫描改动时, 再次把webapps下的web应用给部署进来.

注:

Tomcat中webapps目录下不能直接存放网页格式的文件,否则无法访问到该文件,必须有子目录才能访问该网页文件。
例如:我们直接将index.html放在webapps目录中,通过浏览器http://localhost:8080/index.html 是无法访问到index.html的。而必须要webapps/petweb/index.html才可以通过http://localhost:8080/petweb/index.html 访问到index.html页面。

 

 

 

 

 

 


 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值