码迷,mamicode.com
首页 > 其他好文 > 详细

Tomcat 部署

时间:2015-04-23 23:12:14      阅读:261      评论:0      收藏:0      [点我收藏+]

标签:

 

<CATALINA_HOME>/webapps:

Tomcat的主要Web发布目录,默认情况下把Web应用文件放于此目录。

 

 

1.war包部署: 

将需要发布的web应用打成war文件,

(例如:ROOT.war) 拷贝到<CATALINA_HOME>/webapps下, 

启动Tomcat, 

如果是ROOT.war,直接通过http://ip:port/即可访问 

如果是xxxx.war,可通过http://ip:port/xxxx/访问

 

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

  webapps这个默认的应用目录也是可以改变。打开Tomcat的conf目录下的server.xml文件,找到下面内容:

<Host name="localhost" debug="0" appBase="webapps" unpackWARs="true" autoDeloy="true" xmlValidation="falase" xmlNamespaceAware="false">

 



2.目录部署: 
这种方式可以不必将PetWeb目录拷贝到webapps下,直接在项目所在磁盘部署。

通过在server.xml中新建Context,部署一个JSP应用程序。 

打开<CATALINA_HOME>/conf/server.xml文件,在Host标签内建一个Context,内容如下。: 

<Context path="/xxxx" reloadable="true" docBase="D:\myapp" workDir="D:\myapp\work"/> 

 

其中:

path
  虚拟路径,是访问时的根地址,表示访问的路径;如上述例子中,访问该应用程序地址如下:http://localhost:8080/xxxx/
reloadable
  表示可以在运行时在classes与lib文件夹下自动加载类包。其中reloadable="false"表示当应用程序 中的内容发生更改之后服务器不会自动加载,这个属性在开发阶段通常都设为true,方便开发,在发布阶段应该设置为false,提高应用程序的访问速度。
docBase
  JSP应用程序的物理路径,表示应用程序的路径,注意斜杠的方向“/”。 docBase可以使用绝对路径,也可以使用相对路径,相对路径相对于webapps。 workDir
  这个应用的工作目录,存放运行是生成的于这个应用相关的文件。 表示缓存文件的放置地址

 

启动Tomcat,可通过http://ip:port/xxxx/访问

 

3.重定向web应用程序的目录

  如果想在服务器上运行一个以上的Tomcat实例,公用一个Tomcat发行版文件, 或者想在升级Tomcat时,覆盖原来的配置文件,而不影响现有的web应用程序, 那么“重定向web应用程序的目录”方式部署是一个不错的选择。 

假如Tomcat发行版安装路径是:/opt/Tomcat/,

Web应用名为aubapp, 

在/srv/下建立目录aubapp 

在/srv/aubapp/下建立目录webapps,work,temp,conf 

将/opt/Tomcat/conf/下的所有内容,拷贝到/srv/aubapp/conf/下, 

采用方案1,将war包拷贝到/srv/aubapp/webapps/下, 
或者方案2,修改/srv/aubapp/conf/server.xml文件制定应用路径 

编写启动脚本start.sh,出于方便和习惯于将其放在/srv/aubapp/bin/下 

 

start.sh:
#!/bin/sh     
#设置web应用程序目录     
export CATALINA_BASE="/srv/aubapp"    
#设置Tomcat发行版安装目录     
export CATALINA_HOME="/opt/Tomcat"    
#后台启动Tomcat,并将控制台日志重定向     
nohup sh /opt/Tomcat/bin/catalina.sh run >../logs/tomcat.log 0&1 &    
  
#!/bin/sh  
#设置web应用程序目录  
export CATALINA_BASE="/srv/aubapp"  
#设置Tomcat发行版安装目录  
export CATALINA_HOME="/opt/Tomcat"  
#后台启动Tomcat,并将控制台日志重定向  
nohup sh /opt/Tomcat/bin/catalina.sh run >../logs/tomcat.log 0&1 & 

 

启动后,访问方式与war包部署和目录部署一样。   

 

4 增加自定义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属性值如何设置也是无效的 ),将以下内容复制过去,修改相应路径即可。

<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应用被服务器加载后都会在Tomcat的conf/catalina/localhost目录下生成一个XML文件,其内容如下:

<Context path="/admin" docBase="${catalina.home}/server/webapps/admin" debug="0" privileged="true"></Context>

  可以看出,文件中描述一个应用程序的Context信息,其内容和server.xml中的Context信息格式是一致的,文件名便是虚拟目录名。您可以直接建立这样的一个xml文件,放在Tomcat的conf/catalina/localhost目录下。例子如下:

注意:删除一个Web应用同时也要删除webapps下相应的文件夹祸server.xml中相应的Context,还要将Tomcat的conf
/catalina/localhost目录下相应的xml文件删除。否则Tomcat仍会岸配置去加载。。。  

 

tomcat部署web应用主要有以下几种方式:

1.拷贝你的WAR文件或者你的web应用文件夹(包括该web的所有内容)到$CATALINA_BASE/webapps目录下。
2.为你的web服务建立一个只包括context内容的XML片断文件,并把该文件放到$CATALINA_BASE/webapps目录下。这个web应用本身可以存储在硬盘上的任何地方。这种context片断提供了一种便利的方法来部署web应用,你不需要编辑server.xml,除非你想改变缺省的部署特性,安装一个新的web应用时不需要重启动Tomcat。
3. 同方法2,只是将context片断放在CATALINA_BASE/conf/Catalina/localhost目录下.这种方法比方法2>要有效,笔者经过多次实验发现方法2不如后面这种方法好用.前者多次出现系统打不开的情况.
4.直接在server.xml中</Host>前加上Context片断,使用这种方法时,tomcat会自动在CATALINA_BASE/conf/Catalina/localhost目录下生成一个文件片断.方法同方法3具有同样效果.这种方式需要将ROOT目录删除才行.

另外,为了让tomcat只运行conf/server.xml中指定的web应用,可以有以下几种办法:
实现一:
     1)将要部署的WEB应用放在webapps以外的路径, 并在server.xml相应的context中的docBase指定.
     2)删除webapps中的所有文件夹, 以及conf/catalina/localhost下所有xml文件.
     注: webapps是server.xml中的Host元素的appBase属性的值. 
实现二:
     1) 修改server.xml中Host元素的属性, 添加或修改: deployXML="false" deployOnStartup="false" autoDeploy="false"
     2) 含义:
     deployXML="false": 不部署conf/catalina/localhost下的xml相应的WEB应用     deployOnStartup="false" :tomcat启动时, 不部署webapps下的所有web应用     autoDeploy="false": 避免tomcat在扫描改动时, 再次把webapps下的web应用给部署进来.

 

 

 

 

5 不重启服务器的部署-动态部署

  动态部署是指可以在服务器启动之后部署web应用程序,而不用重新启动服务器。

  动态部署要用到服务器提供的manager.war文件

(如果 在$CATALINA_HOME/webapps/下没有该文件,你必须去重新下载tomcat,否则不能完成以下的功能。要想使用该管理程序必须首先编 辑$CATALINA_HOME/conf/tomcat-users.xml文件)  

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

 

Tomcat 部署

标签:

原文地址:http://www.cnblogs.com/hwaggLee/p/4452053.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!