【协议设计与实现】Linux环境下,如何从0开始设计并实现一个网络协议之一——需要考虑的因素

  • 🐚作者简介:花神庙码农(专注于Linux、WLAN、TCP/IP、Python等技术方向)
  • 🐳博客主页:花神庙码农 ,地址:https://blog.csdn.net/qxhgd
  • 🌐系列专栏:TCP/IP协议
  • 📰如觉得博主文章写的不错或对你有所帮助的话,还望大家三连支持一下呀!!! 👉关注✨、点赞👍、收藏📂、评论。
  • 如需转载请参考转载须知!!

【协议设计与实现】Linux环境下,如何从0开始设计并实现一个网络协议之一------需要考虑的因素

协议位置

  • 一种协议,既可以在用户态实现,也可以在内核态实现。
  • 当然,也可以同时在用户态和内核态来实现(各自分工不同)。

报文格式

  • 需要定义报文的格式:
    -- 具体涉及哪些字段,其中哪些是必选的,哪些又是可选的;
    -- 各字段的长度是定长的还是变长的?
  • 同时,报文的格式,会因报文是二层或三层报文,而也有所不同。

报文收发

  • 报文接收:可自定义协议的ptype,或使用hook,raw socket等方式;
  • 报文发送:用户态可用socket方式,内核态则可直接使用xmit函数即可;
  • 根据需要,一般要和一个接口绑定,或者实接口或者虚接口。

协议数据

  • 协议的数据一般使用结构体或结构体数组来组织;
  • 如果涉及的数据量比较大,则需要考虑使用哈希表来组织。

协议配置

  • 协议涉及一些参数,具体如何对协议进行配置?
    -- 用户态,可考虑使用文件的形式;
    -- 如果同时涉及用户和内核态,则需要考虑用户态内核态通讯的问题;

协议调试

  • 协议调试,可考虑增加调试命令或调试手段,可考虑下面几点功能:
    -- 查看统计,如接口的统计等;
    -- 打印报文,可使用调试开关,控制收发报文的打印,也可细化仅打印特定的报文(特定MAC、特定类型等);
    -- 查看协议的配置和状态,考虑proc文件等方式;

协议状态机

  • 每种协议都有自己的状态机,而状态机有不同的实现方式:
    --switch-case模式
    -- 表驱动

软硬件分工

  • 协议所涉及的功能,如果涉及芯片,且芯片支持该功能,则可考虑使用硬件实现。
  • 如果硬件不支持,则只能考虑软件实现。

如本文对你有些许帮助,欢迎大佬支持我一下,您的支持是我持续创作的不竭动力
支持我的方式

相关推荐
liulian09164 分钟前
Flutter 网络状态与内容分享库:connectivity_plus 与 share_plus 的 OpenHarmony 适配指南
网络·flutter
Bug-制造者5 分钟前
正则表达式 vs Shell通配符:彻底分清,告别命令行踩坑
linux·正则表达式
雨的旋律209914 分钟前
linux网卡绑定bond设置一步不少
linux·运维·网络
OpenAnolis小助手17 分钟前
Anolis OS Linux Dirty Frag 漏洞安全声明
linux·安全·web安全·龙蜥社区
北山有鸟27 分钟前
解决香橙派没有适配ov13855的3A算法
linux·c++·相机·isp
是垚不是土28 分钟前
PostgreSQL 运维工程师 “一本通“ :安装、配置、备份与监控
linux·运维·数据库·postgresql·运维开发
Irene199130 分钟前
在 Linux 命令中,- 开头的东西几乎都是“参数/选项“,用来告诉命令“具体怎么做“
linux
IT大白鼠30 分钟前
Linux账号和权限管理
linux·运维·服务器
zzzyyy53833 分钟前
Linux 下 从 ELF 可执行文件 到 进程虚拟地址空间的加载、映射与运行底层原理
linux·运维
tiandyoin43 分钟前
IPCONFIG重置网络
网络·ip·dfs·dns·vpn·cmd