Tomcat 介绍

Tomcat是由Apache软件基金会下属的Jakarta项目开发的一个Servlet容器,按照Sun Microsystems提供的技术规范,实现了对Servlet和JavaServer Page(JSP)的支持,并提供了作为Web服务器的一些特有功能,如Tomcat管理和控制平台、安全域管理和Tomcat阀等。由于Tomcat本身也内含了一个HTTP服务器,它也可以被视作一个单独的Web服务器。但是,不能将Tomcat和Apache HTTP服务器混淆,Apache HTTP服务器是一个用C语言实现的HTTPWeb服务器;这两个HTTP web server不是捆绑在一起的。Apache Tomcat包含了一个配置管理工具,也可以通过编辑XML格式的配置文件来进行配置。(摘录自Wiki)(Apache Tomcat)

Tomcat 安装

Tomcat是免费的开源软件,可在直接在官方网站下载。
http://tomcat.apache.org/
1.可以直接在左侧选择版本:

2.选择版本后可以在下方进行下载,可以选择下载安装版或者解压版,这里选择了解压版
tar.gz文件是Linux操作系统下的安装版本
exe文件是Windows系统下的安装版本
zip文件是Windows系统下的压缩版本

3.下载完成后解压缩,得到Tomcat目录,

 

Tomcat 的默认端口

Tomcat 修改HTTP默认端口,可以直接修改Tomcat 目录下\conf \server.xml文件。默认端口号为8080,修改为想要的端口,重启Tomcat即可。

<Connector URIEncoding="UTF-8" connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>

若要修改成8081端口:

<Connector URIEncoding="UTF-8" connectionTimeout="20000" port="8081" protocol="HTTP/1.1" redirectPort="8443"/>

Tomcat 的虚拟目录配置

什么是虚拟目录呢,简单的说,我们可以根据请求的路径不同,来发布不同的项目。如此形式:我们想要
在访问http://www.codingme.net/testA 时,进入A项目。
在访问http://www.codingme.net/testB 时,进入B项目。
这个时候我们就需要配置虚拟目录来完成这个操作。
此时的URL:http://www.codingme.net/testA 不是单纯的路径,而是协议域名端口号+WEB应用testA。

自动映射虚拟目录

在Tomcat 默认情况下,我们可以看到 %Tomca%\conf \server.xml文件最底部有配置如下:

      <Host name="localhost"  appBase="webapps"
unpackWARs="true" autoDeploy="true">
<!-- SingleSignOn valve, share authentication between web applications
Documentation at: /docs/config/valve.html -->
<!--
<Valve className="org.apache.catalina.authenticator.SingleSignOn" />
-->
<!-- Access log processes all example.
Documentation at: /docs/config/valve.html
Note: The pattern used is equivalent to using pattern="common" -->
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="localhost_access_log" suffix=".txt"
pattern="%h %l %u %t "%r" %s %b" />
</Host>

这里Tomcat 默认配置了虚拟主机localhost,基础应用目录webapps,也就是%Tomca%\webapps\ 目录,Tomcat 服务器会自动管理webapps目录下的所有web应用,并把它映射成虚似目录。
因此在需要配置虚拟目录时我们可以直接把项目复制到webapps 目录下进行发布
示例:

  1. 复制项目到webapps下
 

  1. 查看test/ index.html 文件内容

  2. 运行%Tomcat%/bin/startup.bat 启动Tomcat
  3. 进行访问测试http://localhost:8080/test/index.html

注意:http://localhost:8080 会默认访问 webapps/ROOT文件夹中的内容。

修改server.xml 映射虚拟目录

我们也可以通过在server.xml 文件中的host 元素之间添加配置代码来配置虚拟目录:添加代码如下;

Context path="/app" docBase="D:/app" debug="0" reloadable="true" crossContext="true"/>

配置中我们配置了访问路径为/app ,项目路径D:/app 因此我们只要把要发布的内容放入D:/app 文件夹中即可。
配置完毕后 运行%Tomcat%/bin/startup.bat 启动Tomcat,可以通过

http://localhost:8080/app/index.html

访问到D:/app/index.html,需要多个虚拟目录可以直接配置多条配置。

注意:若想使用http://localhost:8080 访问项目则需要配置 path=""
注意:配置中的path值和docBase中的文件夹名称没有任何关系。

