nginx 虚拟主机+反向代理+负载均衡

nginx是一款免费、开源的http服务器,它是由俄罗斯程序设计师开发的,官方测试,nginx能支撑5万的并发量,主要功能有虚拟主机、反向代理和负载均衡等。

 

nginx配置

# 全局块 
... 
# events块 
events {
    ... 
} 
# http块
http { 
    # http全局块 
    ... 
    # 虚拟主机server块 
        server { 
            # server全局块 
            ... 
            # location块 
            location [PATTERN] { 
          ...
       } location [PATTERN] {
          ...
       }
} server { ... } # http全局块 ... }


在上述配置中我们可以看出,Nginx配置文件由以下几个部分构成:

    全局块:配置影响nginx全局的指令。一般有运行nginx服务器的用户组,nginx进程pid存放路径,日志存放路径,配置文件引入,允许生成worker process数等。

    events块:配置影响nginx服务器或与用户的网络连接。有每个进程的最大连接数,选取哪种事件驱动模型处理连接请求,是否允许同时接受多个网路连接,开启多个网络连接序列化等。

    http块:可以嵌套多个server,配置代理,缓存,日志定义等绝大多数功能和第三方模块的配置。如文件引入,mime-type定义,日志自定义,是否使用sendfile传输文件,连接超时时间,单连接请求数等。

    server块:配置虚拟主机的相关参数,一个http中可以有多个server。

    location块:配置请求的路由,以及各种页面的处理情况。

 

虚拟主机

nginx可以通过配置多个server来配置多台虚拟主机,一个server对应一台虚拟主机,一台虚拟主机上可部署一个网站。

server {

   listen 80;

   server_name www.domain1.com;

   index index.html;

   root /data/www/html;

}

server {

   listen 80;

   server_name www.domain2.com;

   index index.html;

   root /data/www/static;
}

 

反向代理

反向代理是相对于正向代理而言的,正向代理服务于客户端,反向代理服务于服务端。反向代理服务器位于客户端浏览器和web服务器之间,客户端不能直接向web服务器发请求,所有的请求都必须先发给反向代理服务器,然后由反向代理服务器转发给web服务器,同样,web服务器返回的响应也要先发给反向代理服务器,然后再转发给客户端。反向代理服务器发挥反向代理作用时就起到了一个中转站的作用。反向代理可以保护网站安全、缓存网站的静态资源,提高网站的响应速度、负载均衡。

upstream apache{
    server 192.168.68.43:8080;
}
server {

        listen       80;

        server_name  www.mydomain1.com;

        location / {

            proxy_pass   http://apache;

            index  index.html index.htm;

        }

}

 

负载均衡

要想实现负载均衡的功能,必须先实现反向代理的功能。当反向代理服务器代理的是一个web服务器集群而不是单个web服务器时,这就是负载均衡了。负载均衡指的是多个服务器共同完成一件事情,核心是“分摊压力”。Ngnix实现负载均衡指的是将请求转发给服务器集群。Ngnix默认处理负载均衡的方式是“轮询”,也可以通过weight来调整权重。

#设定负载均衡的服务器列表
#weigth参数表示权值,权值越高被分配到的几率越大
upstream apache{
    server 192.168.68.40:8080 weight=1;
    server 192.168.68.41:8080 weight=1;            
}
   
server {
    #侦听的80端口
    listen       80;
    server_name  localhost;
    #设定查看Nginx状态的地址
    location /nginxstatus{
         stub_status on;
         access_log on;
         auth_basic "nginxstatus";
         auth_basic_user_file htpasswd;
    }
    #匹配以jsp结尾的,tomcat的网页文件是以jsp结尾
    location / {
        index index.html index.php;
        proxy_pass   http://apache;    #在这里设置一个代理,和upstream的名字一样
        #以下是一些反向代理的配置可删除
        proxy_redirect             off; 
        #后端的Web服务器可以通过X-Forwarded-For获取用户真实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; 
        client_max_body_size       10m; #允许客户端请求的最大单文件字节数
        client_body_buffer_size    128k; #缓冲区代理缓冲用户端请求的最大字节数
        proxy_connect_timeout      300; #nginx跟后端服务器连接超时时间(代理连接超时)
        proxy_send_timeout         300; #后端服务器数据回传时间(代理发送超时)
        proxy_read_timeout         300; #连接成功后,后端服务器响应时间(代理接收超时)
        proxy_buffer_size          4k; #设置代理服务器(nginx)保存用户头信息的缓冲区大小
        proxy_buffers              4 32k; #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
        proxy_busy_buffers_size    64k; #高负荷下缓冲大小(proxy_buffers*2)
        proxy_temp_file_write_size 64k; #设定缓存文件夹大小,大于这个值,将从upstream服务器传
    }
}

 

posted @ 2018-11-06 11:28  $wanggang  阅读(499)  评论(0编辑  收藏  举报