IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> PHP知识库 -> 一、tcp负载均衡--加权轮询 -> 正文阅读

[PHP知识库]一、tcp负载均衡--加权轮询

Nginx 最新版本已经支持 传输层端口转发 和负载均衡 stream 模块。使用stream模块在编译nginx时需要添加–with-stream参数。
1、什么叫加权轮询?
加权轮询是指nginx照配置权重来分发給上游服务器请求。让不同服务器按照配置来承担压力。假设有a,b,c服务器,轮询权重按如下配置,则在7次请求中a服务器会接受请求1次,b服务器会接受请求2次,c服务器会接受请求4次。

upstream cluster
{
server a weight=1;
server b weight=2;
server c weight=4;
}

2、加权轮询算法nginx源码
这里仅列出加权轮询算法的核心代码、

/*
假设按照1中配置 a权重1 b权重2 c权重4 那么下面函数 第一次调用 会将current_weight分别设置为 1 2 4。最大的是4 ,所以c服务器被选中。
c服务器权重减掉总权重(4-7)变为-3。下次再调用函数for循环后a,b,c权重为2,4,1。最大的是b,所以b就被选中。b服务器权重减掉总权重(4-7)变为-3。
这样经过7次选择后,a就被选中了1次。b被选中了2次。c被选中了4次。7次选择后所有的权重都会变为0。
*/
static ngx_stream_upstream_rr_peer_t *
ngx_stream_upstream_get_peer(ngx_stream_upstream_rr_peer_data_t *rrp)
{
	//这里rrp->peers->peer 是一个链表 保存所有上游服务器的信息 (包括ip地址 端口号等、具体数据结构后续单独发文章)
    for (peer = rrp->peers->peer, i = 0;
         peer;
         peer = peer->next, i++)
    {
    	//effective_weight 初始化 和 weight相等
        peer->current_weight += peer->effective_weight;
        total += peer->effective_weight; //计算所有服务器权重总和
        //选择当前权重 最大的服务器配置数据结构
        if (best == NULL || peer->current_weight > best->current_weight) {
            best = peer;
            p = i;
        }
    }
	//被选中的当前权重减掉 总权重
    best->current_weight -= total;

    return best; 
}

3、gdb调试nginx加权轮询源码
这里使用gdb 调试客户端连接请求时 nginx加权轮询的过程。
nginx 配置如下

worker_processes 1;
events {
worker_connections 1024;
}
stream {
upstream bitbucket-ssh {
server localhost:9001;
server 120.48.9.1:9001;
}
server {
listen 9000;
proxy_pass bitbucket-ssh;
}
}

gdb启动nginx(关于gdb调试nginx后续单独发链接)
我们这里配置了两个服务器 ,权重参数未配置(默认所有服务器相等)。nginx监听端口设置为9000。
b ngx_stream_proxy_module.c:696 在 这个文件的696行设置断点。
进程数配置为1。也就是一个master进程。一个worker进程。接受客户端连接肯定是在woker进程中处理的。所以set fllow-fork-mode child 将gdb设置为跟踪子进程。
在这里插入图片描述
r 命令开始运行nginx程序。下图可以看到nginx已经启动了。接下来就是使用客户端连接服务器。
在这里插入图片描述
我们使用tcp客户端测试工具连接nginx。
在这里插入图片描述
点击打开 开始连接nginx服务的9000端口。
在这里插入图片描述
上图 可以看到 命中了设置的断点。 但是我设置的断点并不在加权轮询的函数内。所以在单步跟踪几次进入加权轮询函数如下图。
在这里插入图片描述
下图给出所有的调用堆栈。也就是客户端开始连接nginx后epoll_wait 返回,子进程也就被唤醒开始处理客户端的连接请求,然后就是下面的堆栈了。具体逻辑流程后续也打算发文总结。
在这里插入图片描述
我们打印一下peer这个结构 也可以看到我们配置的服务器信息 。一个是本机localhost;一个是120.48.9.1 ,都是9001端口。
在这里插入图片描述

  PHP知识库 最新文章
Laravel 下实现 Google 2fa 验证
UUCTF WP
DASCTF10月 web
XAMPP任意命令执行提升权限漏洞(CVE-2020-
[GYCTF2020]Easyphp
iwebsec靶场 代码执行关卡通关笔记
多个线程同步执行,多个线程依次执行,多个
php 没事记录下常用方法 (TP5.1)
php之jwt
2021-09-18
上一篇文章      下一篇文章      查看所有文章
加:2021-09-05 10:35:27  更:2021-09-05 10:35:41 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/15 10:26:56-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码