Apache反向代理的几种方式

  1. mod_proxy:这是Apache一个标准模块,它提供了反向代理的功能。您可以使用ProxyPass和ProxyPassReverse指令配置反向代理。

  2. mod_jk:这是一个连接Apache和Tomcat模块,它提供了反向代理的功能。您可以使用JkMount指令配置反向代理。

  3. mod_proxy_balancer:这是Apache的一个标准模块,它提供了负载均衡和反向代理的功能。您可以使用ProxyPass和ProxyPassReverse指令配置反向代理,使用ProxyPassReverseCookieDomain和ProxyPassReverseCookiePath指令处理Cookie

  4. 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 FilesApache GroupApache2conf目录中。

        您可以在配置文件添加以下内容

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.co 相关内容例如访问 aaa.bilibilidaxue.com/news.html 实际显示内容则是  www.bilibilidaxue.co 的内容

        如:

        访问 aaa.bilibilidaxue.com/XXX.html   实际访问的是  www.bilibilidaxue.com/ 

        代理前www.test1.com 的配置

<VirtualHost *:80>
    DocumentRoot "D:PHPWWWtest1"
    ServerName www.a.com
    ServerAlias 
  <Directory "D:PHPWWWtest1"&gt;
      Options FollowSymLinks ExecCGI
      AllowOverride All
      Order allow,deny
      Allow from all
     Require all granted
  </Directory&gt;
</VirtualHost&gt;

        代理后的配置

<VirtualHost *:80&gt;
    DocumentRoot "D:PHPWWWtest1"
    ServerName www.a.com
    ServerAlias 
  <Directory "D:PHPWWWtest1"&gt;
      Options FollowSymLinks ExecCGI
      AllowOverride All
      Order allow,deny
      Allow from all
     Require all granted
  </Directory&gt;
  #反向代理配置
  ProxyPassMatch ^/.*$ http://www.test2.com
  ProxyPassReverse ^/.*$ http://www.test2.com
</VirtualHost&gt;

        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&gt;
    DocumentRoot "D:PHPWWWtest1"
    ServerName www.a.com
    ServerAlias 
  <Directory "D:PHPWWWtest1">
      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:PHPWWWtest1"
    ServerName www.a.com
    ServerAlias 
  <Directory "D:PHPWWWtest1">
      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:PHPWWWtest1"
    ServerName www.a.com
    ServerAlias 
  <Directory "D:PHPWWWtest1">
      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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_23856.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注