`
CharlesCui
  • 浏览: 416381 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Unicorn和Passenger性能测试对比

阅读更多

测试工具:ab

 

测试用例:

1.短连接

2.长连接

 

APP:

class App < Sinatra::Application

        get '/' do
            "HELLO "+Time.now.to_s
        end 

        get '/sleep' do
            sleep 5
            "HELLO "+Time.now.to_s
        end
end

run App.new

 

测试环境:

Unicorn:

100进程,

写道
[zheng.cuizh@localhost tbMemberServer]$ ps axf|grep unicorn -c
102
 

8080端口

Passenger:

基于nginx

100进程,

写道
[zheng.cuizh@localhost tbMemberServer]$ ps axf|grep nginx -c
102
 

8081端口

 

测试结果:

场景1:

ab -c 100 -n 10000 10.1.166.138:8080/ => rps:1634

ab -c 100 -n 10000 10.1.166.138:8081/ => rps:1318

场景2:

ab -c 100 -n 100 10.1.166.138:8080/sleep?vcatwbwrge => rps:19.65

ab -c 100 -n 100 10.1.166.138:8081/sleep?v34rnjnf9 => rps:1.17

 

结果比较,unicorn比passenger性能看似好很多,但我不清楚如何关闭缓存,我对这两个东西的配置还不是很熟悉,所以我猜测在测试过程中可能会有读取缓存页的情况,这会使得测试结果看起来速度更快。

 

不过passenger基于nginx,所以支持的并发访问数要比unicorn高,比如测试1000并发的第二个场景时,unicorn出现socket closed by peer的提示,然后ab终止,passenger没出现这个问题。实际生产环境unicorn不会出现在部署的最前端,也会用nginx作一层代理。

 

不管性能哪个更好,希望ruby的库们越来越优秀,越来越丰富。

 

ps:谁告诉我一下这两个server如何关闭cache?比如我用ab的话不能对每次url请求都生成一个随机数,这时候就需要关闭server的缓存。

分享到:
评论
13 楼 zires 2011-05-07  
night_stalker 写道
unicorn 也很好维护啊,通过 signal 控制,信号和 nginx 很相似,发个信号就能热部署,热部署的时候没有请求 queue 延迟的问题 (用posix函数实现的load balancing就比你们自己搞的global queue好用⋯⋯)

unicorn 的进程维护应该比较优才对。可以设置请求后才进行 gc(tps会下降但是用户体验效果很好),可以自动杀超时进程,可以动态增加减少 worker ⋯⋯


热部署很好用
我在生产环境中也使用unicorn + nginx
关于维护和部署方面是用capistrano来管理unicorn也很方便啊
12 楼 CharlesCui 2011-05-06  
kiol 写道
Unicorn是直接部署到前端吗?
还是前面再加nginx做反向代理?


生产环境上要加nginx,
测试开发环境,或者生产环境只有一台server的话,我就直接用unicorn了,

别的同学怎么用的?
11 楼 night_stalker 2011-05-05  
unicorn还有个好处是100% ruby,实现比passenger简单

一般前面再加nginx(unicorn不是设计来处理静态文件的,用unix socket或者端口代理都可以, unicorn源码中带nginx配置的example : https://github.com/defunkt/unicorn/blob/master/examples/nginx.conf),有特殊需求不加也可以⋯⋯
10 楼 kiol 2011-05-05  
Unicorn是直接部署到前端吗?
还是前面再加nginx做反向代理?
9 楼 mamba 2011-05-05  
t0uch 写道
unicorn相当不错。
使用passenger要编译nginx这一点很不爽。
unicorn部署可以让用户感觉不到延迟,这一点很牛,signal控制起来也很方便。


强烈同意, 我从 passenger 切换到 unicorn 的唯一原因就是 passenger 需要编译 nginx
8 楼 t0uch 2011-05-05  
易卡螺丝君 写道
Passenger+Nginx
在性能方面差据不到5%
维护和部署方面有30%以上优势 你说选谁?

这里的所谓5%和30%从哪里来的呢?还是你随便说说的?
7 楼 t0uch 2011-05-05  
unicorn相当不错。
使用passenger要编译nginx这一点很不爽。
unicorn部署可以让用户感觉不到延迟,这一点很牛,signal控制起来也很方便。
6 楼 night_stalker 2011-05-04  
unicorn 也很好维护啊,通过 signal 控制,信号和 nginx 很相似,发个信号就能热部署,热部署的时候没有请求 queue 延迟的问题 (用posix函数实现的load balancing就比你们自己搞的global queue好用⋯⋯)

unicorn 的进程维护应该比较优才对。可以设置请求后才进行 gc(tps会下降但是用户体验效果很好),可以自动杀超时进程,可以动态增加减少 worker ⋯⋯
5 楼 CharlesCui 2011-05-04  
Hooopo 写道
CharlesCui 写道
易卡螺丝君 写道
Passenger+Nginx
在性能方面差据不到5%
维护和部署方面有30%以上优势 你说选谁?


什么5%?
维护和部署方面的30%这个数据是谁测试出来了?

不理解。


是啊,这个怎么测的


虎扑现在混哪里的?记得前震子你还在东北呢,怎么现在到北京了。
4 楼 Hooopo 2011-05-04  
CharlesCui 写道
易卡螺丝君 写道
Passenger+Nginx
在性能方面差据不到5%
维护和部署方面有30%以上优势 你说选谁?


什么5%?
维护和部署方面的30%这个数据是谁测试出来了?

不理解。


是啊,这个怎么测的
3 楼 CharlesCui 2011-05-04  
易卡螺丝君 写道
Passenger+Nginx
在性能方面差据不到5%
维护和部署方面有30%以上优势 你说选谁?


什么5%?
维护和部署方面的30%这个数据是谁测试出来了?

不理解。
2 楼 易卡螺丝君 2011-05-04  
Passenger+Nginx
在性能方面差据不到5%
维护和部署方面有30%以上优势 你说选谁?
1 楼 QuakeWang 2011-05-03  
我以前用 Autobench 测试过Passenger + Nginx, Thin + Nginx 和 Fastcgi + Lighttpd,我测试的是每秒30个请求开始,然后最高到180个请求,测试环境Ruby 1.9.2+Ubuntu Server。

Fastcgi的响应时间稍微比Passenger和Thin要快一点点,可以说3者在性能上的差异极小,但是在内存使用上Thin最少,而Passenger胜在部署和维护方便。 综合考虑我推荐Passenger+Nginx。

相关推荐

Global site tag (gtag.js) - Google Analytics