nginx集群详解

今天介绍以下nginx集群方面的知识,先了解下传统的web访问模型吧,上图


nginx

• 1 部署⼀台备份服务器,宕机直接切换
• 2 部署多台服务器,根据DNS的轮询解析机制去实现⽤户分发
问题:
1⽅案:服务器利⽤率低,成本⾼,切换不及时,服务器压⼒依然⼤
2⽅案: 优势是⽤户处理速度得到了提升,但是当其中⼀台故障,就会有⼀部分⽤户访问不了⽹站

并⾏处理解决⽅案
• 1上述的DNS轮询解析⽅案
• 2 多机阵列---集群模式


image.png

那么啥是集群了???
将多个物理机器组成⼀个逻辑计算机,实现负载均衡和容错
• 计算机集群简称集群,是⼀种计算机系统, 它通过⼀组松散集成的计算机软件或硬件连接起来⾼度紧密地协作完成计算⼯作。在某种意义上,他们可以被看作是⼀台计算机。 (百度解释) • 组成要素

1)VIP: ⼀个IP地址
2)分发器: nginx
3)数据服务器: Web服务器

Nginx集群

在该集群中Nginx扮演的⻆⾊是: 分发器
• 任务:接受请求、分发请求、响应请求
• 功能模块:
1:ngx_http_upstream_module 基于应⽤层分发模块
2:ngx_stream_core_module 基于传输层分发模块 (1.9开始提供)

Nginx集群原理
• Nginx集群其实是:虚拟主机+反向代理+upstream分发模块组成的
虚拟主机:接受和响应请求
反向代理: 带⽤户去数据服务器拿数据
upstream: 告诉Nginx去哪个数据服务器拿数据

• 数据⾛向
1.虚拟主机接受⽤户请求
2.虚拟主机去找反向代理
3.反向代理让去找upstream
4.upstream 告诉 ⼀个数据服务器IP
5.Nginx去找数据服务器 并发起⽤户的请求
6.数据服务器接受请求并处理请求
7.数据服务器响应请求给Nginx
8.Nginx响应请求给⽤户

Nginx集群默认算法
upstream module
nginx的upstream⽬前⽀持4种⽅式的分配
1、轮询(默认)
每个请求按时间顺序逐⼀分配到不同的后端服务器,如果后端服务器down掉,能⾃动剔除。
2、weight
指定轮询⼏率,weight和访问⽐率成正⽐,⽤于后端服务器性能不均的情况。
3、ip_hash
每个请求按访问ip的hash结果分配,这样每个访客固定访问⼀个后端服务器,可以解决session的问题。
4、fair(第三⽅)
按后端服务器的响应时间来分配请求,响应时间短的优先分配。
5、url_hash(第三⽅)
按访问url的hash结果来分配请求,使每个url定向到同⼀个后端服务器,后端服务器为缓存时⽐较有效。
Nginx业务服务器状态

每个设备的状态设置为:
1.down 表示单前的server暂时不参与负载
2.weight 默认为1.weight越⼤,负载的权重就越⼤。
3.max_fails :允许请求失败的次数默认为1.当超过最⼤次数时,返回proxy_next_upstream 模块定义的错误
4.fail_timeout: 失败超时时间,在连接Server时,如果在超时时间之内超过max_fails指定的失败次数,会认为在fail_timeout时间内Server不可⽤。默认为10s。
5.backup: 其它所有的⾮backup机器down或者忙的时候,请求backup机器。所以这台机器压⼒会最轻。

基于请求头的分发
1.基于host分发
2.基于开发语⾔分发
3.基于浏览器的分发
4.基于源ip

#配置web业务机器,可略过。。。。
#web02
[root@web02 ~]# sh nginx_install
[root@web02 ~]# echo web02 > /usr/local/nginx/html/index.html
[root@web02 ~]# yum -y install elinks &>/dev/null
[root@web02 ~]# /usr/local/nginx/sbin/nginx
[root@web02 ~]# elinks http://localhost -dump
 web02

轮询分发(默认)

#配置分发器
upstream web {
   server 192.168.10.42;
   server 192.168.10.43; 
}
 server {
   listen 80;
   server_name localhost;
   location / {
     proxy_pass http://web;
   }
 }

ps:定义了一个名称为web分发机制,会自动去upstream按照顺序自动分发访问
每个请求按时间顺序逐⼀分配到不同的后端服务器,如果后端服务器down掉,能⾃动剔除。

