详解Tomcat Web 应用绑定域名的几种方式

 更新时间:2017年12月04日 08:56:37   作者:Wray Zheng  
本篇文章主要介绍了详解Tomcat Web 应用绑定域名的几种方式,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

当我们将应用部署到 tomcat 之后,默认是通过 http://codebelief.com:8080/myapp/ 这种形式来访问的。

很显然,这只适用于调试的情况,在实际使用时,我们通常会为根据需要,为应用绑定更加便于访问的路径。

一般来说,我们不直接将 tomcat 运行在 80 端口,更安全的做法是在 80 端口运行一个 http server,然后通过反向代理转发到 8080 端口。

以下的几种方式均基于反向代理实现,需要对应的反向代理服务程序,这里使用的是 apache,也可以用 nginx 实现,大同小异。

首先,需要确保开启 mod_proxy 模块:

$ sudo a2enmod proxy
$ sudo a2enmod proxy_http
$ service apache2 restart

通过 80 端口访问

即通过 http://codebelief.com/myapp/ 的形式访问 web 应用。

我们在 80 端口运行 apache,由 apache 处理 80 端口的请求,然后将所有请求转发给运行在 8080 端口的 tomcat 处理,这样就无需修改 tomcat 的运行端口,另一方面也确保了安全性。

在 /etc/apache2/sites-available/ 目录下添加配置文件 tomcat.conf:

<VirtualHost *:80>
ServerName codebelief.com

ProxyRequests On
ProxyPass / http://localhost:8080/
ProxyPassReverse / http://localhost:8080/
</VirtualHost>

然后将该配置文件通过软链接放入 /etc/apache2/sites-enabled/ 目录以启用该配置。

可以使用以下命令:

$ ln -s tomcat.conf /etc/apache2/sites-enabled/tomcat.conf

也可以使用 apache 自带的命令:

$ a2ensite tomcat

最后重新加载 apache 配置文件:

$ service apache2 reload

完成。

通过子域名访问

即通过 http://app.codebelief.com/myapp/ 访问 web 应用。

与上述配置过程类似,依然采用反向代理的方式将子域名请求转发给 8080 端口。

只需将 tomcat.conf 文件改成:

<VirtualHost *:80>
ServerName codebelief.com
ServerAlias app.codebelief.com

ProxyRequests On
ProxyPass / http://localhost:8080/
ProxyPassReverse / http://localhost:8080/
</VirtualHost>

同样,将该文件链接到 sites-enabled 目录下,然后 reload 配置即可。

域名根路径访问应用

即直接通过 http://codebelief.com 的形式访问 myapp,而无需加应用所在目录名。

tomcat.conf 文件内容如下,其它步骤一样。

<VirtualHost *:80>
ServerName codebelief.com
ServerAlias app.codebelief.com

ProxyRequests On
ProxyPass / http://localhost:8080/myapp/
ProxyPassReverse / http://localhost:8080/myapp/
</VirtualHost>

这样,就可以通过 http://codebelief.com 或者 http://app.codebelief.com 直接访问 myapp 了。

使用根路径直接访问应用,还有另一种实现方式。

这种方式不需要 apache 或 nginx 等反向代理服务程序,但是如果要使用这种方式,最好是 tomcat 只运行单个 web 应用,避免一个 web 应用的内部路径与其它 web 应用的路径冲突。

我们这里不考虑端口号的修改,使用默认的 8080 端口。

目标是通过 http://codebelief.com:8080 来访问 myapp。

修改 tomcat/conf/server.xml 文件

在 <Engine> 标签内添加下面的主机配置:

<Host name="codebelief.com" appBase="webapps" unpackWARs="true" autoDeploy="true">
  <Alias>app.codebelief.com</Alias>
  <Context path="" docBase="myapp" debug="0" privileged="true" />
  <Valve className="org.apache.catalina.valves.AccessLogValve"
  directory="logs"  prefix="localhost_access_log." suffix=".txt"
  pattern="%h %l %u %t "%r" %s %b" resolveHosts="false" />
