嗯,近期都在网易游戏实习,所以貌似有段时间没有上来写点东西了。。。

来网易游戏实习最基本的目的事实上就是想知道在游戏公司里面工作都是些什么内容,毕竟自己曾经也没有接触过游戏公司。。

还比較的好奇。。

曾经可能认为游戏公司各种高大上吧。做的工作各种有意思。

。如今看来应该也不是这样子的,毕竟大多数时间应该还是在写游戏的逻辑代码了。。

挺奇怪的。

。感觉尽管在游戏公司实习。可是做的事情还是自己的老本行。

。。由于要用python开发一个server的监控系统。并且有提出要监控某个指定进程所占用的网络带宽的情况。

。。嗯。

找来找去python没有现成的东西来做这件事情。

。并且本身能够用的东西都比較少。

。。

只是倒是找到了类似的东西。

。。nethogs。

一个专门用于linux下监控各个进程的网络带宽的程序。

。。

所以就直接看了下他的代码实现。

。代码不是非常多吧。。

。c++写的。

。。并且非常easy。。。这里就不详细的说这部分的代码了。。。直接来说一下功能实现的原理吧。。

。。


嗯,比較重要的一个文件夹:/proc  

嗯。事实上它是一个伪文件夹吧,由于它并不存在于实实在在的文件系统其中。而是一个执行时创建的文件夹。并且保存的信息也都是一些执行时的信息,比如进程信息,网络连接信息什么的。。。

好,如今如果我们有一个进程,它的PID 是 7140。那么我们能够进入例如以下文件夹:

/proc/7140/fd

事实上这里看名字就大概可以猜到这个文件夹下保存的都是什么数据吧:当前进程所打开的文件描写叙述符。。。例如以下图:

linux下实现监控进程网络带宽_linux


嗯。这个应该非常熟悉吧。。。略微了解一点linux以下编程的就应该知道,在程序中,我们的socket,或者打开文件都是相应着一个文件描写叙述符。那么上述的文件夹中就保存了我们程序执行中文件描写叙述符的情况。。然后这些事实上又都是链接,终于连接到一个inode上面。。。在这里能够看到我们两个socket都相应着23045以及23046这两个inode。

。。


那么我们怎样在找到上述这两个socket的详细的信息呢。。。

嗯。在终端输入例如以下命令:cat /proc/net/tcp

我们能够得到的输出例如以下图:linux下实现监控进程网络带宽_网易游戏_02


这里就是当前本机所建立的全部的tcp的信息。

。。

ip地址,port啥的。。

。最后我们还能够看到一个项目:inode。

。。也就是这个链接它所关联的inode。。。

到这里就应该可以将前面所示进程的文件描写叙述符与它详细的链接信息相应起来了吧。。。


好啦。。。通过上面的过程呢。。

我们能够获取一个进程它所建立的全部的连接的信息了。

。。

那么接下来一步就是怎样来计算它的网络流量情况了。

。。

嗯。这里nethogs 採用的方法是利用libcap来抓包。然后对网络包进行分析,从而来计算每个连接它的网络流量情况。。。(嗯,好多代码都是直接採用的nethogs的源码)

嗯,这里就不详细的来列出实现的代码了。

用c++以及libcap为python写了一个linux以下的扩展库。。。代码传到了github上面。。

。地址例如以下:

https://github.com/2225377fjs/processNet

点击打开链接