前言
通常情况下,一个完整的web应用需要浏览器、web服务器、服务端程序、数据库四大组件的相互配合协作来完成一个请求处理与返回结果的过程。服务端程序,比如Java中的Servlet,会完成对特定请求的处理过程。如何把请求分配给对应的Servlet,如何管理这些Servlet以及静态资源,便是web服务器的职责了,Tomcat是一个开源的由Java语言实现的web服务器、支持Servlet与Jsp(Jsp本质上也是Servlet)。

下载与安装
以下操作场景均在MacOS系统下完成,选择安装的tomcat版本为tomcat 9
-
tomcat官网下载
- 解压
tar -zxvf apache-tomcat-9.0.34.tar.gz
- 解压后
tomcat9中的文件目录结构
BUILDING.txt LICENSE README.md RUNNING.txt conf logs webapps
CONTRIBUTING.md NOTICE RELEASE-NOTES bin lib temp work
- 其中4个重要的目录
| 目录名 | 目录内容 |
|---|---|
bin |
一些工具脚本,开启关闭tomcat的脚本都在这里 |
conf |
配置文件,其中server.xml是tomcat的主要配置文件 |
logs |
存放日志文件 |
webapps |
存放你web应用的目录 |
- 配置
JAVA_HOME
tomcat需要指定JDK或JRE,使用echo $JAVA_HOME查看是否有设置环境变量。
$ echo $JAVA_HOME
/Library/Java/JavaVirtualMachines/jdk1.8.0_20.jdk/Contents/Home
如果没有设置、可以手动设置、MacOS中jdk所在位置一般如上、设置过程如下。
vi .bash_profile
在 .bash_profile中输入以下配置并保存
JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.8.0_20.jdk/Contents/Home
export JAVA_HOME
source使其生效
source .bash_profile
启动与关闭
在tomcat的bin目录下有2个脚本。startup.sh表示启动tomcat,shutdown.sh表示关闭tomcat。执行./startup.sh后会有如下提示
Using CATALINA_BASE: /Users/xxx/tomcat/apache-tomcat-9.0.34
Using CATALINA_HOME: /Users/xxx/tomcat/apache-tomcat-9.0.34
Using CATALINA_TMPDIR: /Users/xxx/tomcat/apache-tomcat-9.0.34/temp
Using JRE_HOME: /Library/Java/JavaVirtualMachines/jdk1.8.0_20.jdk/Contents/Home
Using CLASSPATH: /Users/LENN/tomcat/apache-tomcat-9.0.34/bin/bootstrap.jar:/Users/LENN/tomcat/apache-tomcat-9.0.34/bin/tomcat-juli.jar
Tomcat started.
tomcat默认监听在主机上的 8080端口,让我们用浏览器访问这个端口,若出现如下默认页面则说明tomcat启动成功。

若启动失败,则可能是默认的
8080端口被别的进程占用了,让我们去之前提到的server.xml修改默认端口配置,再重新启动。
- 修改
xml中的默认端口至8090
<Connector port="8090" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
webapp目录结构
上面我们提到了webapps用来存放我们的web应用,让我们看下这个目录下有什么
-
weapps目录
.
├── ROOT
├── docs
├── examples
├── host-manager
├── manager
其中examples目录是官方提供给我们的一个示例,提供了一个标准的web应用的文件目录的组织结构信息让我们参考。
-
examples目录结构
.
├── WEB-INF
├── index.html
├── jsp
├── servlets
└── websocket
Tips:查看一个目录层级结构可以使用tree -L [层数]命令来完成,MacOS下可以使用brew intstall tree来下载安装该工具。
examples中,最顶层目录就是我们web应用的document root,在部署的时候管理员会把它映射到一个访问路径下, 假设映射到localhost:8080/test这个访问路径,我们想查看index.html文件,只要在浏览器输入localhost:8080/test/index.html就可以了。
我们可以把一个webapp根目录下的文件分为两类,
- 一类是浏览器用户可见的文件,比如各种
html、jsp、css、img等(当然对于这些文件我们也可以在当前根目录下设置对应的文件夹对其进行管理,比如examples中的jsp、servlets,打开看一下其中均是html文件)。- 另一类则是浏览器用户不可见的资源,位于
WEB-INF目录下,包含我们的服务端小程序(servlet)位于WEB-INF/classes下和用到的依赖库位于WEB-INF/lib
在WEB-INF下还有一个至关重要的配置文件web.xml,它用来告诉tomcat容器构成你web应用的servlet等其他组件信息、初始化参数等等。
部署webapp
让我们也模仿examples的组织结构,创建一个myweb文件夹,将其放置于webapps目录下。
-
myweb目录结构
.
├── WEB-INF
└── hello.html
-
hello.html中的内容
Hello World!
现在通过访问localhost:8090/myweb/hello.html就可以查看这个页面

之前我们说过web.xml这个配置文件会告诉tomcat关于这个web应用的详细信息,现在我们通过配置web.xml告诉tomcat我们的应用myweb的首页为hello.html。
- 通过
web.xml配置首页
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0"
metadata-complete="true">
<welcome-file-list>
<welcome-file>hello.html</welcome-file>
</welcome-file-list>
</web-app>
只要简单的在<welcome-file-list>设置欢迎文件即可。现在通过访问http://localhost:8090/myweb/则会默认返回hello.html这个欢迎界面了。