1.3 Tomcat的下载和安装

TomcatJava领域最著名的开源web容器,简单、易用,稳定性极好,既可以作为个人学习之用,也可以作为商业产品发布。Tomcat不仅提供了Web容器的基本功能,还支持JAASJNDI绑定等。

1.3.1 安装Tomcat服务器

因为Tomcat完个是纯Java实现,因此它是平台无关的,在任何平台上运行完全相同。在WindowsLinux平台上的安装及配置基本相同。我们Windows平台为示范,介绍Tomcat下载和安装。

1. 登录http//tomcat.apache.org站点,下载Tomcat合适的版本,而且需使用Servlet31规范,因此必须使用Tomcat80或更新的版本系列。

目前Tomcat有几个稳定的产品版本,JDK1.6则建议使用Tomcat6.0系列。而Tomcat只有8.0

才支持Servlet3.1规范。Tomcat 8.0.X的最新稳定版本是8.0.9,建议下载该版本,Windows平台ZIP包,Linux平台下载载TAR包。建议不要下载安装文件,因为安装文件的Tomcat看不到启动、运行时控制台的输出,不利于开发者使用。

2. 解压缩刚下载到的压缩包,解压缩后应有如下文件结构。

bin:存放启动和关闭Tomcat的命令的路径。

conf:存放Tomcat的配置,所有的Tomcat的配置都在该路径上设置。

lib:存放Tomcat服务器的核心类库(JAR文件),如果需要扩展Tomcat功能,也可第三方

类库复制到该路径下。

logs:这是一个空路径,该路径用于保存Tomcat每次运行后产生的日志。

temp:保存web应用运行过程中生成的临时文件。

webapps:该路径用于自动部署web应用,将web应用复制在该路径下,Tomcat会将该应用自动部署在容器中。

work:保存web应用在运行过程中,编译生成的class文件。该文件夹可以删除,但每次启

Tomcat服务器时,系统将再次建立该路径。

license等相关文档。

 

将解压缩后的文件夹放在任意路径下。

运行Tomcat只需要一个环境变量:JAVA_HOME。不管是Windows还是Linux,只需要增加该环境变量即可,该环境变量的值指向JDK安装路径。

 

此处JAVA_HOME环境变量应该指向JDK安装路径,不是JRE安装路径。JDK安装

路径下应该包含bin目录,该目录下应该有javac.exenative2ascii.exe等程序;JDK安装

路径下还含有一个lib目录,该目录下应该有dt.jartools.jar两个文件;JDK安装路径下

还应该包含jre目录,这个jre目录就是JDK自带的JRE

 

3. 启动Tomcat,对于Windows平台,只需要双击Tomcat安装路径下bin目录中的startup.bat文件即可。启动Tomcat之后,打开浏览器,在地址栏输入http://localhost8080,然后回车,浏览器中出现如图1.2所示的界面,即表示Tomcat安装成功。

 

 

Tomcat安装成功后,必须对其进行简单的配置,这些配置包括Tomcat的端口、控制台等。下面详细介绍这些配置过程。

虽然Tomcat是一个免费的web服务器,但也提供了图形界面控制台,通过控制台,用户可以方便地部署Web应用、监控Web应用的状态等。但对于一个开发者而言,通常建议通过修改配置文件来管理Tomcat置,而不是通过图形界面。

 

1.3.2 配置Tomcat的服务端口

Tomcat的默认服务端口是8080,可以通过管理Tomcat配置文件来改变该服务端口,甚至可以通过修改配置文件让Tomcat同时在多个端口提供服务。

Tomcat的配置文件都放在conf目录下,控制端口的配置文件也放在该路径下。打开conf下的server.xml文件,务必使用记事本或vi等无格式的编辑器,不要使用如写字板等有格式的编辑器。定位server.xml文件的68行处,看到如下代码:

<Connector port="8080" protocol="HTTP/1.1"

connectionTimeout="20000"

redirectPort="8443"/>

其中,Port="8080"就是Tomcat提供web服务的端口,将8080修改成任意的端口,建议使用1024以上的端口,避免与公用端口冲突。此处修改为8888,即Tomcatweb服务的提供端口为8888。修改成功后,重新启动Tomcat后,在浏览器地址栏输入http://localhost:8888,回车,将再次看到如图1.2所显示的tomcat控制台界面,即显示Tomcat端口修改成功。

 

