nginx--->负载均衡

1. 介绍

  • Web服务器,直接面向用户,往往要承载大量并发请求,单台服务器难以负荷,我使用多台WEB服务器组成集群,前端使用Nginx负载均衡,将请求分散的打到我们的后端服务器集群中,
  • 实现负载的分发。那么会大大提升系统的吞吐率、请求性能、高容灾
  • Nginx要实现负载均衡需要用到proxy_pass代理模块配置
  • Nginx负载均衡与Nginx代理不同地方在于
  • Nginx代理仅代理一台服务器,而Nginx负载均衡则是将客户端请求代理转发至一组upstream虚拟服务池
  • Nginx可以配置代理多台服务器,当一台服务器宕机之后,仍能保持系统可用。

1.2 图解

2. 案例

2.1 环境准备

# 1. 1台机器 ip10.0.0.129(用你自己的IP)
# 2. 安装好nginx
# 3. 2个django项目(我已经准备好了)
git clone https://gitee.com/yqmc/nginx_fu.git

2.2 后台启动django程序

# 安装模块,这两个项目的包只有一个django 1.11.20的
pip3 install django==1.11.20 -i https://pypi.douban.com/simple

sudo python3 manage.py runserver 0.0.0.0:8005&
sudo python3 manage.py runserver 0.0.0.0:8006&

2.3 nginx.conf配置

 # 负载均衡的方式,默认是轮训,
 # 1人一次
 # 还有其他的负载均衡的规则
upstream mydjango {
   
       server 10.0.0.129:8005;
       server 10.0.0.129:8006;
}

location / {
        proxy_pass http://mydjango;
        }

2.4 nginx.conf完整配置

# 进程数
worker_processes  1;
events {
    worker_connections  1024;
}
# 核心代码
http {
    include       mime.types;
    default_type  application/octet-stream;
    # 定义nginx访问日志的格式 
    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;
    # 推图片等静态文件压缩,提升传输效率
    gizp  on;
    #server被称为虚拟主机,可以有多个
    # 负载均衡的方式,默认是轮训,
    # 1s一次#还有其他的负载均衡的规则
    upstream mydjango {
       server 10.0.0.129:8005;
       server 10.0.0.129:8006;
}
    server {
    	# 监听的端口号 
        listen       80;
        server_name  10.0.0.129;
        location / {
         proxy_pass http://mydjango;
        }
} 

}

2.5 访问80端口即可看到被轮询转发

3. upstream分配策略

调度算法      概述
轮询        按时间顺序逐一分配到不同的后端服务器(默认)
weight       加权轮询,weight值越大,分配到的访问几率越高
ip_hash      每个请求按访问IP的hash结果分配,这样来自同一IP的固定访问一个后端服务器
url_hash      按照访问URL的hash结果来分配请求,是每个URL定向到同一个后端服务器
least_conn    最少链接数,那个机器链接数少就分发

4.分配配置

默认 && 优先级

1.轮询(不做配置,默认轮询)

2.weight权重(优先级)

weight 权重

upstream django {
       server 10.0.0.10:8000 weight=1;
       server 10.0.0.11:9000 weight=2; #这个节点访问比率是大于8000的
}

ip_hash

# 根据客户端ip哈希分配,不能和weight一起用weight 权重 
每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器
upstream django {
    ip_hash;
       server 10.0.0.10:8000;
       server 10.0.0.11:9000;
}

 backup

# 在非backup机器繁忙或者宕机时,请求backup机器,因此机器默认压力最小
upstream django {
       server 10.0.0.10:8000 weight=5;
       server 10.0.0.11:9000;
       server node.oldboy.com:8080 backup;
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

骑猪去兜风z1

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值