您的位置:首页 > 运维架构 > Nginx

Nginx 高级应用-负载均衡

2017-12-23 14:39 225 查看
Nginx 可以根据规则以轮询、IP哈希、URL哈希等方式调度后端真实服务器,同时支持对后端服务器的健康检测。

Nginx 作为反向代理服务器的配置方法:

当用户访问http://www.example.com/a ,可以定义指令将数据请求转发给后端A服务器;当用户访问http://www.example.com/b,可以定义指令将数据请求转发给后端B服务器;

location 指令可以直接匹配字串,也可以匹配正则表达式。

使用正则表达式时,必须指定前缀~(区分大小写) 或是~*(不区分大小写)如果匹配时希望达到精确匹配,使用=前缀。

proxy_pass 指令可以根据location 匹配的情况建立被代理的服务器或URI与代理服务器直接的映射关系。

由于客户端请求直接到的是代理服务器,后端真实服务器将无法获得客户端的IP地址,使用X-Forwarded-For 实现重新定义数据包包头,记录用户真实的IP地址

location ~* \.(map3|mp4)$ {//匹配以mp3 或mp4 结尾的请求

proxy_pass http://localhost:8080 # location 条件满足时,将请求转发到本机的8080端口

}

location / { #匹配任意URL

proxy_pass http://localhost:8000; #location 条件满足时将请求转发给本机的8000端口

proxy_set_header X-Forwarded-For $remote_addr; #保留用户真实的IP地址



upstream 指令负责定义后端真实服务器集合,可以通过proxy_pass和fastcgi_pass 将请求转发给一组服务器。在upstream 中嵌套使用server 指令可以设置服务器及香港参数。

ip_hast 指令可以根据用户IP地址的Hash值分配固定的后端服务器

weight 的值表示服务器的权重

down指令可以设置某台服务器暂时处于宕机不可用状态

简单的案例:

定义一个名为backend 的服务器组,使用server定义组内所有的真实服务器成员,并将www2.example.com 设置为宕机状态,当用户使用域名http://www.example.com 访问代理服务器时,Nginx 代理服务器会将请求转发给backend 服务器组

http{

upstream backend{

ip_hash;

server www1.example.com weight=2;

server www2.example.com own;

server www3.example.com;

}

server{

listen 80;

server_name www.example.com;

location / {

proxy_pass http://backend;
}

}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: