为了实现nginx的反向代理以及负载均衡功能,我们需要用到HttpProxyModuleHttpUpstreamModule模块。其中,HttpProxyModule模块的作用是将用户的数据请求转发至其他服务器,HttpUpstreamModule模块的作用是提供简单的负载均衡技术(轮询、最少连接、客户端IP)。这两个模块为nginx默认的自动编译模块。

当代理单台主机时,nginx配置文件为:

server {

          listen 80;

          server_name aaa.com;

 

        location / {

               proxy_pass      http://10.10.10.128/;

               proxy_set_header Host   $host;

               proxy_set_header X-Real-IP     $remote_addr;

               proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

            }

#            access_log  /home/logs/aaa_access.log combined;

        }

如果后端的机器有多台(负载均衡)

Nginx配置文件写成

upstream bbb

{

            server  192:168.182.129;

            server  192:168.182.131;

}

 

server {

       listen 80;

       server_name bbb.com;

       location / {

               proxy_pass      http://bbb/;

               proxy_set_header Host   $host;

               proxy_set_header X-Real-IP     $remote_addr;

               proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

        }

#            access_log  /home/logs/bb_access.log combined;

}

 

代理一个服务器上所有域名 

首先在vhosts目录下需要建立两个文件,一个是servername 列表文件,一个是虚拟主机配置文件

两个文件内容分别为

1) servername

server_name aaa.com  111.com  //就这么简单一行,当然这个server_name 还可以继续添加的

 

2) 虚拟主机配置文件

server {

           listen 80;

           include vhosts/servername; // 这里的文件就是上边那个servername列表文件

           location / {

               proxy_pass     http://10.10.10.128/;  //这里就是需要做代理的服务器ip地址了

               proxy_set_header Host   $host;

               proxy_set_header X-Real-IP     $remote_addr;

               proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

            }

            access_log  /dev/null; 

        }