基于权重的分发

upstream web {
   server 192.168.10.42 weight=1;
   server 192.168.10.43 weight=2 down;#down表示不参与分发了 ,backup表示web01忙不过来的时候帮忙分发
}
 server {
   listen 80;
   server_name localhost;
   location / {
     proxy_pass http://web;
   }
 }

ps:指定轮询⼏率,weight和访问⽐率成正⽐,⽤于后端服务器性能不均的情况。

ip_hash

upstream web {
   ip_hash;
   server 192.168.10.42;
   server 192.168.10.43;
}
 server {
    listen 80;
    server_name localhost;
    location / {
       proxy_pass http://web;
   }
 }
#ip_hash算法能够保证来⾃同样源地址的请求,都分发到同⼀台主机

ps:每个请求按访问ip的hash结果分配,这样每个访客固定访问⼀个后端服务器,可以解决
session的问题。
介绍2个第三方的分发方式吧!
A:fair(第三⽅)
按后端服务器的响应时间来分配请求,响应时间短的优先分配。
B:url_hash(第三⽅)
按访问url的hash结果来分配请求,使每个url定向到同⼀个后端服务器,后端服务器为缓
存时⽐较有效。
下面介绍4个常用的分发吧

1:基于host分发(域名)

http{
  upstream web1 {
    server 192.168.10.42;
  }
  upstream web2 {
    server 192.168.10.43; 
  }
  server {
     listen 80;
     server_name www.web1.com;
     location / {
         proxy_pass http://web1;
       }
   }
   server {
     listen 80;
     server_name www.web2.com;
     location / {
         proxy_pass http://web2;
     }
   }
}

2:基于开发语言分发

http{
   upstream php {
      server 192.168.10.42;
  }
  upstream html {
     server 192.168.10.43;
  }
  server {
      location ~* \.php$ {
          proxy_pass http://php;
      }
      location ~* \.html$ {
          proxy_pass http://html;
     }
  }
}

ps:就是访问不同的域名,例如index.html和index.php就可以根据规则,分发不同的服务器去访问

3:基于浏览器分发

upstream elinks { server 192.168.10.42; }
upstream chrome { server 192.168.10.43; }
upstream any { server 192.168.10.42:81; }
server {
    listen 80;
    server_name www.web1.com;
    location / {
       proxy_pass http://any;
       if ( $http_user_agent ~* Elinks ) {
         proxy_pass http://elinks;
    }
   if ( $http_user_agent ~* chrome ) {
     proxy_pass http://chrome;
   }
 }
}

ps:根据你访问的浏览器的不同,从而分发不同的服务器或者匹配的规则去响应数据,例如手机客户和PC客户

4:基于源ip分发

upstream beijin.server {
     server 192.168.10.42;
 }
upstream shanghai.server {
     server 192.168.10.43;
 }
upstream default.server {
    server 192.168.10.42:81;
 }
geo $geo {
    default default;
    192.168.10.241/32 beijin;
    192.168.10.242/32 shanghai;
}
location / {
   proxy_pass http://$geo.server$request_uri;
 }

ps:http://geo.serverrequest_uri;是为了匹配全路径,防止url所有参数丢失,例如源ip来自北京的就返回北京的server数据,来自上海的就返回上海的server数据
好了,大功告成,今天就先写到这里吧,感谢观看~~~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容

  • 一、集群介绍 1、传统web访问模型 (1)传统web访问模型完成一次请求的步骤 1)用户发起请求2)服务器接受请...
    呆叔么么阅读 3,981评论 1 5
  • 传统web服务模型 集群 将多个物理机器组成一个逻辑计算机 , 实现负载均衡和容器 计算机集群简称集群,是一种计算...
    stamSuper阅读 568评论 0 1
  • 什么是负载均衡就不多说了、自己可以百度查看 实现负载均衡其实并不难、只是很多人不敢去尝试而已,简单来说就是: 在n...
    一颗地梨子阅读 1,653评论 0 1
  • 准备条件 服务器最少2-3台 服务器先添加站点 添加反向代理 找到反向代理的文件夹 修改反向代理的文件夹 至此简单...
    王玉伟的伟阅读 1,847评论 0 0
  • 更多内容请浏览本人博客 LVS搭建Nginx集群 准备工作 环境说明 设定IP环境如下 服务名IP端口作用LVS-...
    weylan阅读 536评论 0 1