存档

‘ruby’ 分类的存档

Rails 使用Haml代替Rhtml

2009年1月1日 没有评论
什么是Haml
Haml,一款简洁的的类似Rhtml的插件,可以极大的简少写xhtml等视图代码的量。

安装haml
安装gem
sudo gem install haml
安装haml plugin至rails
haml –rails [rails路径] 如 haml –rails . 则安装haml插件至当前目录

第一个haml

%h1 Chapters#index
%p
  == Time: #{Time.now}
  =h "a~!@\#$%^&*()+-"

输出

<h1>Chapters#index</h1>
<p>
  Time: Thu Jan 01 01:56:57 +0800 2009
  a~!@#$%^&amp;*()+-
</p>

比起笨重的Rhtml实在是简化不少。

性能
rhtml 158.72 reqs/s
haml 154.83 reqs/s
下降约 2.45%
单个文件请求时间绝对值增加 0.159ms
对性能的影响还是微乎其微的

相关链接
haml首页
Haml Tutorial
Haml Documentation

分类: 2 ruby/rails, ruby, 编程 标签:

Fastcgi,Lighttpd比Nginx更好

2009年1月1日 没有评论

javaeyerobbin建议我使用lighttpd 我对服务器的实现机制不太了解,只要哪个稳定,支持高负荷,快则选哪个。试用了lighttpd后,的确发现在fastcgi方面比nginx做得更好。比如nginx 500并发测试rack,fastcgi会出现broken pipe错误。而lighttpd不会。虽说我相信可能是我配置不当,且可以通过nginx和linux一些设置来解决这问题,但没有理由不去选择直接可以正常运行而性能不分伯仲的lighttpd。nginx的配置服务器非常更方便,灵活。如果没有那个错误,我想我还是会继续走nginx之路 :p

分类: 2 ruby/rails, ruby, 编程 标签:

对于这两天ruby开发网站性能测试总结

2008年12月31日 2 条评论

这只是个人测试,也是个ruby初学者的测试,如果因优化不周而造成重大误差还请各位能多多指教。

  1. Rails vs Rack vs Merb:
    Rails 性能比Merb差不少,但文档,插件丰富,加上Rack可以高速处理某些需求。又闻Merb要并入Rails,高速处理又有Metal,真是前景无限。
    Rack 一个字快,爽。
    Merb 看上去很美,只是发觉文档太少。不太试合初学者,比如我想让ActiveRecord支持Enum类型,Merb似乎需要自已操刀,而Rails可以拿来就用
    速度上 静态>Rack>Merb>Rails
    速度横向比较
    静态 Rack Merb Rails
    速度 3130 1192 305 180

    (单位:reqs/sec)

  2. Cache:

    page缓存很方便,而且直接生成html,很容易实现全站静化,只是如果每个文件id都放于同一目录下,很难想像几万文件挤在一个目录下。cache还有待学习。似乎fragment能解决这个问题。
    对于很简单的helloworld,action缓存不快反慢。reqs由180下降到150。

  3. 服务器:
    Fastcgi比mongrel快不少。mongrel更易使用。我现在是 development用mongrel,production用fastcgi
    Nginx和lighttpd差不多快,
    apache2的mod_rails性能记得也不错,具体数值忘了,apache2太大型,内存占得多,配置灵活性没Nginx好,且在性能上和Nginx与Lighttpd有不小差距,所以不再予考虑。
  4. 我个人最终取向:
    Nginx+Fastcgi+Rails+Rack 作为我的Rails平台。

2009-1-21补充:

  1. Fastcgi

    经过实践,发现在fastcgi上lighttpd略胜一筹,最佳的性能稳定Rails平台还是为公认的 Lighttpd+Fastcgi. 但不可否认nginx为非常优秀的服务器,特别是他的配置方式,我尤为中意。

  2. Cache

    提到的Fragment Cache与Page Cache为2个不同等级的cache,
    Page提供全文cache,在controller中以caches_page :actionName形式。
    Fragment为区域cache,在views中以 <% cache do %> xxx <%end%> 形式。
    关于Fragment Cache存储方式如文档中提到的

    #内存cache,也是默认的cache
    ActionController::Base.cache_store = :memory_store
    #以文件形式保存
    ActionController::Base.cache_store = :file_store, "/path/to/cache/directory"
    ActionController::Base.cache_store = :drb_store, "druby://localhost:9192"
    ActionController::Base.cache_store = :mem_cache_store, "localhost"
    ActionController::Base.cache_store = MyOwnStore.new("parameter") #重写自已的Store
    

    在environment可以添加语句 config.cache_store = xxx 进行设置

    网上很多文章因使用的rails版本已过时,仍以 fragment_cache_store= 作为教程存在,使人走了不少弯路。所以在rails升级或学习的过程中,阅读changelog是很有必要的。

    关于自定义Store网上教程似乎很少,但因其并不复杂,又因rails源码公开,大家可参考MemoryStore的源文件 memorystore_cache.rb
    如 class MyOwnStore < ActiveSupport::Cache::Store 并重写write,read等方法,则可以轻松制定Fragment的缓存方式。

    关于更多cache可以参考http://www.railsenvy.com/2007/2/28/rails-caching-tutorial 但注意该rails的版本也以过时,因为其log显示还是以Completed in 0.18700 (5 reqs/sec) | Rendering: 0.10900 (58%) | DB: 0.00000 (0%)形式。

