学习嵌入式的第三十三天-数据结构-(2025.7.25)服务器/多客户端模型

服务器/多客户端模型

循环服务器
while(1){ accept(); recv(); }

适用于简单任务,如基础Web服务器,但无法处理并发请求。

并发服务器

通过threadfork实现多任务处理。需注意子进程/线程的资源回收,避免内存泄漏。

多路IO模型服务器

使用selectepoll实现高效的事件驱动模型,适合高并发场景,减少系统资源占用。


MQTT协议(消息队列遥测传输协议)

专为嵌入式或资源受限设备设计,特点包括:

  • 低带宽、低功耗
  • 传输可靠,适合移动设备或物联网场景

工作过程

涉及三个角色:

  • 发布者:发送数据时必须携带主题名(Topic),数据发送至Broker。
  • 订阅者:向Broker注册关心的主题名,Broker记录订阅关系。
  • Broker(代理服务器):根据订阅链表匹配主题,向订阅者转发数据。

双向通信

订阅者可同时作为发布者,反之亦然。


软件安装方法

在线安装

bash 复制代码
sudo apt-get install <package_name>

本地安装

  1. 下载源码(如从www.github.org

  2. 生成配置与编译文件:

    bash 复制代码
    ./configure
  3. 编译源码:

    bash 复制代码
    make

    生成可执行文件或库文件(如.so)。

  4. 安装到系统目录:

    bash 复制代码
    sudo make install
相关推荐
XGeFei1 小时前
【Fastapi学习笔记(4)】—— JsonScheme与数据验证、错误响应格式、正则表达式
学习·fastapi
爱喝水的鱼丶1 小时前
SAP-ABAP:SAP 简单报表输出开发系列(共6篇) 第四篇:SAP 报表异常处理机制:数据校验与消息提示规范落地
开发语言·数据库·学习·算法·sap·abap
LIZHUOLONG12 小时前
linux 设备初始化
linux·运维·服务器
遇印记2 小时前
软考知识点(局域网基础)
运维·服务器·局域网
難釋懷2 小时前
Nginx-CA 签名
服务器·nginx·ssl
東雪木2 小时前
泛型、反射、注解(Spring 框架核心底层)专属复习笔记
java·windows·笔记·学习·spring
ylscode2 小时前
Linux CIFSwitch 内核新漏洞允许攻击者获得 root 权限
linux·运维·服务器
啦啦啦啦啦zzzz2 小时前
数据结构:二叉树的线索化
数据结构·算法
小陈phd3 小时前
多模态大模型学习笔记(四十七)——跨模态融合策略:早融合、中融合与晚融合核心解析
笔记·学习
进击的小头3 小时前
第7篇:MOS 管最全入门:原理、关键参数、选型、驱动与典型应用
经验分享·科技·嵌入式硬件·学习