Apache服务器+tomcat配置

本文详细介绍如何在Windows和Linux环境下安装配置Apache服务器,并通过示例讲解如何将Apache与Tomcat进行连接配置,实现反向代理及虚拟主机功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.安装Apache服务器

1.1 Windows下安装Apache

打开Apache Server的官网,可以看到上面只提供源码,不提供编译好的包,如果需要二进制文件可以从其它贡献者那里获取,并且网站上也提供了几个网址,我选择了Apache Lounge,因为它同时提供32位和64位的下载,下载好后解压到某个目录,如G:\Program Files\Apache24,然后打开conf/httpd.conf文件,修改其中的某些代码:

# Apache的IP地址和端口。一般来说不需要设置,Apache会绑定在本机所有IP地址的80端口上。
Listen 80
Listen 127.0.0.1:80

# Web服务器的名字
ServerName www.mysite.com

# 这是网站的根目录
DocumentRoot "G:\Program Files\Apache24\htdocs"
<Directory "G:\Program Files\Apache24\htdocs">
    # 这里删掉了Indexes,否则别人可以浏览到您网站里的所有文件
    Options FollowSymLinks
</Directory>

启动bin目录下的httpd.exe文件(也可以用httpd.exe -k install命令把apache注册为服务,然后用net start Apache2.4命令启动Apache),然后在浏览器中输入localhost就可以看到默认的页面了--"It works!"。以上简单的配置只是为了让Apache服务器先运行起来,感谢这篇博文

1.2 Linux下安装Apache

参考这篇博客,主要步骤是:

  1. 安装C++
  2. 安装apr
  3. 安装apr-util
  4. 安装pcre
  5. 安装apache
  6. 如果启动apache时找不到libpcre库,可以参考这篇博客

2.安装Tomcat

Tomcat的安装比较简单,打开Tomcat官网,Windows则选择32位或64位的zip包,Linux则选择tar.gz包或zip包,下载后解压到指定目录即可。

3.Apache连接Tomcat

3.1 http_proxy方式

这是利用 Apache 自带的 mod_proxy 模块使用反向代理技术来连接 Tomcat。http_proxy 模式是基于 HTTP 协议的代理,因此它要求 Tomcat 必须提供 HTTP 服务,也就是说必须启用 Tomcat 的 HTTP Connector。首先打开 APACHE_HOME/conf/httpd.conf文件,把下面这些模块的加载语句前面的注释#删掉:

LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_ajp_module modules/mod_proxy_ajp.so
LoadModule proxy_balancer_module modules/mod_proxy_balancer.so
LoadModule proxy_connect_module modules/mod_proxy_connect.so
LoadModule proxy_ftp_module modules/mod_proxy_ftp.so
LoadModule proxy_http_module modules/mod_proxy_http.so

Include conf/extra/httpd-vhosts.conf

然后打开 APACHE_HOME/conf/extra/httpd-vhosts.conf,这里是配置虚拟主机的文件,当然也可以在httpd.conf文件中配置,但是这里单独配置比较清晰。文件中已经提供了一些模版,所以我们只要照着模板添加:

<VirtualHost *:80>
    ServerAdmin webmaster@dummy-host2.example.com
    DocumentRoot "G:\working\idea_workspace\demo1\src\main\webapp"
    ServerName demo1.com
    ErrorLog "logs/demo1.com-error.log"
    CustomLog "logs/demo1.com-access.log" common
	
	ProxyPass /test http://localhost:8080/demo1/
	ProxyPassReverse /test http://localhost:8080/demo1/
</VirtualHost>

<VirtualHost *:80>
    ServerAdmin webmaster@dummy-host2.example.com
    DocumentRoot "G:\working\idea_workspace\BlogTest\ROOT"
    ServerName blog.com
    ErrorLog "logs/blog.com-error.log"
    CustomLog "logs/blog.com-access.log" common
	
	ProxyPass / http://localhost:8082/blog/
	ProxyPassReverse / http://localhost:8082/blog/
</VirtualHost>

解释一下上面的配置,DocumentRoot是指定网站的根目录,也就是类似于tomcat中的docBase,假如这里不配置,则默认使用httpd.conf中的DocumentRoot配置。 ServerName是指定要代理的服务,ProxyPass后面有两个参数,例如对于第一个<VirtualHost>的配置,它的意思是把所有demo1.com/test/xxx的请求都转给 http://localhost:8080/demo1/xxx 处理,注意 ProxyPass是用作URL前缀匹配的,不可以使用正则表达式,例如代理/*.jpg这样的配置是不接受的,而ProxyPassReverse主要是为了防止重定向跳过代理的,关于这一点,可以参考这篇博客
这里配置了两个虚拟主机,因此Apache可以对这两个网站进行代理,从而实现一台服务器搭建多个网站的功能。要想实现这一点,当然还需要在tomcat中配置,建议对于一个网站就启动一个tomcat实例,不要使用tomcat的虚拟主机功能,这样重启A网站的tomcat实例时就不会影响B网站的运行了。关于tomcat的配置这里不多做介绍,主要就是注意把tomcat的关闭端口改成不一样的,以及监听端口不要重复,关于Apache的虚拟主机配置还可以参考这篇文章。另外,还可以在<VirtualHost>节点中配置Apache不转发静态文件给tomcat处理,这样可以提高性能,例如:

<VirtualHost *:80>
# 这里同上
ProxyPass /images !
ProxyPass /css !
ProxyPass /js !
</VirtualHost>

因为静态文件交给了Apache处理,因此需要授权,否则无法访问,打开APACHE_HOME/conf/httpd.conf文件,添加如下代码:

<Directory "G:\working\idea_workspace\demo1\src\main\webapp">
    Options Indexes FollowSymLinks
    AllowOverride None
    Require all granted
</Directory>

这里指定了demo1网站的根目录,同时授权,这样当访问静态资源时就不会报403错误了。

4.其它Apache配置细节

关于Apache的配置文件httpd.conf,还有一些细节和配置的含义在这里总结一下:

  • 使用LoadModule加载模块的顺序是跟它们在文件中声明的顺序相反的,即后写的LoadModule语句先加载;
  • ServerName: 标识Apache自身,如果没有配置,会使用127.0.0.1作为服务器的默认地址,而这个地址只是一个网络回环地址,只有本机能访问;
  • ScriptAliasAlias:都是用于实现映射目录的功能,但ScriptAlias是把映射的目录识别为CGI脚本目录,目录中所有文件都当作CGI脚本对待,而Alias只是映射为一个普通的目录;
  • Options指令:指定在目录中使用哪些服务器特性,例如Indexes代表开启索引功能,请求该目录的URL中如果没有由DirectoryIndex指令指定的索引文件,则用户可以查看当前目录的文件列表(默认返回结果是这个),一般情况下应该要关闭;

转载于:https://my.oschina.net/JoeyXieIsCool/blog/687166

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值