网站首页 > 精选教程 正文
基于请求头分发适用于多个集群场景;也适应进行服务灰度发布的场景。
1、基于host分发
适用于一个公司有多个网站,一个网站设置为一个集群
#nginx分发器设置
http {
upstream web1 { # 名为web1的反向代理群组
server server1;
}
upstream web2 { # 名为web2的反向代理群组
server server2;
}
server { # web1虚拟主机
listen 80;
server_name www.web1.com; # 基于域名分发必须有域名
location / {
proxy_pass http://web1;
}
}
server { # web2虚拟主机
listen 80;
server_name www.web2.com; # 基于域名分发必须有域名
location / {
proxy_pass http://web2;
}
}
}
2、基于开发语言分发
适用于混合开发的网站,某些大型网站既有php也有jsp
# 分发器上nginx配置
http {
upstream php {
server server1;
}
upstream asp {
server server2;
}
upstream html {
server server2;
}
server {
location ~* \.php$ { # 以php结尾的
proxy_pass http://php;
}
location ~* \.asp$ { # 以asp结尾的
proxy_pass http://asp;
}
location ~* \.html$ { # 以html结尾的
proxy_pass http://html;
}
}
}
3、基于浏览器分发
常应用于PC端和移动端区分或浏览器适配
upstream curl {
server server1;
}
upstream firefox {
server server2;
}
upstream other {
server server3;
}
server {
listen 80;
server_name www.web1.com;
location / {
proxy_pass http://other;
if ( $http_user_agent ~* curl ) {
proxy_pass http://curl;
}
if ( $http_user_agent ~* firefox ) {
proxy_pass http://firefox;
}
}
}
4、基于源IP分
通过ngx_http_geo_module模块,根据客户端ip访问到不同的server
upstream bj.server {
server server1; # web01
}
upstream sh.server {
server server2; # web02
}
upstream default.server {
server server3; # web03
}
geo $geo { # IP库
default default;
server1 bj; # 北京
server2 sh; # 上海
}
server {
listen 80;
server_name www.web1.com;
location / {
proxy_pass http://$geo.server$request_uri;
}
}
5. 根据http header转发到不同的服务
根据请求 Header 转发不同后端服务server。
http {
map $http_custom_header $backend_name {
default backend1;
"version2.0" backend2;
}
upstream backend1 {
server backend1.example.com;
}
upstream backend2 {
server backend2.example.com;
}
server {
listen 80;
location / {
proxy_pass http://$backend_name;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
}
在这个配置中,$http_custom_header 是一个变量,代表HTTP请求header中的自定义字段。map 指令根据这个变量的值来设置一个变量 $backend_name。如果请求header中的自定义字段值为 "version2.0",则会将请求转发到 backend2.example.com;否则,会转发到 backend1.example.com。
也可以如下配置
map $http_accept $version {
default "";
"application/vnd.demo.v2.0+json" "v2.0";
}
upstream backend1 {
server backend1.example.com;
}
upstream backend2 {
server backend2.example.com;
}
server {
listen 80;
server_name olive.com;
charset utf-8;
autoindex off;
location / {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Forwarded-Port $server_port;
proxy_set_header X-Forwarded-Ssl on;
if ($version="v2.0"){
proxy_pass http://backend2;
break;
}
proxy_pass http://backend1;
}
}
在这个配置中,$http_accept 是一个变量,代表HTTP请求header中的http_accept字段。map 指令根据这个变量的值来设置一个变量 $version。如果请求header中的自定义字段值为 "application/vnd.demo.v2.0+json",则$version的值为v2.0;否则$version的值为空字符串。然后if条件判断根据$version的值进行转发。
- 上一篇: Linux防火墙端口开放或关闭的操作教程
- 下一篇: Nginx 居然支持流量拷贝,一个牛X的功能!
猜你喜欢
- 2024-10-07 Redis + Tomcat + Nginx 集群实现 Session 共享
- 2024-10-07 使用 Nginx 进行流媒体处理 nginx搭建rtmp流媒体服务器
- 2024-10-07 Nginx 四种分配方式——session处理
- 2024-10-07 介绍下Nginx 反向代理与负载均衡 nginx反向代理的几种模式
- 2024-10-07 Nginx 居然支持流量拷贝,一个牛X的功能!
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- nginx反向代理 (57)
- nginx日志 (56)
- nginx限制ip访问 (62)
- mac安装nginx (55)
- java和mysql (59)
- java中final (62)
- win10安装java (72)
- java启动参数 (64)
- java链表反转 (64)
- 字符串反转java (72)
- java逻辑运算符 (59)
- java 请求url (65)
- java信号量 (57)
- java定义枚举 (59)
- java字符串压缩 (56)
- java中的反射 (59)
- java 三维数组 (55)
- java插入排序 (68)
- java线程的状态 (62)
- java异步调用 (55)
- java中的异常处理 (62)
- java锁机制 (54)
- java静态内部类 (55)
- java怎么添加图片 (60)
- java 权限框架 (55)
本文暂时没有评论,来添加一个吧(●'◡'●)