nginx三种负载均衡的方式

nginx三种负载均衡的方式

一、轮询

1.启动docker

systemctl start docker

2切换root

su

3.启动nginx

nginx

4.创建并编辑test.py

vim test.py
from flask import Flask
app = Flask(__name__)
@app.route('/')
def index():
	return 'hello'
app.run(host='0.0.0.0',port=5000)

5.构建dockerfile

vim Dockerfile
FROM python:3.8.12-slim-buster
WORKDIR /app
COPY ./test.py ./
RUN pip install flask
CMD python test.py

6.构建镜像

docker build -t flask5000 -f ./Dockerfile .

7.启动第一个容器

docker run -it flask5000

8.退出容器

ctrl+q+p

9.启动第二个容器

docker run -it flask5000 /bin/bash

10.退出容器

ctrl+q+p

11.修改test.py

vim test.py
from flask import Flask
app = Flask(__name__)
@app.route('/')
def index():
	return 'world'
app.run(host='0.0.0.0',port=5000)

12.将修改好的test.py复制到第二个容器内

docker ps # 查看第二个容器的id
docker cp ./test.py 镜像id:/

13.修改nginx配置

vim /usr/local/nginx/conf/nginx.conf
# 在虚拟主机配置上面添加负载均衡的代码
	upstream OrdinaryPolling { # 与sever同级
    server 172.17.0.2:5000;
    server 172.17.0.3:5000;
    }
#虚拟主机的配置
    server {
		#监听端口
        listen       80;
		#域名可以有多个,用空格隔开
        server_name  localhost;
# 添加proxy_pass项,并将它的值设置为需要方向代理的地址
.....
server {
	#对 "/" 启用反向代理,当访问'/'时,会访问proxt_pass定义的地址
    location / {
    	root   html;
    	proxy_pass http://172.17.0.2:5000;
    	index  index.html index.htm;
    }
}
....

14.重新加载nginx

nginx -s reload

二、权重

前面与轮询步骤一样

nginx配置

vim /usr/local/nginx/conf/nginx.conf
# 在虚拟主机配置上面添加负载均衡的代码
	upstream OrdinaryPolling { # 与sever同级
    server 172.17.0.2:6000 weight=5;
    server 172.17.0.4:5000 weight=2;
    }
#虚拟主机的配置
    server {
		#监听端口
        listen       80;
		#域名可以有多个,用空格隔开
        server_name  localhost;
# 添加proxy_pass项,并将它的值设置为需要方向代理的地址
.....
server {
	#对 "/" 启用反向代理,当访问'/'时,会访问proxt_pass定义的地址
    location / {
    	root   html;
    	proxy_pass http://172.17.0.2:5000;
    	index  index.html index.htm;
    }
}
....

三、IP

前面步骤与轮询、权重一样

nginx配置

vim /usr/local/nginx/conf/nginx.conf
# 在虚拟主机配置上面添加负载均衡的代码
	upstream OrdinaryPolling { # 与sever同级
	ip_hash;
    server 172.17.0.2:6000 weight=5;
    server 172.17.0.4:5000 weight=2;
    }
# ip_hash指令告诉nginx服务器,同一个IP地址客户端发送的请求都将分发到同一个服务器进行处理。
#虚拟主机的配置
    server {
		#监听端口
        listen       80;
		#域名可以有多个,用空格隔开
        server_name  localhost;
# 添加proxy_pass项,并将它的值设置为需要方向代理的地址
.....
server {
	#对 "/" 启用反向代理,当访问'/'时,会访问proxt_pass定义的地址
    location / {
    	root   html;
    	proxy_pass http://172.17.0.2:5000;
    	index  index.html index.htm;
    }
}
....
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
nginx是一种高性能的web服务器,它提供了多种方式实现负载均衡,以满足大量用户访问的需求,提升服务器的稳定性和性能。 一、基于IP Hash算法负载均衡 IP Hash算法是一种基于客户端IP地址的负载均衡策略,nginx会根据请求的客户端IP地址,将请求分配给后端的服务器。当第一次请求来自一个客户端时,nginx会取得请求中的客户端IP地址,并通过哈希算法计算得出该请求应该分配到的服务器。 二、Round Robin负载均衡 Round Robin负载均衡算法是一种按照预设的规则顺序轮流选择服务器的方法。nginx会将请求平均分配给多个服务器,在遍历完所有服务器以后从头开始重新选择。 三、Least Connections负载均衡 Least Connections算法是一种根据实时服务器的连接数动态分配请求的方法。nginx会根据服务器的连接数来判断请求应该向哪台服务器分配。该算法通常适用于后端服务器性能不一的情况下,以保证业务的稳定性和可靠性。 四、ip_hash + weight负载均衡 ip_hash+weight算法是一种将IP Hash算法和Round Robin算法结合起来的方法。nginx会首先使用IP Hash算法将请求分配到特定的服务器,然后根据预先设置的权重轮流分配请求。 总之,nginx实现负载均衡有以上几种方式,不同的负载均衡策略适用于不同的应用场景,企业可以根据自身的业务特点和性能要求来选择适合的负载均衡算法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值