本文转载,http://blog.hellolucky.info/articles/ruby-on-rails-large-amounts-of-data-transfer-json-the-use-json-generate-data/
最近在等设计,空闲时间就tune一下api server。因为我一直很纳闷,为何action只是很单纯的到Redis捞出数据吐json,也没有什么特别的动作,到redis捞数据只需要10ms,可是最后render出json的时候竟然变成70~80ms,一整个很扯。
一开始的想法以为是Rails的包袱太重,所以我的方向朝向调整api controller,于是我就把ActionController::Base换成ActionController::Metal,一开始很兴奋的测试,只render text的时候的确快到爆炸,不过当我开始捞数据吐json的时候,速度其实和原本差不多。
突然脑袋灵机一动,把data.to_s试看看,速度快了约30ms,当下有点傻眼,后来google了一下to_json真的是个很慢的method,改成JSON.generate(data)的话一样快了约30ms。
之后有空的时候再测试一下https://github.com/msgpack/msgpack-ruby,速度快又省空间