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

软硬件分工

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

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

相关推荐
扛枪的书生2 小时前
Linux 网络管理器用法速查
linux
顺风尿一寸5 小时前
Java Socket 内核之旅:从 SocketChannel.read() 到 tcp_recvmsg 与 epoll 的完整调用链路
linux
extrao7 小时前
🚀 Kea DHCP4 自动分配系统完整搭建
网络协议
疯狂的魔鬼11 小时前
告别 boolean 地狱:一个文件上传组件的状态机实践
前端·设计
XIAOHEZIcode11 小时前
Ubuntu 终端美化全栈指南:Bash 到 Kitty 踩坑实录
linux·ubuntu·命令行
唐青枫13 小时前
别再只会用 cron:Linux systemd Timer 定时任务实战详解
linux
疯狂的魔鬼1 天前
一个"懂分寸"的文本省略组件是怎样炼成的
前端·vue.js·设计
不做菜鸟的网工2 天前
BGP特性
网络协议
AlfredZhao2 天前
生产环境里,为什么不建议把普通端口直接暴露到公网?
linux·https·443·80
戴为沐3 天前
Linux内存扩容指南
linux