Apache的反向代理的几种方式:
- mod_proxy:这是Apache的一个标准模块,它提供了反向代理的功能。您可以使用ProxyPass和ProxyPassReverse指令来配置反向代理。
- mod_jk:这是一个连接Apache和Tomcat的模块,它提供了反向代理的功能。您可以使用JkMount指令来配置反向代理。
- mod_proxy_balancer:这是Apache的一个标准模块,它提供了负载均衡和反向代理的功能。您可以使用ProxyPass和ProxyPassReverse指令来配置反向代理,使用ProxyPassReverseCookieDomain和ProxyPassReverseCookiePath指令来处理Cookie。
- mod_rewrite:这是Apache的一个标准模块,它提供了重写URL的功能。您可以使用RewriteRule指令来配置反向代理。
这些方式都可以实现反向代理的功能,但它们的实现方式和配置方式略有不同。选择哪种方式要根据具体情况而定,例如需要使用哪些功能、需要连接哪些后端服务器等。
我们主要讲解方式一:
要开启Apache的反向代理,您可以按照以下步骤进行操作:
1.确认Apache服务器已经安装,并启动了mod_proxy和mod_proxy_http这两个模块。您可以通过运行以下命令来检查:
sudo a2enmod proxy
sudo a2enmod proxy_http
sudo systemctl restart apache2
2.在Apache的配置文件中添加反向代理的配置。
Apache的主配置文件名字是httpd.conf,它通常位于Apache安装目录下的conf子目录中。在Linux系统中,它通常位于/etc/httpd/conf/或/etc/apache2/目录中。在Windows系统中,它通常位于C:\Program Files\Apache Group\Apache2\conf\目录中。
您可以在配置文件中添加以下内容:
ProxyPass /app http://localhost:3000
ProxyPassReverse /app http://localhost:3000
3. 将把所有来自“/app”的请求转发到本地主机上的端口3000上运行的应用程序。保存并退出配置文件,然后重新启动Apache服务器以使更改生效:
sudo systemctl restart apache2
现在,当用户访问您的Apache服务器上的“/app”时,Apache将会将请求转发到本地主机上的端口3000上运行的应用程序,然后将响应返回给用户。
具体配置:
1、全站反向代理
配置全站反向代理后,在浏览器访问 aaa.bilibilidaxue.com 的任何链接 最后显示的都是 www.bilibilidaxue.com 相关的内容,例如:访问 aaa.bilibilidaxue.com/news.html 实际显示的内容则是 www.bilibilidaxue.com 的内容。
如:
访问 aaa.bilibilidaxue.com/XXX.html 实际访问的是 www.bilibilidaxue.com/
代理前www.test1.com 的配置
<VirtualHost *:80>
DocumentRoot "D:\PHP\WWW\test1"
ServerName www.a.com
ServerAlias
<Directory "D:\PHP\WWW\test1">
Options FollowSymLinks ExecCGI
AllowOverride All
Order allow,deny
Allow from all
Require all granted
</Directory>
</VirtualHost>
代理后的配置
<VirtualHost *:80>
DocumentRoot "D:\PHP\WWW\test1"
ServerName www.a.com
ServerAlias
<Directory "D:\PHP\WWW\test1">
Options FollowSymLinks ExecCGI
AllowOverride All
Order allow,deny
Allow from all
Require all granted
</Directory>
#反向代理配置
ProxyPassMatch ^/.*$ http://www.test2.com
ProxyPassReverse ^/.*$ http://www.test2.com
</VirtualHost>
2、指定文件类型代理配置
假设现在只想 aaa.bilibilidaxue.com 下的以.shtml结尾的访问代理 www.bilibilidaxue.com ,配置如下(只有访问以'.shtml'结尾的 aaa.bilibilidaxue.com/XXX.shtml 链接才会显示 www.bilibilidaxue.com 站点的内容)
如:
访问 aaa.bilibilidaxue.com/XXX.shtml 实际访问的是 www.bilibilidaxue.com/
<VirtualHost *:80>
DocumentRoot "D:\PHP\WWW\test1"
ServerName www.a.com
ServerAlias
<Directory "D:\PHP\WWW\test1">
Options FollowSymLinks ExecCGI
AllowOverride All
Order allow,deny
Allow from all
Require all granted
</Directory>
#反向代理配置
ProxyPassMatch ^/.*\.shtml$ http://www.bilibilidaxue.com
ProxyPassReverse ^/.*\.shtml$ http://www.bilibilidaxue.com
</VirtualHost>
3、二级目录代理配置
假设现在只想让 aaa.bilibilidaxue.com 的 news 目录代理 www.bilibilidaxue.com ,配置如下(只有在访问 aaa.bilibilidaxue.com/news 下的页面才会显示 www.bilibilidaxue.com 站点的内容 )
如:
访问 aaa.bilibilidaxue.com/NEWS 实际访问的是 www.bilibilidaxue.com/
<VirtualHost *:80>
DocumentRoot "D:\PHP\WWW\test1"
ServerName www.a.com
ServerAlias
<Directory "D:\PHP\WWW\test1">
Options FollowSymLinks ExecCGI
AllowOverride All
Order allow,deny
Allow from all
Require all granted
</Directory>
#反向代理配置
ProxyPass /news http://www.bilibilidaxue.com
ProxyPassReverse /news http://www.bilibilidaxue.com
</VirtualHost>
4、指定某个具体的页面代理配置
指定某个具体页面代理,也就是只有在访问这个指定的页面时才会显示代理内容,访问其他页面任然显示自己原本的内容。
假设现在只想让aaa.bilibilidaxue.com/contact.html这个页面 -》代理 www.bilibilidaxue.com ,配置如下(只有在访问 aaa.bilibilidaxue.com/contact.html 是才会显示 www.bilibilidaxue.com 站点的内容 )
如:
访问 aaa.bilibilidaxue.com/CONTACT.html 实际访问的是 www.bilibilidaxue.com/
<VirtualHost *:80>
DocumentRoot "D:\PHP\WWW\test1"
ServerName www.a.com
ServerAlias
<Directory "D:\PHP\WWW\test1">
Options FollowSymLinks ExecCGI
AllowOverride All
Order allow,deny
Allow from all
Require all granted
</Directory>
#反向代理配置
ProxyRequests off
<Proxy *>
Order allow,deny
Allow from all
</Proxy>
<Location /contact.html>
ProxyPass /contact.html http://www.bilibilidaxue.com
ProxyPassReverse /contact.html http://www.bilibilidaxue.com
</Location>
</VirtualHost>
本文转载自: https://blog.csdn.net/weixin_42074713/article/details/129795904
版权归原作者 Fun_放 所有, 如有侵权,请联系我们删除。
版权归原作者 Fun_放 所有, 如有侵权,请联系我们删除。