Linux C/C++网络编程实战-陈硕-笔记17-多个版本的Netcat概览

操作模式

在这里插入图片描述
对于 netcat 程序,存在两种模式,即 服务端 和 客户端, 它们的区别在于连接建立的方式。 一旦连接建立,客户端/服务器 的行为都是一样的,使用两个并行的循环处理:

  • 从标准输入,写到 TCP Socket
  • 从 TCP Socket 读, 写到标准输出

主要有两种基本的并发模型:

  • 多线程配合阻塞IO
  • IO多路复用配合非阻塞

netcat 的实现

在这里插入图片描述
这里提供三种netcat的实现:

以及,为了测试以上 netcat 程序,这里还提供了对应的负载生成器:

对于 netcat 的实现这里提供了三个版本,多线程配合阻塞IO、IO多路复用配合阻塞IO、IO多路复用配合非阻塞IO。其中 IO多路复用配合非阻塞IO 实现的netcat使用不当会使整个程序阻塞。

测试

  • 右边窗口运行 chargen
    在这里插入图片描述
  • 左上运行 utop,可以看到每个程序的 CPU 使用率
    左下运行 netcat
    在这里插入图片描述
测试系统自带的 netcat 性能
  • 约为 1360MiB/s
    在这里插入图片描述
测试自实现的 netcat 性能
  • 约为 3200MiB/s
    在这里插入图片描述
  • 通过对比,我们可以发现自实现的 netcat 比系统实现的要快一些
分析cpu资源分配对整个测试结果的影响

分析 cpu 的使用率我们可以发现,在测试系统自带的 netcat 时,nc cpu 100%, 而chargen cpu 35%, 说明在测试结果11360 MiB/s 中, nc 程序是性能的瓶颈,拖慢了整个数据的传输速率。

而在测试自带的 nc 性能时,chargen cpu 100%,nc 接近 100%,测得性能为 3200 MiB/s 。

此时,如果我们再加上一个 pv 命令用于显示实时带宽,就会发现整体的测试结果会下降到 1130 MiB/s 左右。此时如果我们关注cpu的占用率,就会发现 pv 占用了一部分 cpu,导致 chargen 程序的cpu占用下降,从而拖慢了整个测试结果。
在这里插入图片描述

测试基于 python 实现的 netcat 性能
  • 约为 940 MiB/s
    在这里插入图片描述
测试基于 python 实现的非阻塞IO的 netcat 性能
  • 约为 958 MiB/s
    在这里插入图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这是一门linuxc++通讯架构实战课程,针对c/c++语言已经掌握的很熟并希望进一步深造以将来用c++linux下从事网络通讯领域/网络服务器的开发和架构工作。这门课程学习难度颇高但也有着极其优渥的薪水(最少30K月薪,最高可达60-80K月薪),这门课程,会先从nginx源码的分析和讲解开始,逐步开始书写属于自己的高性能服务器框架代码,完善个人代码库,这些,将会是您日后能取得高薪的重要筹码。本课程原计划带着大家逐行写代码,但因为代码实在过于复杂和精细,带着写代码可能会造成每节课至少要4~5小时的超长时间,所以老师会在课前先写好代码,主要的时间花费在逐行讲解这些代码上,这一点望同学们周知。如果你觉得非要老师领着写代码才行的话,老师会觉得你当前可能学习本门课程会比较吃力,请不要购买本课程,以免听不懂课程并给老师差评,差评也会非常影响老师课程的销售并造成其他同学的误解。 这门课程要求您具备下面的技能:(1)对c/c++语言掌握的非常熟练,语言本身已经不是继续学习的障碍,并不要求您一定熟悉网络或者linux;(2)对网络通讯架构领域有兴趣、勇于挑战这个高难度的开发领域并期望用大量的付出换取高薪;在这门课程中,实现了一个完整的项目,其中包括通讯框架和业务逻辑框架,浓缩总结起来包括如下几点:(1)项目本身是一个极完整的多线程高并发的服务器程序;(2)按照包头包体格式正确的接收客户端发送过来的数据包, 完美解决收包时的数据粘包问题;(3)根据收到的包的不同来执行不同的业务处理逻辑;(4)把业务处理产生的结果数据包正确返回给客户端;本项目用到的主要开发技术和特色包括:(1)epoll高并发通讯技术,用到的触发模式是epoll中的水平触发模式【LT】;(2)自己写了一套线程池来处理业务逻辑,调用适当的业务逻辑处理函数处理业务并返回给客户端处理结果;(3)线程之间的同步技术包括互斥量,信号量等等;(4)连接池中连接的延迟回收技术,这是整个项目中的精华技术,极大程度上消除诸多导致服务器程序工作不稳定的因素;(5)专门处理数据发送的一整套数据发送逻辑以及对应的发送线程;(6)其他次要技术,包括信号、日志打印、fork()子进程、守护进程等等;

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值