【协议设计与实现】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模式
    -- 表驱动

软硬件分工

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

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

相关推荐
zhgjx-dengkewen2 分钟前
eNSP实验:配置NAT Server
服务器·网络·华为·智能路由器
添砖java‘’15 分钟前
NAT代理、内网打洞和内网穿透
linux·服务器·网络
SilentSamsara17 分钟前
Linux 文件系统入门:目录结构不是随便画的
linux·运维·服务器
0vvv040 分钟前
linux-操作系统(基础
linux
陳103040 分钟前
Linux:进程状态和优先级
linux·运维·服务器
网络小白不怕黑44 分钟前
二、初识rocky linux
linux·运维
monana61 小时前
Linux离线安装nvm 和 node
linux·运维·服务器
风子杨yxf7711 小时前
linux下oracle开机自启动以及关机自关闭数据库,并发送邮件通知
linux·运维·数据库·oracle·自启动·发邮件·自关闭
河阿里1 小时前
JWT 与 Cookie/Session 的对比分析
网络协议
Once_day1 小时前
网络以太网之(3)LLDP协议
网络·以太网·lldp