在conf /Catalina /localhost 增加xml文件映射虚拟目录

博主比较推荐这一种。
在%Tomcat%/conf/Catalina/localhost目录中,增加配置文件来配置虚拟目录。
配置文件名称格式为:虚拟目录路径.xml
举个栗子:
在%Tomcat%/conf/Catalina/localhost目录中增加文件 blog.xml
写入内容:

<?xml version="1.0" encoding="utf-8"?>
<Context
docBase="d:/blog"
reloadable="true">
</Context>

D盘下blog文件夹中内容:

docBase="d:/blog" 指定了Web应用存放位置为D盘下blog文件夹中。
reloadable="true"表示当blog文件夹中文件有变化中,自动加载。
配置完毕启动Tomcat后就可以通过访问到blog文件夹中的内容。

http://localhost:8080/blog

 
image

注意:需要多个虚拟目录可以多建立几个配置文件,文件名不能相同。
注意:若想使用http://localhost:8080 访问项目则需要配置文件名为ROOT.xml
注意:文件名blog.xml 和配置中d:/blog 没有关系,文件名可以写成其他,如blog111.xml,那么在访问时就要访问http://localhost:8080/blog111

Tomcat 的虚拟主机

首先我们先了解虚拟主机的用处,一个虚拟主机也就是一个网站。比如我们只有一个服务器,一个服务器上只有一个80端口,我们需要发布两个web项目,那么我们可以使用虚拟目录,把两个项目发布到两个不同的路径之下,但是如果我们有两个不同的域名需要把两个项目对应两个域名,我们就需要配置虚拟主机了。

示例:两个域名
一个是www.aaaa.com
一个是 www.bbbb.com

为了实验效果,我们配置C:\Windows\System32\drivers\etc\hosts 文件,添加两行映射。

127.0.0.1   www.aaaa.com
127.0.0.1 www.bbbb.com

此时我们本机可以使用 localhost / www.aaaa.com / www.bbbb.com 进行访问。

配置虚拟主机指定www.aaaa.com访问是的内容。
1:在server.xml中Engine元素中添加一个host子元素

<Host name="www.aaaa.com" debug="0" appBase="d:/aaaa" unpackWARs="true"
autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
<Logger className="org.apache.catalina.logger.FileLogger" directory="logs"
prefix="aaaa_log." suffix=".txt" timestamp="true" />
</Host>

其中的

  1. name表示在访问的域名是www.aaaa.com时会使用此配置。
  2. appBase="d:/aaaa" 指定了项目的发布路径。

启动Tomcat后,此时在使用www.aaaa.com进行访问时候,会默认显示d:/aaaa/ROOT中的内容。

如果存在 d:/aaaa/test,则可以通过http://www.aaaa.com:8080/test 进行访问。
此时test也就是www.aaaa.com的虚拟目录。
添加www.bbbb.com 访问同上。

Tomcat 的单例多实例配置

参考之前文章
Linux配置Tomcat的单机多实例

作者: 雪漫士兵

博客: https://www.codingme.net (转载请注明出处)

