百万并发连接的实践测试02

简介: 百万并发连接的实践测试02

本次主要解决上次遗留的数据结构问题

代码部分

头文件

#ifndef STRUCT_H_
#define STRUCT_H_
#include <stdio.h>
#define BUFFER_LENGTH       1024
#define EPOLL_LENGTH        1024
typedef struct conn_item conn_item_t;
typedef struct conn_block conn_block_t;
typedef struct reactor_node reactor_node_t;
int reactor_init(reactor_node_t* reactor);
void reactor_dest(reactor_node_t* reactor);
int reactor_block_connect(reactor_node_t* reactor);
int reactor_item_connect(reactor_node_t* reactor, int fd);
#endif

源文件

#include "struct.h"
#include <stdlib.h>
#include <string.h>
typedef struct conn_item
{
    int fd;
    char wbuffer[BUFFER_LENGTH];
    int wc;
    char rbuffer[BUFFER_LENGTH];
    int rc;
} conn_item_t;
typedef struct conn_block
{
    struct conn_item* conntions;
    struct conn_block* next;
} conn_block_t;
typedef struct reactor_node
{
    int epfd;
    int blcnt;
    struct conn_block* block_heander;
} reactor_node_t;
int reactor_init(reactor_node_t* reactor)
{
    if(!reactor)
        return -1;
    reactor->block_heander = malloc(sizeof(conn_block_t) + EPOLL_LENGTH * sizeof(conn_item_t));
    if(reactor->block_heander == NULL)
        return -1;
    reactor->block_heander->next = NULL;
    reactor->block_heander->conntions = (conn_item_t*)(reactor->block_heander + 1);
    reactor->blcnt = 1;
    reactor->epfd = epoll_create(1);
}
void reactor_dest(reactor_node_t* reactor)
{
    if(!reactor)
        return;
    if(!reactor->block_heander)
        free(reactor->block_heander);
    close(reactor->epfd);
}
int reactor_block_connect(reactor_node_t* reactor)
{
    if(!reactor)
        return -1;
    conn_block_t* block = malloc(sizeof(conn_block_t) + EPOLL_LENGTH * sizeof(conn_item_t));
    if(block == NULL)
        return -1;
    conn_block_t* temp = reactor->block_heander;
    while(temp->next != NULL)
        temp = temp->next;
    temp->next = block;
    block->conntions = (conn_item_t*)(block + 1);
    reactor->blcnt++;
    return 0;
}
int reactor_item_connect(reactor_node_t* reactor, int fd)
{
    int i = 0;
    if(!reactor)
        return -1;
    int pos = fd / EPOLL_LENGTH;
    while(pos > reactor->blcnt)
    {
        reactor_block_connect(reactor);
    }
    conn_block_t* blk = reactor->block_heander;
    for(; i < pos; i++)
    {
        blk = blk->next;
    }
    int idx = fd % EPOLL_LENGTH;
    blk->conntions[pos].fd = fd;
    memset(blk->conntions[pos].rbuffer, 0, BUFFER_LENGTH);
    memset(blk->conntions[pos].wbuffer, 0, BUFFER_LENGTH);
    blk->conntions[pos].rc = 0;
    blk->conntions[pos].wc = 0;
    return 0;
}

数据结构示意图

代码解读

上次我们是搞了一个很大的数组,这次我们做出一些优化。把做出一个链式结构,一个链表头,下面有很多块。块里面是conn_item,一个块里面有1024个conn_item。

相关文章
|
28天前
|
人工智能 自然语言处理 测试技术
从人工到AI驱动:天猫测试全流程自动化变革实践
天猫技术质量团队探索AI在测试全流程的落地应用,覆盖需求解析、用例生成、数据构造、执行验证等核心环节。通过AI+自然语言驱动,实现测试自动化、可溯化与可管理化,在用例生成、数据构造和执行校验中显著提效,推动测试体系从人工迈向AI全流程自动化,提升效率40%以上,用例覆盖超70%,并构建行业级知识资产沉淀平台。
从人工到AI驱动:天猫测试全流程自动化变革实践
|
22天前
|
数据采集 存储 人工智能
从0到1:天猫AI测试用例生成的实践与突破
本文系统阐述了天猫技术团队在AI赋能测试领域的深度实践与探索,讲述了智能测试用例生成的落地路径。
从0到1:天猫AI测试用例生成的实践与突破
|
2月前
|
Java 测试技术 API
自动化测试工具集成及实践
自动化测试用例的覆盖度及关键点最佳实践、自动化测试工具、集成方法、自动化脚本编写等(兼容多语言(Java、Python、Go、C++、C#等)、多框架(Spring、React、Vue等))
127 6
|
2月前
|
人工智能 边缘计算 搜索推荐
AI产品测试学习路径全解析:从业务场景到代码实践
本文深入解析AI测试的核心技能与学习路径,涵盖业务理解、模型指标计算与性能测试三大阶段,助力掌握分类、推荐系统、计算机视觉等多场景测试方法,提升AI产品质量保障能力。
|
2月前
|
人工智能 自然语言处理 测试技术
AI测试平台的用例管理实践:写得清晰,管得高效,执行更智能
在测试过程中,用例分散、步骤模糊、回归测试效率低等问题常困扰团队。霍格沃兹测试开发学社推出的AI测试平台,打通“用例编写—集中管理—智能执行”全流程,提升测试效率与覆盖率。平台支持标准化用例编写、统一管理操作及智能执行,助力测试团队高效协作,释放更多精力优化测试策略。目前平台已开放内测,欢迎试用体验!
|
3月前
|
人工智能 资源调度 jenkins
精准化回归测试:大厂实践与技术落地解析
在高频迭代时代,全量回归测试成本高、效率低,常导致关键 bug 漏测。精准化测试通过代码变更影响分析,智能筛选高价值用例,显著提升测试效率与缺陷捕获率,实现降本增效。已被阿里、京东、腾讯等大厂成功落地,成为质量保障的新趋势。
|
3月前
|
搜索推荐 Devops 测试技术
避免无效回归!基于MCP协议的精准测试影响分析实践
本文揭示传统测试的"孤岛困境",提出MCP(Model Context Protocol)测试新范式,通过模型抽象业务、上下文感知环境和协议规范协作,实现从机械执行到智能测试的转变。剖析MCP如何颠覆测试流程,展示典型应用场景,并提供团队落地实践路径,助力测试工程师把握质量效率革命的新机遇。
|
3月前
|
人工智能 缓存 自然语言处理
大模型性能测试完全指南:从原理到实践
本文介绍了大模型性能测试的核心价值与方法,涵盖流式响应机制、PD分离架构、五大关键指标(如首Token延迟、吐字率等),并通过实战演示如何使用Locust进行压力测试。同时探讨了多模态测试的挑战与优化方向,帮助测试工程师成长为AI系统性能的“诊断专家”。
|
3月前
|
安全 网络安全 数据安全/隐私保护
解决SSH测试连接GitHub时出现“connection closed by remote host”的问题。
然后使用 `ssh -T git@ssh.github.com`来测试连接。
423 0
|
5月前
|
人工智能 Java 测试技术
SpringBoot 测试实践:单元测试与集成测试
在 Spring Boot 测试中,@MockBean 用于创建完全模拟的 Bean,替代真实对象行为;而 @SpyBean 则用于部分模拟,保留未指定方法的真实实现。两者结合 Mockito 可灵活控制依赖行为,提升测试覆盖率。合理使用 @ContextConfiguration 和避免滥用 @SpringBootTest 可优化测试上下文加载速度,提高测试效率。
319 6