提示

如果需要让Tomcat运行多个服务,只需要复制server.xml文件中的Service元素,并修改相应的参数,便可以实现一个Tomcat运行多个服务,当然必须在不同的端口提供服务。

Web应用的开发阶段,通常希望Tomcat能列出Web应用根路径下的所有页面,这样能更方便地选择需要调试的JSP页面。在默认情况下,出于安全考虑,Tomcat并不会列出Web应用根路径下的所有页面,为了让Tomcat列出web应用根路径下的所有页面,可以打开Tomcatconf目录下的web.xml文件,在该文件的110、111两行,看到一个listings参数,该参数的值默是false,将该参数改为true

即可让Tomcat列出web应用根路径下的所有页面。即将这两行改为如下形式:

<init-param>

<param-name>listing</param-name>

<pärarn-value>true</param-vaIue>

</init-param>

 

1.3.3进入控制台

在图1.2的右上角显示有三个控制台:一个是Server Status控制台,另一个是Manager App控制台,还有一个是Host Manager控制台。 Status控制台用于监控服务器的状态,而Manager控制台可以部署、监控应用,因此通常只需使用Manager控制台即可。

如图1.2右上角所示的第二个按钮,即是进入Manager控制台的链接,单击该按钮将出现如图1所示的登录界面。

 

这个控制台必须输入用户名和密码才可以登录,控制台的用户名和密码是通过TomcatJAAS控制的。下面介绍如何为这个控制台配置用户名和密码。

 

提示

JAAS的全称是Java Authentication Authorization ServiceJava验证和授权API),它用于控制对Java web应用的授权访问。关于JAAS的全面介绍,在前面关于Tomcat文件结构的介绍中己经指出:web apps路径是web应用的存放位置,而Manager控制台对应的web应用也是放在该路径下的。进入webapps/manager/WEB-INF路径下,该路径存放Manager应用的配置文件,用无格式编辑器打开文件。

 

 

 