Web笔记(二)Tomcat 使用总结的更多相关文章

  1. JAVA WEB学习笔记(二):Tomcat服务器的安装及配置

    一.Tomcat的下载及安装. 前往Tomcat官网下载安装包或者免安装压缩包.链接http://tomcat.apache.org/ 这里,我选择的是Tomcat8.0,而不是最新的Tomcat9. ...

  2. JSP学习笔记(二):Tomcat服务器的安装及配置

    一.Tomcat的下载及安装. 前往Tomcat官网下载安装包或者免安装压缩包.链接http://tomcat.apache.org/ 这里,我选择的是Tomcat8.0,而不是最新的Tomcat9. ...

  3. amazeui学习笔记二(进阶开发5)--Web 组件开发规范Rules

    amazeui学习笔记二(进阶开发5)--Web 组件开发规范Rules 一.总结 1.见名知意:见那些class名字知意,见函数名知意,见文件名知意 例如(HISTORY.md Web 组件更新历史 ...

  4. amazeui学习笔记二(进阶开发2)--Web组件简介Web Component

    amazeui学习笔记二(进阶开发2)--Web组件简介Web Component 一.总结 1.amaze ui:amaze ui是一个web 组件, 由模板(hbs).样式(LESS).交互(JS ...

  5. Mastering Web Application Development with AngularJS 读书笔记(二)

    第一章笔记 (二) 一.scopes的层级和事件系统(the eventing system) 在层级中管理的scopes可以被用做事件总线.AngularJS 允许我们去传播已经命名的事件用一种有效 ...

  6. JavaWeb学习笔记二 Http协议和Tomcat服务器

    Http协议 HTTP,超文本传输协议(HyperText Transfer Protocol),是互联网上应用最为广泛的一种网络协议.所有的WWW文件都必须遵守这个标准.设计HTTP最初的目的是为 ...

  7. webpy使用笔记(二) session/sessionid的使用

    webpy使用笔记(二) session的使用 webpy使用系列之session的使用,虽然工作中使用的是django,但是自己并不喜欢那种大而全的东西~什么都给你准备好了,自己好像一个机器人一样赶 ...

  8. AJax 学习笔记二(onreadystatechange的作用)

    AJax 学习笔记二(onreadystatechange的作用) 当发送一个请求后,客户端无法确定什么时候会完成这个请求,所以需要用事件机制来捕获请求的状态XMLHttpRequest对象提供了on ...

  9. JNDI学习总结(二)——Tomcat下使用C3P0配置JNDI数据源

    一.C3P0下载 C3P0下载地址:http://sourceforge.net/projects/c3p0/files/?source=navbar

  10. dom解析器机制 web基本概念 tomcat

    0 作业[cn.itcast.xml.sax.Demo2]   1)在SAX解析器中,一定要知道每方法何时执行,及SAX解析器会传入的参数含义 1 理解dom解析器机制 1)dom解析和dom4j原理 ...

随机推荐

  1. Final——无线网络密码破解——WPA/WPA2

    Final--无线网络密码破解--WPA/WPA2 20154305 齐帅 ↓ ↓ ↓ * # % & 郑 重 声 明 & % # * ↓ ↓ ↓ 本实验教程用于探索无线路由安全漏洞, ...

  2. Paper | 学习多任务中的最佳分/ 合结构(十字绣结构)

    目录 1. 问题 2. 十字绣结构(Cross-stitch architecture) 3. 实验设计 论文:Cross-stitch Networks for Multi-task Learnin ...

  3. ES6学习:两个面试题目--关于模板字符串

    号称看完就能“让开发飞起来”,不过文中的两个面试题目的知识点并没包括在文中. https://www.jianshu.com/p/287e0bb867ae 文中并没有完整的知识点去完成上面的两道题,这 ...

  4. XSS攻击 CSRF攻击

    XSS攻击: 跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets, CSS)的缩写混淆, 故将跨站脚本攻击缩写为XSS.恶意攻击者 ...

  5. 26.HashCode

      在前面三篇博文中讲解了(HashMap.HashSet.HashTable),在其中不断地讲解他们的put和get方法,在这两个方法中计算key的hashCode应该是最重要也是最精华的部分,所以 ...

  6. some knowledge of the IT world

    IT世界一切皆是可信息化(数据的转换)即信息记录一切,对信息的控制{存储,运算,传输{信息的位置转移},转换}就是对一切的控制{硬件(实质维)以信息的控制{软件形式(存在维)}进行操作} 信息本身的实 ...

  7. css实现圆形倒计时效果

    实现思想: 1.最外层包裹内部的div1(.box) 2.内部左右两边div2(.left_box和.right_box),宽度为div1的一半,通过overflow:hidden隐藏其内部的div ...

  8. python 导入模块出错 ImportError: No module named 'request'

    运行程序时报错 ImportError: No module named 'request' 1,第一种情况是真的没有安装requests这个模块,使用 sudo pip install reques ...

  9. 解决Django项目数据库无法迁移问题

    找到自己的虚拟环境,以下是我自己的环境路径 D:\xunihuanjing\venv\Lib\site-packages\django\contrib\admin\migrations 然后删除里面的 ...

  10. Enum扩展特性,代替中文属性

    由于对英语的天生缺陷,在枚举时一直使用中文,这样就不用看注释就知道枚举意思,今天看到博文 https://www.cnblogs.com/emrys5/p/Enum-rename-htmlhelper ...