大数据转JSON别用to_json

本文转载,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,可是最后renderjson的时候竟然变成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,速度快又省空间

猜你喜欢

转载自fztree.iteye.com/blog/2148664
今日推荐