Apache Reverse Proxy Configuration for Linux

A reverse proxy operates as a gateway and presents itself to the client as a standard web server. This guide will walk you through the process of setting up and configuring a reverse proxy on an Apache server. The configuration of a reverse proxy is crucial as it instructs the Apache server where to redirect or cache information for clients requesting data.

In our scenario, we will be working with two servers:

  • Server1: http://WWW.webhostinggeeks.local –
  • Server2: http://WEB.webhostinggeeks.local –

When a client browses /web on Server1, the traffic will be redirected to Server2. This guide is applicable for Linux CentOS 6, RHEL 6, and Oracle Linux 6.

For a deeper understanding of Apache, you can refer to our comprehensive guide on Apache. If you’re interested in exploring other web servers, we have detailed explanations on Nginx and LiteSpeed as well.

Step 1: Load the Necessary Apache Proxy Modules

To utilize the Apache proxy directives, you need to load the following modules:

LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_http_module modules/mod_proxy_http.so

Step 2: Configure /web on Apache Web Server on Server1

To configure /web on the Apache web server on Server1, you need to edit the reverse_proxy.conf file. You can do this using the vi editor:

# vi /etc/httpd/conf.d/reverse_proxy.conf

Then, add the following lines to the file:

<IfModule mod_proxy.c>
 ProxyRequests Off
 <Proxy *>
 Order allow,deny
 Allow from all
 ProxyPass /web http://web.webhostinggeeks.local
 ProxyPassReverse /web http://web.webhostinggeeks.local

Step 3: Restart or Reload Apache to Apply Changes

After making the necessary changes, you need to restart or reload the Apache server for the changes to take effect. You can do this by running the following command:

# service httpd restart

You should see the following output, indicating that the Apache server has successfully stopped and started:

Stopping httpd: [ OK ]
Starting httpd: [ OK ]

Step 4: Test the Configuration

To test the configuration, browse the URL http://www.webhostinggeeks.local/web. If the configuration is correct, you should be able to access the site without any issues.

See also  How To Disable The IPv6 on CentOS 5.8


Setting up a reverse proxy on an Apache server involves loading the necessary modules, configuring the proxy settings, and restarting the Apache server to apply the changes. This guide has provided a step-by-step walkthrough of the process, applicable for Linux CentOS 6, RHEL 6, and Oracle Linux 6.

Remember, a reverse proxy can bea powerful tool in your server management toolkit, providing benefits such as load balancing, security enhancements, and performance improvements. However, it’s crucial to understand and correctly implement the configuration to ensure it functions as intended.

See also  How to Configure Basic Setup for lighttpd on CentOS 6.3

If you’re looking to explore more about server types and hosting options, we have detailed guides on dedicated servers, VPS servers, cloud hosting, and shared hosting.

Remember, the key to successful server management lies in understanding the tools at your disposal and how to use them effectively. Whether you’re managing an Apache server or exploring other server options, the right knowledge and skills can make a significant difference in your server’s performance and security.

Commands Mentioned

  • LoadModule – This command is used to load the necessary Apache proxy modules.
  • vi /etc/httpd/conf.d/reverse_proxy.conf – This command is used to open the reverse_proxy.conf file in the vi editor.
  • service httpd restart – This command is used to restart the Apache server,applying any changes made to the configuration files.

FAQ Section

  1. What is a reverse proxy?

    A reverse proxy is a server that sits between client devices and a web server, forwarding client requests to the web server. It presents itself to the client as an ordinary web server. This can provide various benefits such as load balancing, security features, or caching to enhance performance.

  2. Why do we need to load specific modules in Apache for reverse proxy configuration?

    The specific modules like ‘mod_proxy’ and ‘mod_proxy_http’ are necessary for enabling proxy services in Apache. ‘mod_proxy’ provides basic proxy capabilities, and ‘mod_proxy_http’ provides support for proxying HTTP connections. Without these modules, Apache cannot function as a reverse proxy.

  3. What does the ‘ProxyRequests Off’ directive do?

    ‘ProxyRequests Off’ is a directive in the Apache configuration that disables forward proxy requests. This is important in a reverse proxy setup because you want the Apache server to handle requests from clients to the server, not the other way around.

  4. What is the purpose of the ‘ProxyPass’ and ‘ProxyPassReverse’ directives?

    ‘ProxyPass’ and ‘ProxyPassReverse’ are directives in Apache that handle the passing of requests from the client to the backend server and the response from the backend server to the client, respectively. They are crucial in a reverse proxy setup to ensure proper routing of requests and responses.

  5. How can I verify that my reverse proxy configuration is working?

    You can verify your reverse proxy configuration by attempting to access your server through the configured URL (in this case, http://www.ehowstuff.local/web). If the reverse proxy is correctly configured, you should be able to access the site without any issues.


Leave a Reply

Your email address will not be published. Required fields are marked *