nginx-负载均衡相关配置 第五章
一、负载均衡:
通过反向代理客户端的请求到一个服务器群组,通过某种算法,将客户端的请求按照自定义的有规律的一种调度调度给后端服务器。
Nginx的负载均衡使用upstream定义服务器组,后面跟着组名,组名后面是大括号包起来的服务器列表,每个服务器使用server开头,后面跟定义的服务器名字、服务器IP:Port、参数;
1:upstream要写在Server块的外面,可以有多个,名称不同即可,如下:
upstream webserver { #配置后端服务器组
server 10.2.61.23:;
server 10.2.61.21:;
}
server {
listen ;
server_name localhost;
location / { #指定访问 / 负载到webserver 组中
proxy_pass http://webserver ;
proxy_set_header X_Forworded_For $remote_addr; #将客户端地址插入数据报头
}
location ~* ^/aab/ { #正则表达式匹配 /aab 路径 ,后端服务器必须要有这个路径
add_header webserver $upstream_addr; #将后端服务器地址插入到响应报头中,网上很多人说需要安装ngx_http_headers_module 模块。我测试默认支持这个模块,只有 add_header ,add_trailer ,expires.
proxy_pass http://webserver;
proxy_set_header X_Forworded_For $remote_addr;
}
}
访问结果:


1.2:nginx支持的三种负载方式:
round-robin:轮训调度,默认
ip_hash:会话绑定
least_conn:最少会话链接
1.3 backup 服务器
upstream webserver {
server 10.2.61.23: weight= max_fails= fail_timeout=;
server 10.2.61.21: backup;
}
server {
listen ;
server_name localhost;
location / {
proxy_pass http://webserver ;
proxy_set_header X_Forworded_For $remote_addr;
}
location ~* ^/aab/ {
add_header webserver $upstream_addr;
proxy_pass http://webserver;
proxy_set_header X_Forworded_For $remote_addr;
}
}
1.4 实现动静分离:

