`
robbin
  • 浏览: 4798284 次
  • 性别: Icon_minigender_1
  • 来自: 上海
博客专栏
377a9ecd-1ea1-34ac-9530-9daa53bb2a7b
robbin谈管理
浏览量:135701
社区版块
存档分类
最新评论

在top监视窗口显示Rails当前正在执行的请求URL

    博客分类:
  • Ruby
阅读更多
这是一个从PragDave的博客上面学来的技巧,很实用,很cool!

话说在一个运行着Rails的网站上面,我们可以用Linux的top命令来监控Rails应用程序实例的运行状况,占用的内存,消耗的CPU等等,例如JavaEye网站的某一刻的截图:




在这个截图里面,我们可以了解Rails进程实例的运行状况,但是我们无法确切的知道,某个当前时刻消耗CPU很高的fcgi进程究竟在执行哪个请求,如果能够确切的了解这个信息,对于寻找性能瓶颈有极大的帮助,所以下面看我们来变个魔术:

在你的Rails应用的app/controllers/application.rb里面增加两个filter,如下:

before_filter :set_process_name_from_request
after_filter :unset_process_name_from_request

def set_process_name_from_request
  $0 = request.path[0,16] 
end   

def unset_process_name_from_request
  $0 = request.path[0,15] + "*"
end  


在ruby语言中$0是应用程序的命令行,因为我们以fcgi方式启动Rails,所以默认显示为dispatch.fcgi,但我们现在要改变$0,把URI强行赋值给$0,然后top就被我们欺骗了:




乖乖的给我显示出来我当前处理请求的URI是 /blog/283416,其实就是我的这篇博客:对领域模型实现的总结性观点

是不是很酷!如果Rails应用正在处理该请求,那么top显示 /blog/283416,如果Rails应用已经处理完该请求,那么top显示 /blog/283416* ,再来一个全一点的,给大家过过瘾





提醒:top命令启动以后,要按“c”,切换到显示完整命令的模式才能显示处理URI。

  • 大小: 28.7 KB
  • 大小: 10.1 KB
  • 大小: 89.5 KB
分享到:
评论
19 楼 magician 2008-12-08  
hu......

算是大致找到了php的做法,不过相当麻烦

-------------------------------------------------------

思路与django大致相当,就是调用/lib/libc.so.6中的prctl方法(直接使用prctl命令不行)。

但是php无法直接dl这个so,因为不是php extendsion,所以先得自己包一个,写写c代码

后面就和django一样了,我就不重复了

django的做法:http://www.iteye.com/topic/286277
18 楼 magician 2008-12-04  
robbin 写道
magician 写道
php有做到这个的可能吗?


如果你是apache mod_php来跑的话,也许你可以试试修改 _ENV["_"] 这个环境变量的值,把它的值改成_SERVER["REQUEST_URI"]看看。但我没有试过行不行。


感谢回复

不过我是用lighttpd+fcgi跑的php,手头上暂时也找不到apache的环境,没法测试

我想深入一下问问

这个方法的原理是通过修改环境变量来试图欺骗top命令对吧,那么理论上我只要知道lighttpd是通过哪个环境变量显示进程名字,然后修改它就可以了,是吗?

或者我理解的有错误,请指正,谢谢!
17 楼 robbin 2008-12-04  
magician 写道
php有做到这个的可能吗?


如果你是apache mod_php来跑的话,也许你可以试试修改 _ENV["_"] 这个环境变量的值,把它的值改成_SERVER["REQUEST_URI"]看看。但我没有试过行不行。
16 楼 airport 2008-12-03  
困扰很多年的问题,今天看到了
15 楼 johnnyhg 2008-12-03  
用JAVA做也应该是这种做法!
14 楼 系统程序 2008-12-03  
:( 没有切换到完整命令的模式
13 楼 系统程序 2008-12-03  
我的好像不行啊? CentOS 5.2 fcgi+lighttpd布署
12 楼 hozaka 2008-12-03  
07年的时候已经有一个类似的插件,不过是针对 mongrel 的一个扩展,实现相同的目的
http://purefiction.net/mongrel_proctitle/
11 楼 FGhost 2008-12-03  
 
好cool..
很实用..
10 楼 fanix 2008-12-02  
这个办法真不错,多谢robin同志,带来的总是这么惊艳的东西
9 楼 magician 2008-12-02  
php有做到这个的可能吗?
8 楼 inosin 2008-12-02  
过瘾的不得了~
7 楼 yangzhihuan 2008-12-01  
这个也想到了,赞一个。
6 楼 richyzhang 2008-12-01  
确实很酷.
脚本语言的天堂.
5 楼 wosmvp 2008-12-01  
相当不错,用在脚本上,就可以知道脚本的运行情况了,哈哈
4 楼 fsword 2008-12-01  
好阿,确实很实用
3 楼 koalant 2008-12-01  
可惜在 BSD 系统上不管用。
2 楼 robbin 2008-12-01  
playcase 写道

很cool. 想了解下加这个filter对性能是否会有影响?

没啥影响。
1 楼 playcase 2008-12-01  
很cool. 想了解下加这个filter对性能是否会有影响?

相关推荐

Global site tag (gtag.js) - Google Analytics