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

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

还比較的好奇。。

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

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

挺奇怪的。

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

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

。。嗯。

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

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

。。

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

。。nethogs。

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

。。

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

。代码不是非常多吧。。

。c++写的。

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

。。

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

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

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

/proc/7140/fd

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

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

。。

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

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

我们能够得到的输出例如以下图:

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

。。

ip地址,port啥的。。

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

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

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

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

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

。。

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

。。

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

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

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

。地址例如以下:

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

点击打开链接

linux下实现监控进程网络带宽的更多相关文章

  1. windows和linux下关闭Tomcat进程

    windows和linux下解决Tomcat进程 windows下启动Tomcat报错,8080端口号被占用,报错信息如下 两种解决方法,一种是关闭了这个端口号,另外一种是修改Tomcat下的serv ...

  2. Linux下查看某个进程打开的文件数-losf工具常用参数介绍

    Linux下查看某个进程打开的文件数-losf工具常用参数介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 在linux操作系统中,一切皆文件.通过文件不仅仅可以访问常规数据,还 ...

  3. Linux下分析某个进程CPU占用率高的原因

      Linux下分析某个进程CPU占用率高的原因 通过top命令找出消耗资源高的线程id,利用strace命令查看该线程所有系统调用  1.top 查到占用cpu高的进程pid 2.查看该pid的线程 ...

  4. 解决linux下tomcat停止进程任存在问题

    解决linux下tomcat停止进程任存在问题 在Linux下(之所以强调linux下,是因为在windows下正常),执行tomcat ./shutdown.sh 后,虽然tomcat服务不能正常访 ...

  5. windows和linux下杀死Tomcat进程,解决端口占用

    windows和linux下解决Tomcat进程 windows下启动Tomcat报错,8080端口号被占用,报错信息如下 两种解决方法,一种是关闭了这个端口号,另外一种是修改Tomcat下的serv ...

  6. linux下1号进程的前世(kthread_init)今生(init)

    参考: 1.  Linux下1号进程的前世(kernel_init)今生(init进程)----Linux进程的管理与调度(六) 2. linux挂载根文件系统过程 3. BusyBox init工作 ...

  7. linux下脚本监控网络流量

    linux下脚本监控网络流量 学习了:https://blog.csdn.net/chenghuikai/article/details/48437479 学习了:http://www.jb51.ne ...

  8. [转帖]linux下网络监控神器"iptraf-ng"

    linux下网络监控神器"iptraf-ng" https://www.cnblogs.com/dupengfei/articles/iptraf-ng.html 优点:监控的网络 ...

  9. linux下查看当前进程以及杀死进程

    ###linux下查看当前进程以及杀死进程 查看进程 ps命令查找与进程相关的PID号: ps a :显示现行终端机下的所有程序,包括其他用户的程序. ps -A :显示所有程序. ps c :列出程 ...

随机推荐

  1. 【CS Round #39 (Div. 2 only) C】Reconstruct Sum

    [Link]:https://csacademy.com/contest/round-39/task/reconstruct-sum/ [Description] 给你一个数字S; 让你找有多少对A, ...

  2. 【Codeforces Round #426 (Div. 2) C】The Meaningless Game

    [Link]:http://codeforces.com/contest/834/problem/C [Description] 有一个两人游戏游戏; 游戏包括多轮,每一轮都有一个数字k,赢的人把自己 ...

  3. Windows学习总结(1)——win10系统最新快捷键汇总

    Win10新增功能快捷键大全: 贴靠窗口:Win + 左/右 >  Win + 上/下 > 窗口可以变为 1/4 大小放置在屏幕 4 个角落. 切换窗口:Alt + Tab(不是新的,但任 ...

  4. oracle取随机结果测试

    http://www.2cto.com/database/201307/227524.html

  5. C++集合运算函数总结 & 需要有序集合的操作

    前提:两个集合已经有序.merge() //归并两个序列,元素总个数不变,只是将两个有序序列归并为一个有序序列.set_union() //实现求集合A,B的并.set_difference()//实 ...

  6. 分析深圳电信的新型HTTP劫持方式

    昨天深圳下了一天的暴雨,2014年的雨水真是够多的. 用户的资源就是金钱,怎的也要好好利用嘛不是? ISP的劫持手段真是花样百出.从曾经的DNS(污染)劫持到后来的共享检測.无不通过劫持正常的请求来达 ...

  7. javascript创建对象的方法--原型模式

    javascript创建对象的方法--原型模式 一.总结 1.原型模式解决内存浪费的方法(继承):通过继承,对象继承原型模式下的所有属性,对象不同于其它对象的的属性自己创建或者修改 2.原型的使用(p ...

  8. 4.使用fastjson进行json字符串和List的转换

    转自:https://blog.csdn.net/lipr86/article/details/80833952 使用fastjson进行自定义类的列表和字符串转换 1.环境 jdk1.8,fastj ...

  9. BZOJ2806: [Ctsc2012]Cheat(广义后缀自动机,单调队列优化Dp)

    Description Input 第一行两个整数N,M表示待检查的作文数量,和小强的标准作文库的行数接下来M行的01串,表示标准作文库接下来N行的01串,表示N篇作文 Output N行,每行一个整 ...

  10. VB 宏+mysql解决EXCEL表格实现自动化处理

    1.表格模板自动建立源码 Sub opp()Dim myPath$, myFile$, AK As WorkbookApplication.ScreenUpdating = FalsemyPath = ...