Nginx负载均衡配置与健康状况检查

Nginx负载均衡简单配置

准备三台虚拟机来做这个实验:

172.16.100.6        web服务器
172.16.100.7        web服务器
172.16.100.106    负载均衡服务器

首先三台电脑装好nginx软件:
向web服务器中放入测试文件:
<html>   
<head>   
<title>Welcome to nginx!</title>   
</head>   
<body bgcolor="white" text="black">   
<center><h1>Welcome to nginx! 172.16.100.6</h1></center>   
</body>   
</html>

配置负载均衡服务器:
vi /usr/local/nginx/conf/nginx.conf
 
user nginx nginx;worker_processes  1;
 
events {
    worker_connections  1024;
}
 
http {
    include      mime.types;
    default_type  application/octet-stream;   
    sendfile      on;
    keepalive_timeout  65;
    upstream webservs {
        server 172.16.100.6 weight=1;
        server 172.16.100.7 weight=1;
    }
     
    server {
        listen    8083;
        server_name  localhost;
        index index.html index.htm index.php; 
        location / {
            proxy_pass webservs;
          proxy_set_header X-Real-IP $remote_addr;
        }
                 
        error_page  500 502 503 504  /50x.html;
        location = /50x.html {
            root  html;
        }
    }
}

拓展:
要在server之外定义upstream ,upstream可以定义多个名称,但每一个upstream都要有自己独立的名称
upstream里有很多的子指定,其中server用来定义每一个后端服务器;每一个后端还可以传递很多参数,weight权重,没有权重为0,不做负载均衡的,权重一样就轮调,权重不一样实现加权轮调,还可以实现端口映射;定义server时只能定义名称或是IP地址,不能使用协议http。

upstream backend {
    server backend1.example.com weight=5;
    server backend2.example.com:8080;
    server unik:/tmp/backend3;
}
server{
    location / {
        proxy_pass ;    //反向代理不是某些主机,而是upstream定义的名称,,由upstream来实现负载均衡功能
    }
}

mkdir -p web/errorpages
vi web/errorpages/index.html
sorry!.......

当两台后端服务器挂掉,就会使用本机的sever访问的页面是sorry

拓展:
定义upstream中server指令语法如下:
        server address [parameters]
        关键字server必选。
        address也必选,可以是主机名、域名、ip或unix socket,也可以指定端口号。
        parameters是可选参数,可以是如下参数:server address [ parameters ]

weight = NUMBER    权重

max_fails = NUMBER    最多错误几次

fail_timeout = TIME      最多错误迟疑多长时间,不确定默认10s

down    表示当前server已停用
backup 表示当前server是备用服务器,只有其它非backup后端服务器都挂掉了或者很忙才会分配到请求。
max_failsfail_timeout一般会关联使用,如果某台server在fail_timeout时间内出现了max_fails次连接失败,那么Nginx会认为其已经挂掉了,从而在fail_timeout时间内不再去请求它,fail_timeout默认是10s,max_fails默认是1,即默认情况是只要发生错误就认为服务器挂掉了,如果将max_fails设置为0,则表示取消这项检查。

下面关于Nginx的文章您也可能喜欢,不妨参考下:

CentOS 7.2下编译安装PHP7.0.10+MySQL5.7.14+Nginx1.10.1 

Nginx实现集群的负载均衡配置过程详解

Nginx高级应用--负载均衡与rewrite规则 

CentOS 6.4安装配置Nginx+Pcre+php-fpm

CentOS 6.8下源码安装 Nginx 1.11.10 

CentOS 7 编译安装Nginx1.10.2 脚本启动失败解决思路

Nginx简单实现网站的负载均衡 

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/a8ec797235093207fd0597731807cffc.html