nginx负载均衡实验

Nginx负载均衡概述

1Web服务器,直接面向用户,往往要承载大量并发请求,单台服务器难以负荷,我使用多台WEB服务器组成集群,前端使用Nginx负载均衡,将请求分散的打到我们的后端服务器集群中, 2实现负载的分发。那么会大大提升系统的吞吐率、请求性能、高容灾 3

 

Nginx要实现负载均衡需要用到proxy_pass代理模块配置

Nginx负载均衡与Nginx代理不同地方在于

Nginx代理仅代理一台服务器,而Nginx负载均衡则是将客户端请求代理转发至一组upstream虚拟服务池

Nginx可以配置代理多台服务器,当一台服务器宕机之后,仍能保持系统可用。

 upstream配置

在nginx.conf > http 区域中

1upstream django { 2 server 10.0.0.10:8000; 3 server 10.0.0.11:9000; 4} 5

在nginx.conf > http 区域 >  server区域  > location配置中

添加proxy_pass

1location / { 2 root html; 3 index index.html index.htm; 4 proxy_pass http://django; 5} 6

此时初步负载均衡已经完成,upstream默认按照轮训方式负载,每个请求按时间顺序逐一分配到后端节点。

upstream分配策略

weight 权重

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

ip_hash

1每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器 2

backup

在非backup机器繁忙或者宕机时,请求backup机器,因此机器默认压力最小

1upstream django { 2 server 10.0.0.10:8000 weight=5; 3 server 10.0.0.11:9000; 4 server node.oldboy.com:8080 backup; 5} 6

负载均衡实验环境规划

1角色 ip 主机名 2lb01 192.168.119.10 lb01 3web01 192.168.119.11 web01 4web02 192.168.119.12 web02 5

关闭防火墙

1iptables -F 2sed -i 's/enforcing/disabled/' /etc/selinux/config 3 4systemctl stop firewalld 5systemctl disable firewalld 6

一、web01服务器配置nginx,创建index.html

1server { 2 listen 80; 3 server_name 192.168.119.11; 4 location / { 5 root /node; 6 index index.html index.htm; 7 } 8} 9mkdir /node 10echo 'i am web01' > /node/index.html 11#启动NGINX 12./sbgin/nginx 13

二、web01服务器配置nginx,创建index.html

1server { 2 listen 80; 3 server_name 192.168.119.12; 4 location / { 5 root /node; 6 index index.html index.htm; 7} 8mkdir /node 9echo 'i am web02...' > /node/index.html 10#启动nginx 11./sbing/nginx 12

三、配置lb01服务器的nginx负载均衡

1.检查lb01的 nginx.conf

1http { 2 include mime.types; 3 default_type application/octet-stream; 4 sendfile on; 5 keepalive_timeout 65; 6 upstream node { 7   server 192.168.119.11:80; 8   server 192.168.119.12:80; 9} 10 server { 11 listen 80; 12 server_name 192.168.119.10; 13 location / { 14   proxy_pass http://node; 15include proxy_params; #需要手动创建 16 } 17 } 18} 19

2.手动创建proxy_params文件,文件中存放代理的请求头相关参数

1[root@lb01 conf]# cat /opt/nginx/conf/proxy_params 2proxy_set_header Host $http_host; 3proxy_set_header X-Real-IP $remote_addr; 4proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 5 6proxy_connect_timeout 30; 7proxy_send_timeout 60; 8proxy_read_timeout 60; 9 10proxy_buffering on; 11proxy_buffer_size 32k; 12proxy_buffers 4 128k; 13
1启动lb01负载均衡nginx服务 2 3./sbin/nginx 4

四、访问lb01节点nginx,反复刷新

五、nginx负载均衡调度算法

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

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

2.weight权重(优先级)

3.ip_hash配置,根据客户端ip哈希分配,不能和weight一起用

六、nginx动静分离负载均衡

 

环境准备 

 

1系统 服务 软件 ip地址 2centos7(lb01) 负载均衡 nginx proxy 192.168.119.10 3centos7(web01) 静态资源 nginx静态资源 192.168.119.11 4centos7(web02) 动态资源 django 192.168.119.12 5

 

一、在web01机器上,配置静态资源,图片等

1cat nginx.conf 2 3 4server { 5 listen 80; 6 server_name 192.168.119.11; 7 #定义网页根目录 8 root /code; 9 #定义了静态资源 10 index index.html; 11#域名匹配,所有的png、jpg、gif请求资源,都去/root/code/images底下找 12 location ~* .*\.(png|jpg|gif)$ { 13 root /code/images; 14 } 15#重启nginx 16./sbin/nginx 17
1#创建目录 2mkdir -p /code/images 3#准备首页文件 4[root@web01 /code]$cat index.html 5static files... 6#准备静态文件,图片 7[root@web01 /code/images]$wget http://pythonav.cn/av/girlone.jpg^C 8[root@web01 /code/images]$ls 9girlone.jpg 10

二、在web02配置动态请求,准备一个flask程序和静态资源转发

1cat nginx.conf 2 3#静态资源地址 4upstream static { 5server 192.168.119.11:80; 6} 7#flask动态请求 8upstream flask { 9server 192.168.119.12:8080; 10} 11 12 server { 13 listen 80; 14 server_name 192.168.119.12; 15      #当请求到达192.168.119.12:80/时,转发给flask的8080应用 16 location / { 17 proxy_pass http://flask; 18 include proxy_params; 19 } 20      #当判断资源请求是 192.168.119.12/girl.jpg时候,转发请求给static地址池的服务器192.168.119.11/ 21 location ~ .*\.(png|jpg|gif)$ { 22        proxy_pass http://static; 23include proxy_params; 24} 25

准备flask应用,flask.py

1from flask import Flask 2app=Flask(__name__) 3@app.route('/') 4def hello(): 5 return "i am flask....from nginx" 6if __name__=="__main__": 7 app.run(host='0.0.0.0',port=8080) 8

后台运行flask程序

1python flask-web.py & 2

三、在负载均衡服务器lb01上测试访问192.168.119.10

 

 

 

代码交流 2021