upstream web {
server 192.168.0.1 weight=1 max_fails=2 fail_timeout=2;
server 192.168.0.2 weight=1 max_fails=2 fail_timeout=2;
}
upstream image {
server 192.168.0.3 weight=1 max_fails=2 fail_timeout=2;
server 192.168.0.4 weight=1 max_fails=2 fail_timeout=2;
}
upstream php {
server 192.168.0.5 weight=1 max_fails=2 fail_timeout=2;
server 192.168.0.6 weight=1 max_fails=2 fail_timeout=2;
}
location /{
root html/web;
index index.php index.html;
}
location ~* \.php$ {
fastcgi_proxy http://php;
}
location ~* "\.(.jpg|png|jpeg|gif)" {
proxy_pass http://image;
}
1.5 实现数据缓存:
缓存是缓存nginx服务器接收请求过的数据,数据超时时间不能太长,因为数据可能会发生变化,但是nginx服务器内部的缓存的数据还没有更细,会导致客户端请求的数据不是最新数据的问题,数据缓存目录不能定义在server快内,要定义在http块中。
proxy_cache_path /usr/local/nginx/cache/first levels=: keys_zone=first:20m max_size=1g; #定义缓存路径与参数
upstream webserver {
server 10.2.61.23: weight= max_fails= fail_timeout=;
#server 10.2.61.21: backup;
#server 10.2.61.23: weight= max_fails= fail_timeout=; }
server {
listen ;
server_name localhost;
location / {
proxy_pass http://webserver;
proxy_set_header Host $host;
#add_header Host $upstream_addr ;
add_header X_Via $server_addr; #添加服务器地址到报文头部
add_header X-Cache $upstream_cache_status; #添加缓存状态到报文头部
proxy_cache first; #调用缓存
proxy_cache_valid 10m; #为状态码 为200 的缓存设置缓存时间为 10 分钟,不定义缓存不生效
proxy_set_header X_Forworded_For $remote_addr; }
location ~* ^/aab/ {
add_header webserver $upstream_addr;
proxy_pass http://webserver;
proxy_set_header X_Forworded_For $remote_addr;
}
}
#/usr/local/nginx/cache/first定义缓存目录参数
#evels=1:2 定义两层目录,第一层一个字符名称,第二个两个字符名称
#keys_zone=first:20m 每个缓存都是一个共享内存空间。这就是用户定义共享内存空间地址的名称
#max_size=1g 定义目录最大空间为1g,因为缓存空间越大搜索数据越慢,因此不宜太大。

1.6 另外常用的三种缓存:
open_log_cache:日志缓存,降低磁盘IO
open_file_cache:打开文件句柄缓存,将文件缓存至 Nginx管理的内存当中加速响应
fastcgi_cache:缓存后端php服务器的内容,当时如果php内容发生更改则会导致客户端访问的页面不是最新的,因此要慎用。
另外Nginx的limit限制也是基于内存共享来实现的
1.7 sticky 会话保持,基于自定义cookie 进行会话保持的方式
安装包下载地址:https://github.com/bymaximus/nginx-sticky-module-ng
./configure --prefix=/usr/local/nginx --sbin-path=/usr/local/nginx/sbin/nginx --conf-path=/usr/local/nginx/conf/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --pid-path=/var/run/nginx/nginx.pid --user=nginx --group=nginx --with-http_ssl_module --with-http_stub_status_module --with-http_gzip_static_module --with-pcre=/usr/local/src/pcre-8.42 --with-zlib=/usr/local/src/zlib-1.2. --with-stream --add-module=/usr/local/src/nginx-1.14./echo-nginx-module-master --add-module=/usr/local/src/headers-more-nginx-module-master --add-module=/usr/local/src/nginx-sticky-module-ng-master
upstream webserver {
server 10.2.61.23: weight= max_fails= fail_timeout=;
#server 10.2.61.21: backup;
server 10.2.61.23: weight= max_fails= fail_timeout=;
sticky expires=1h path=/;
}

upstream webserver {
server 10.2.61.23: weight= max_fails= fail_timeout=;
#server 10.2.61.21: backup;
server 10.2.61.23: weight= max_fails= fail_timeout=;
sticky name=srv_id expires=1h path=/;
}

nginx-负载均衡相关配置 第五章的更多相关文章
- nginx负载均衡简单配置
nginx负载均衡简单配置准备三台虚拟机来做这个实验:192.168.232.132 web服务器192.168.232.133 web服务器192.168.232.134 ...
- nginx负载均衡及配置
nginx负载均衡及配置 1 负载均衡概述 负载均衡由来是因为当一台服务器单位时间内的访问量很大时,此时服务器的压力也会很大,当超过自身承受能力时,服务器就会崩溃.为避免让服务器崩溃,用户拥有更好的体 ...
- nginx 负载均衡相关知识
Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器. Nginx 是由 Igor Sysoev ...
- nginx 负载均衡简单配置
配置要求: 三台服务器 127.0.0.1 主负载(把访问请求分给主机池) 127.0.0.2 主机2 127.0.0.3 主机3 第一步: 配置127.0.0.1 ...
- nginx负载均衡常见问题配置信息
nginx为后端web服务器(apache,nginx,tomcat,weblogic)等做反向代理 几台后端web服务器需要考虑文件共享,数据库共享,session共享问题.文件共享可以使用nfs, ...
- Nginx负载均衡各种配置方式
Nginx负载均衡 - 小刚qq - 博客园http://www.cnblogs.com/xiaogangqq123/archive/2011/03/04/1971002.html Module ng ...
- Nginx负载均衡NFS配置
Nginx配置 首先在两台服务器上部署同一个项目,例如下: 测试网站节点1: http://192.168.168.61/nfstest/ 测试网站节点2: http://192.168.64.145 ...
- window下nginx负载均衡简单配置-----权重的实现
下面介绍一个在window下的nginx的负载均衡配置. 需要你在你的电脑上跑两个tomcat.一个8080,一个9080. 需要一个nginx服务器. 需要修改本机的host 注意:我们这里配置不会 ...
- php nginx 负载均衡简单配置过程
负载均衡 负载均衡是我们大流量网站要做的一个东西,下面我来给大家介绍在Nginx服务器上进行负载均衡配置方法,希望对有需要的同学有所帮助哦. 简单了解一下什么是负载均衡,单从字面上的意思来理解就可以解 ...
随机推荐
- post数据过多时,有可能会丢失数据
开奖时,post时请求的user_id过多,导致活动id丢失
- centos 安装 python36
centos6 安装 python36 临时方法: https://www.softwarecollections.org/en/scls/rhscl/rh-python36/ 方法二: http:/ ...
- 基于nmap扫描结果的端口爆破工具:BrutesPray
大家搞内网或者C段渗透测试的时候可能遇到很多时候需要对大批的主机进行精确爆破,这时候BruteSpray就派上用场了. BruteSpray是一款基于nmap扫描输出的gnmap/XML文件.自动 ...
- java学习之路--简单基础的面试题
1.面向对象的特征有哪些方面? 答:面向对象的特征主要有以下几个方面: 1)抽象:抽象是将一类对象的共同特征总结出来构造类的过程,包括数据抽象和行为抽象两方面.抽象只关注对象有哪些属性和行为,并不关注 ...
- java中的静态代理和动态代理
1.动态代理的定义:为其他对象提供一个代理以控制对这个对象的访问 代理类主要负责委托类的预处理消息,过滤消息,把消息传给委托类以及消息事后处理 按照代理类的创建时期,代理类可以分为2种:静态代理类(在 ...
- ASP.NET页面使用JQuery EasyUI生成Dialog后台取值为空
原因: JQuery EasyUI生成Dialog后原来的文档结构发生了变化,原本在form里的内容被移动form外面,提交到后台后就没有办法取值了. 解决办法: 在生成Dialog后将它append ...
- android不知不觉偷拍他人功能实现(手机关闭依然拍照)【申明:来源于网络】
android不知不觉偷拍他人功能实现(手机关闭依然拍照)[申明:来源于网络] 地址:http://blog.csdn.net/huangxiaoguo1/article/details/536660 ...
- vins-mono的边缘化分析
##marg 基础 摘自贺一家的博客 在我们这个工科领域,它来源于概率论中的边际分布(marginal distribution).如从联合分布p(x,y)去掉y得到p(x),也就是说从一系列随机 ...
- vim快捷键与vi
vim与程序员 所有的 Unix Like 系统都会内建 vi 文书编辑器,其他的文书编辑器则不一定会存在. 但是目前我们使用比较多的是 vim 编辑器. vim 具有程序编辑的能力,可以主动的以字体 ...
- vue computed的执行问题
1.在new Vue()的时候,vue\src\core\instance\index.js里面的_init()初始化各个功能 function Vue (options) { if (process ...