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;
}
}
}
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;
}
}
}
相关文章推荐
- apache高级应用--------负载均衡(LB)
- 【Nginx应用】1.理解正、反向代理和负载均衡
- Nginx常见问题 、 Tomcat服务器 、 Tomcat高级应用
- Nginx入门级简介,包括安装,基本使用,负载均衡,动静分离,反向代理,缓存应用等功能。
- Windows环境下Nginx+Tomcat+Redis实现应用服务器集群负载均衡和Session共享
- Nginx简介,及日常应用, 负载均衡
- 利用Redis+Nginx实现Sping-Boot应用的负载均衡部署
- nginx 负载均衡与location应用分析 简单实验
- nginx 负载均衡与location应用分析
- 用Nginx做NodeJS应用的负载均衡
- 【Nginx应用】3.Nginx+Tomcat实现Web服务负载均衡(上)
- nginx高级部分:动静分离、负载均衡配置
- Nginx+Tomcat+Redis实现应用服务器集群负载均衡和Session共享
- N年前Nginx 负载均衡在金山逍遥网中的应用
- Nginx高级应用--负载均衡、rewrite规则
- nginx+keepalived负载均衡可用框架(补一 keepalived安装配置-热备-(服务器层和应用层))
- Nginx常见问题、Tomcat服务器、Tomcat高级应用
- nginx高级应用--------Location Url 配置
- nginx+keepalived负载均衡可用框架(补一 keepalived安装配置-热备-(服务器层和应用层))
- Nginx的反向代理和负载均衡应用实践