0
点赞
收藏
分享

微信扫一扫

五、负载均衡和会话保持

IT影子 2021-09-26 阅读 76
NginxNgix

负载均衡设备硬件设备常见:F5

upstream 负载均衡模块

一、负载均衡算法

算法 upstream 支持4种负载均衡调度算法
轮询(默认) 每个请求按时间顺序逐一分配到不同的后端服务器;
ip_hash 每个请求按访问IP的hash结果分配,同一个IP客户端固定访问一个后端服务器。可以保证来自同一ip的请求被打到固定的机器上,可以解决session(会话)问题。
url_hash 按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器。
fair 这是比上面两个更加智能的负载均衡算法。此种算法可以依据页面大小和加载时间长短智能地进行负载均衡,也就是根据后端服务器的响应时间来分配请求,响应时间短的优先分配。Nginx本身是不支持 fair的,如果需要使用这种调度算法,必须下载Nginx的 upstream_fair模块。

二、upstream配置

1. 轮询

upstream myweb {          #myweb只是一个定义的名字,但是必须和location中指定的 名字一致
server 10.3.134.2:80; #/服务端口
server 10.3.134.3:80;
}
server {
....
location / {
proxy_pass http://myweb; #upstream myweb 定义的服务器列表
}

2. 热备

upstream myweb {
server 10.3.134.2:80;
server 10.3.134.3:80 backup; #热备
}
server {
....
location / {
proxy_pass http://myweb;
}

3. 加权轮询

upstream myweb {
server 10.3.134.2:8080 weight=1;
server 10.3.134.3:8080 weight=2; 权重高的先被访问}
server {
....
location / {
proxy_pass http://myweb;
}

4. ip_hash

upstream myweb {
server 10.3.134.2:8080;
server 10.3.134.3:8080;
ip_hash;
}
server {
....
location / {
proxy_pass http://myweb;
}

5. 参数

nginx负载均衡配置状态参数
down 表示当前的server暂时不参与负载均衡。
backup 预留的备份机器。当其他所有的非backup机器出现故障或者忙的时候,才会请求backup机器,因此这台机器的压力最轻。
max_fails 允许请求失败的次数,默认为1。当超过最大次数时,返回proxy_next_upstream 模块定义的错误。
fail_timeout 在经历了max_fails次失败后,暂停服务的时间单位秒。max_fails可以和fail_timeout一起使用。
   upstream myweb {
server 10.3.134.2:8080 weight=2 max_fails=2 fail_timeout=2;
server 10.3.134.3:8080 weight=1 max_fails=2 fail_timeout=1;
}

三、nginx配置7层协议

举例讲解下什么是7层协议,什么是4层协议。
(1)7层协议
OSI(Open System Interconnection)是一个开放性的通行系统互连参考模型,他是一个定义的非常好的协议规范,共包含七层协议。直接上图,这样更直观些:


准备三台机器:

代理服务器IP:10.3.134.2
后端服务器IP:
nginx-a:10.3.134.98
nginx-b:10.3.134.3

配置代理服务器的nginx配置文件:

worker_processes  4;

worker_rlimit_nofile 102400;

events {
worker_connections 1024;
}

http {
include mime.types;
default_type application/octet-stream;

log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';

#access_log logs/access.log main;

sendfile on;
keepalive_timeout 65;
gzip on;

upstream testweb {
server 10.3.134.98:80;
server 10.3.134.3:80;
}
server {
listen 80;
server_name www.test.com;
charset utf-8;
#access_log logs/host.access.log main;
location / {
proxy_pass http://testweb;
proxy_set_header Host $host:$server_port;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}

error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
}

nginx-a

    server {
listen 80;
server_name localhost;

location / {
root /duan/html; #路径自定义
index index.html index.htm;
}

nginx-b

 server {
listen 80;
server_name localhost;

location / {
root /duan/html; #路径自定义
index index.html index.htm;
}

测试访问10.3.134.2

4层协议方法(扩展)

(2)4层协议
TCP/IP协议
之所以说TCP/IP是一个协议族,是因为TCP/IP协议包括TCP、IP、UDP、ICMP、RIP、TELNETFTP、SMTP、ARP、TFTP等许多协议,这些协议一起称为TCP/IP协议。

从协议分层模型方面来讲,TCP/IP由四个层次组成:网络接口层、网络层、传输层、应用层。



nginx在1.9.0的时候,增加了一个 stream 模块,用来实现四层协议(网络层和传输层)的转发、代理、负载均衡等。stream模块的用法跟http的用法类似,允许我们配置一组TCP或者UDP等协议的监听.

负载均衡机器配置

user  nginx;
worker_processes 1;

events {
worker_connections 1024;
stream {
upstream myweb {
hash $remote_addr consistent; #ip hash
server 10.3.134.98:80; #服务端口,服务端口改变,配置文件也要改变
server 10.3.134.3:80;
}
server {
listen 82; #监听82端口,访问时要加端口号
proxy_connect_timeout 10s;
proxy_timeout 30s;
proxy_pass myweb;
}
}

nginx 会话保持

nginx会话保持主要有以下几种实现方式。
1、ip_hash

ip_hash使用源地址哈希算法,将同一客户端的请求总是发往同一个后端服务器,除非该服务器不可用。
ip_hash语法:

upstream backend {
ip_hash;
server backend1.example.com;
server backend2.example.com;
server backend3.example.com down;
}

ip_hash简单易用,但有如下问题:

2、sticky_cookie_insert

sticky模块

语法:

upstream backend {
server backend1.example.com;
server backend2.example.com;
sticky_cookie_insert srv_id expires=1h domain=3evip.cn path=/;
}

说明:
expires:设置浏览器中保持cookie的时间
domain:定义cookie的域
path:为cookie定义路径

使用后端服务器自身通过相关机制保持session同步,如:使用数据库、redis、memcached 等做session复制

举报

相关推荐

0 条评论