分类: 2 ruby/rails, ruby, 编程 标签:

Ruby Rack + Fcgi 那是相当的快啊!!!

2008年12月31日 没有评论
如下Rack代码

#!/usr/bin/ruby
require 'rubygems'
require 'rack'

class HelloRack
        def call(env)
                [200,{"Content-Type"=>"text/html"},["Hello Rack"]]
        end
end
Rack::Handler::FastCGI.run(HelloRack.new)

页面为最简单的输出“Hello Rack”
测试结果:
Requests per second: 1192.04 [#/sec] (mean)
太强悍了。
鄙人这台虚拟机nginx静态文件也不过
Requests per second: 3130.42 [#/sec] (mean)
速度横向比较

静态 Rack Merb Rails
速度 3130 1192 305 180

(单位:reqs/sec)
以后小任务就交给你啦Rack。
Rails不久会有Metal,也是基于Rack,听说很快,让我们拭目以待。

分类: 2 ruby/rails, ruby, 编程 标签:

merb自已附带了一个.gitignore

2008年12月30日 没有评论

人都是比较懒的,我就因为.gitignore的存在,merb用git而不是svn版本控制了。而且git在ruby中很流行,看来凡是学ruby的人都会慢慢git化。

分类: 2 ruby/rails, ruby, 编程 标签:

测试下来Merb比Rails快80%

2008年12月30日 没有评论
同样是最简单的Hello World程序
昨日测Rails约为180左右
而Merb达到了305req/s
比Rails快60-70%。
非常不错。
分类: 2 ruby/rails, ruby, 编程 标签:

Rails服务器Nginx+Fastcgi比Nginx+Mongrel快不少

2008年12月29日 没有评论
测试Fastcgi命令 ab -n1000 -c[并发数] http://localhost:4001/test
测试Mongrel命令 ab -n1000 -c[并发数] http://localhost:4002/test
请求对象:rails最简单的generate直接生成的view
下图测试结果数据为“每秒请求数 ”   

  Fastcgi Mongrel+Proxy 性能提升百分比
1并发 180.76 164.52 9.87%
2并发 175.92 113.26 55.32%
10并发 182.01 121.21 50.16%
100并发 182.15 117.18 55.44%
200并发 107.19 47.34 126.43%
500并发 107.38 16.62 546.09%

总结:测试下来Nginx+Fastcgi比Nginx+Mongrel快很多,但200并发和500并发测试时,到大约900请求后会速度走骤降,特别是mongrel几乎都快挂了。mongrel和fastcgi都这样,不清楚为什么。但用100并发,无论连续测几次都能以稳正的正常速度完成。
–2008-12-29 23:58–
于是让nginx多开了4个fcgi进程,共5个fcgi进程,于是可以支持500并发了
Requests per second: 178.93 [#/sec] (mean)
Time per request: 2794.346 [ms] (mean)
Time per request: 5.589 [ms] (mean, across all concurrent requests)
为什么我只开1个fcgi就不行呢

分类: 2 ruby/rails, ruby, 编程 标签:

ruby irb添加自动完成功能

2008年12月15日 没有评论

编辑irb文件

vi /usr/bin/irb
require "irb"
#开启TAB补完功能
require "irb/completion"

#utf8
$KCODE="utf8"

if __FILE__ == $0
  IRB.start(__FILE__)
else
  # check -e option
  if /^-e$/ =~ $0
    IRB.start(__FILE__)
  else
    IRB.setup(__FILE__)
  end
end
分类: 1 ruby/基础, ruby, 编程 标签: ,

ruby irb显示utf8

2008年12月15日 没有评论
使用命令 $KCODE=”utf8″

irb(main):003:0> "你好"
=> "\344\275\240\345\245\275"
irb(main):004:0> $KCODE="utf8"
=> "utf8"
irb(main):005:0> "你好"
=> "你好"
分类: 1 ruby/基础, ruby, 编程 标签: ,

使用Ruby访问WordPress的XML-RPC

2008年12月15日 没有评论

使用 ‘xmlrpc/client’

require 'xmlrpc/client'
#建立server
begin
	server=XMLRPC::Client.new2("http://www.jiangmiao.org/blog/xmlrpc.php")
	server.call("wp.getUsersBlogs","admin","blog密码")
rescue
	puts $!.message
end

运行后返回我的blog信息

blogid  1
blogName        江淼的Blog
xmlrpc  http://www.jiangmiao.org/blog/xmlrpc.php
url     http://www.jiangmiao.org/blog/
isAdmin true
--------

就是这么简单:)