</Host>

Host 标签中的 name 表明该配置用于处理来自 codebelief.com 主机的请求。注意,name 必须为一级域名或 ip 地址。

要使得子域名 app.codebelief.com 也能使用该配置,即根路径直接访问 myapp,那么需要使用 Alias 标签绑定该子域名。

Context 标签内的 path="" 表示直接通过根路径访问, docBase="myapp" 表示根路径默认访问的是 myapp 应用。

对外屏蔽 8080 端口

当我们使用不包含端口号的形式访问 myapp 时,我们还可以对外屏蔽 8080 端口,即必须通过 80 端口由 apache 转发给 tomcat。

要使外部不能直接访问 8080 端口,可以在 iptables 中添加对应规则,有关 iptables 的具体原理和用法,可以自行参考相关文章。

在这里,只需要执行以下命令:

$ iptables -t mangle -A PREROUTING -p tcp --dport 8080 -j DROP

该命令会在 mangle 表中的 PREROUTING 链添加指定规则,即对来自 8080 端口的 tcp 连接,直接做丢弃处理。

这样就可以禁止外部通过 8080 端口访问 tomcat 应用了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 优化Tomcat配置(内存、并发、缓存等方面)方法详解

    优化Tomcat配置(内存、并发、缓存等方面)方法详解

    这篇文章主要介绍了优化Tomcat配置(内存、并发、缓存等方面)方法详解,具有一定参考价值,需要的朋友可以了解下。
    2017-10-10
  • 解决spring boot + jar打包部署tomcat 404错误问题

    解决spring boot + jar打包部署tomcat 404错误问题

    这篇文章主要介绍了spring boot + jar打包部署tomcat 404错误问题解决方案,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • Tomcat执行startup.bat出现闪退的可能原因及解决

    Tomcat执行startup.bat出现闪退的可能原因及解决

    本文主要介绍了Tomcat执行startup.bat出现闪退的可能原因及解决,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • 详述 tomcat 中的 server.xml 配置文件示例

    详述 tomcat 中的 server.xml 配置文件示例

    本文将通过实例,介绍server.xml中各个组件的配置,并详细说明 Tomcat 各个核心组件的作用以及各个组件之间的相互关系。对tomcat server.xml 配置文件相关知识感兴趣的朋友一起看看吧
    2017-08-08
  • Tomcat使用线程池处理远程并发请求的方法

    Tomcat使用线程池处理远程并发请求的方法

    这篇文章主要介绍了Tomcat使用线程池处理远程并发请求的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • Docker Tomcat为何看不到访问界面

    Docker Tomcat为何看不到访问界面

    这篇文章主要介绍了Docker Tomcat为何看不到访问界面,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • Tomcat启动成功但无法访问http://localhost:8080/的解决方法

    Tomcat启动成功但无法访问http://localhost:8080/的解决方法

    在初次使用Tomcat时遇到了一些问题,经过一段时间的调试最终将其解决,个人感觉此问题应该比较常见,因此在这做一个分享,这篇文章主要给大家介绍了关于Tomcat启动成功但无法访问http://localhost:8080/的解决方法,需要的朋友可以参考下
    2023-04-04
  • 为什么我的tomcat启动不起来

    为什么我的tomcat启动不起来

    tomcat安装好了,准备部署Web项目了,启动tomcat,发现没有反应,本文就来解决一下这个问题,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • tomcat7w.exe 出现指定的服务未安装的解决方法

    tomcat7w.exe 出现指定的服务未安装的解决方法

    下面小编就为大家分享一篇tomcat7w.exe 出现指定的服务未安装的解决方法,很简单,有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-11-11
  • 详解tomcat部署静态html网站方法

    详解tomcat部署静态html网站方法

    这篇文章主要介绍了tomcat部署静态html网站方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06

最新评论