<!-- Define a Security Constraint on this Application -->

  <!-- NOTE:  None of these roles are present in the default users file -->

  <security-constraint>

   <!--访问/HTML/*资源需要manager-gui角色-->

    <web-resource-collection>

      <web-resource-name>HTML Manager interface (for humans)</web-resource-name>

      <url-pattern>/html/*</url-pattern>

    </web-resource-collection>

    <auth-constraint>

       <role-name>manager-gui</role-name>

    </auth-constraint>

  </security-constraint>

  <security-constraint>

  <!--访问/text/*资源需要manager-script角色-->

    <web-resource-collection>

      <web-resource-name>Text Manager interface (for scripts)</web-resource-name>

      <url-pattern>/text/*</url-pattern>

    </web-resource-collection>

    <auth-constraint>

       <role-name>manager-script</role-name>

    </auth-constraint>

  </security-constraint>

  <security-constraint>

 <!--访问/jmxproxy/*资源需要manager-jmx角色-->

    <web-resource-collection>

      <web-resource-name>JMX Proxy interface</web-resource-name>

      <url-pattern>/jmxproxy/*</url-pattern>

    </web-resource-collection>

    <auth-constraint>

       <role-name>manager-jmx</role-name>

    </auth-constraint>

  </security-constraint>

  <security-constraint>

<web-resource-collection>

<!--访问/status/*资源需要以下任务一个角色-->

 

      <web-resource-name>Status interface</web-resource-name>

      <url-pattern>/status/*</url-pattern>

    </web-resource-collection>

    <auth-constraint>

       <role-name>manager-gui</role-name>

       <role-name>manager-script</role-name>

       <role-name>manager-jmx</role-name>

       <role-name>manager-status</role-name>

    </auth-constraint>

  </security-constraint>

 

  <!-- Define the Login Configuration for this Application -->

 <!--确定JAAS的登录方式-->

  <login-config>

     <!--BASIC表示使用弹出式窗口登录-->

    <auth-method>BASIC</auth-method>

    <realm-name>Tomcat Manager Application</realm-name>

  </login-config>

 

 

 

通过上面的配置文件可以知道,登录Manager控制台可能需要不同的manager角色。对于普通开发者来说,通常需要访问匹配/html/*/status/*的资源,因此为该用户分配一个manager-gui角色即可。

Tomcat默认采用文件安全域,即以文件存放用户名和密码,Tomcat的用户山conf路径下的

tomcat-users.xml文件控制,打开该文件,发现该文件内有如下内容:

<tomcat-users>

<!--

  NOTE:  By default, no user is included in the "manager-gui" role required

  to operate the "/manager/html" web application.  If you wish to use this app,

  you must define such a user - the username and password are arbitrary.

-->

<!--

  NOTE:  The sample user and role entries below are wrapped in a comment

  and thus are ignored when reading this file. Do not forget to remove

  <!.. ..> that surrounds them. http://www.infocool.net

-->

<!--

  <!--增加一个角色,指定角色名即可-->

  <role rolename="tomcat"/>

  <role rolename="role1"/>

  <!--增加一个用户,指定用户名、密码、角色即可-->

  <user username="tomcat" password="tomcat" roles="tomcat"/>

  <user username="both" password="tomcat" roles="tomcat,role1"/>

  <user username="role1" password="tomcat" roles="role1"/>

-->

</tomcat-users>

 

上面的配置文件显示了Tomcat默认没有配置任何用户,所以无论在如图1.3所示的登录对话框中输入任何内容,系统都不能登录成功。为了正常登录Manager控制台,可以通过修改tomcat-users.xml文件来增加用户,并让该用户属于manager角色即可。Tomcat允许在元素中增加元素来增加用户,将tomcat-users.xml文件内容修改如下:

<tomcat-users>

<!--

  <!--增加一个角色,指定角色名即可-->

  <role rolename="manager-gui"/>

  <!--增加一个用户,指定用户名、密码、角色即可-->

  <user username="manager" password="manager" roles="manager-gui"/>

-->

</tomcat-users>

 

上面的配置文件中粗体字代码行增加了一个用户:用户名为manager,密码为manager,角色属于manager-gui。这样即可在如图1.3所示的登录对话框中输入managermanager来登录Manager控制台。

 

成功登录后可以看到如图1.4所示的界面。

 

1.4 TomcatManager控制台

 

在如图1.4所示的控制台可监控到所有部署在该服务器下的web应用,左边列出了所有部署在该web容器内的web应用,右边的4个按钮则用于控制,包括启动、停止、重启等。

控制台下方的Deploy区则用于部署web应用。Tomcat控制台提供两种方式部署web应用:一种是将整个路径部署成web应用:另一种是将WAR文件部署成web应用(在图1.4中看不到这种方式,在Deploy区下面,还有一个WAR file to deploy区,用于部署WAR文件)。

 

1.3.4部署web应用

Tomcat中部署web应用的方式主要有如下几种。

l 利用Tomcat的自动部署。

l 利用控制台部署。

l 增加自定义的web部署文件。

l 修改server.xml文件部署Web应用。

 

利用Tomcat的自动部署方式是最简单、最常用的方式,只要将一个web应用复制到Tomcatwebapps下,系统就会把该应用部署到Tomcat中。

利用控制台部署web应用也很简单,只要在部署web应用的控制台按如图1.5所示方式输入即可。

 

 

1.5利用控制台部署Web应用

 

按如图所示方式输入后,单击“Deploy"按钮,将会看到Tomcatweb aps目录下多了一个

名为AppName的文件夹,该文件夹的内容和自己项目文件夹的内容完全相同。这表明:当利用控制台部署web应用时,其实质依然是利用Tomcat的自动部署。

 

第三种方式则无须将web应用复制到Tomcat安装路径下,只是部署方式稍稍复杂一点,需要在conf目录下新建Catalina目录,再在Catalina目录下新建localhost目录,最后在该目录下新建一个名字任意的XML文件一一该文件就是部署web应用的配置文件,该文件的主文件名将作为web应用的虚拟路径。例如在conf/Catalina/localhost下增加一个dd.xml文件,该文件的内容如下:

<Context path="" docBase="D:\workspace\App" debug="0" reloadable="true"/>

 

上面的配置文件中粗体字代码指定了web应用的绝对路径,再次启动TomcatTomcat将会把

D:\workspace\路径下的App文件夹部署成web应用。该应用的URL地址为:

http://<server-host:port>/dd, 其中URL中的dd就是web部署文件的主名。

最后还有一种方式是修改server.xml文件,这种方式需要修改conf目录下的server.xml文件,修改该文件可能破坏Tomcat的系统文件,因此不建议采用。

 

1.3.5配置Tomcat的数据源

Tomcat 5.5开始,Tomcat内置了DBCP的数据源实现,所以可以非常方便地配置DBCP数据源。

Tomcat提供了两种配置数据源的方式,这两种方式所配置的数据源的访问范围不同:一种数据源可以让所有的web应用都访问,被称为全局数据源;另一种只能在单个的web应用中访问,被称为局部数据源。

不管配置哪种数据源,都需要提供特定数据库的JDBC驱动。我们以MySQL为例来配置数据源,所以读者必须将MySQLJDBC驱动程序复制到Tomcatlib路径下。

 

局部数据源无须修改系统的配置文件,只需修改用户自己的web部署文件,不会造成系统的混乱,而且数据源被封装在一个web应用之内,防止被其他的web应用访问,提供了更好的封装性。

局部数据源只与特定的web应用相关,因此在该web应用对应的部署文件中配置。例如,为上面的Web应用增加局部数据源,修改Tomcatconf/Catalina/localhost下的dd.xml文件即可。为Context元素增加一个Resource子元素,增加局部数据源后的dd.xml文件内容如下:

<Context docBase="G/publish/codes/Ol/aa" debug="0">

<!--其中name指定数据源在容器中的JNDI名

driverClassName指定连接数据库的驱动

uri指定数据库服务的URL

username指定连接数据库的用户名

Password指定连接数据库的密码

maxActive指定数据源最大活动连接数

maxIdie指定数据池中最大的空闲连接数

maxwait指定数据池中最大等待获取连接的客户端

-->

<Resource name:"jdbc/dstest"auth="Container"

Type=”javax.sql.DataSource"

driverCIassName="com.mysql.jdbc.Driver"

Url=”jdbc://localhost:3306/javaee"

Username="root" pssword="32147" maxÄctive="5"

maxIdIe="2"  maxWait=”10000"/>

</Context>

 

上面的配置文件中粗体字标出的Resource元素就为该web应用配置了一个局部数据源,该元素的各属性指定了数据源的各种配置信息。

 

提示

JNDI的全称是Java Naming Directory Interface,即Java命名和目录接口,听起来非常专业,其实很简单:就是为某个Java对象起一个名字。例如,上面JNDI的用途就是为Tomcat容器中的数据源起一个名字:jdbc/dstest,从而让其他程序可以通过该名字来访问该数据源对象。

再次启动Tomcat,web应用即可通过该JNDI名字来访问该数据源。下面是测试访问数据源的

JSP页面代码片段。

 

//初始化Context,使用InitialContext初始化Context

Context ctx = new InitiaIContext();

/*

通过JND工查找数据源,该JND工为javacomp/env/jdbc/dstest,分成两个部分

Java:comp/envTomcat固定的,Tomcat提供的JNDI绑定都必须加该前缀

jdbc/dstest是定义数据源时的数据源名

DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/dstest");

//获取数据库连接

Connection conn = ds.getConnection()冫

//获取Statement

Statement stmt = conn.createStatement();

//执行查询,返回Resultset对象

ResultSetrs = stmt.executeQuery(“select * from new_inf”)

While (rs.next())

Out..println(rs.getString(1)) +”\t" + rs.getString(2) +”<br/>”);

 

上面的粗体字代码实现了JNDI查找数据源对象,一旦获取了该数据源对象,程序就可以通过该数据源取得数据库连接,从而访问数据库。

 

上而的方式是配置局部数据源,如果需要配置全局数据源,则应通过修改server文件来实现。

全局数据源的配置与局部数据源的配置基本类似,只是修改的文件不同。局部数据源只需修改Web应用的配置文件,而全局数据源需要修改Tomcatserver.xml文件。

 

使用全局数据源需要修改Tomcat原有的server.xml文件,所以可能导致破坏Tomcat

系统,因而尽量避免使用全局数据源。


转载请注明出处http://blog.csdn.net/wolaiye320/article/details/51420178

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值