使用Oj JSON解析器无法获得性能改进

Dav*_*der 5 json ruby-on-rails

根据https://www.ruby-toolbox.com/categories/JSON_Parsers,我应该在使用Oj序列化哈希时获得疯狂的加速.我已经安装了最新的gem,将它包含在我的Gemfile中,运行bundle install,并且可以确认它已经被使用了.如何_know_哪个JSON渲染器在我的Rails 3应用程序中处于活动状态?但是,渲染JSON响应绝对没有加速.

在库中,我使用Ruby的mysql模块查询遗留的MySQL数据库.我将字符串转换为值,并返回一个哈希数组.这很好用,大约需要1.5到2秒.它应该在这里检索一大块数据.

CONTROLLER

@data = Gina.points(params[:project], params[:test],
    session[:username], session[:password])
respond_to do |format|
    format.html { render :text => @data }
    format.json { render :json => @data } # :text => MultiJson.engine
end
Run Code Online (Sandbox Code Playgroud)

图书馆

dbh = Mysql.real_connect(@@host, u, p)
res = dbh.query("SELECT * FROM #{d}.#{t}")
    @data = []
    res.each_hash do |row|
    obj = {}
        row.each_pair do |k, v|
            v.match(/\A[+-]?\d+?(\.\d+)?\Z/) == nil ? obj[k] = v : obj[k] = v.to_f
        end
    @data << obj
end
Run Code Online (Sandbox Code Playgroud)

我的问题是'render:json'部分.对于大约1.5 MB的数据,这可能需要大约8或9秒.在较大的数据集(3.5 - 4 MB)上,可能需要25或30.我使用JSON完全使用JSON编写,在库中使用"人工"分隔符将字符串一起使用,在视图中使用jQuery中的普通.get ,然后在浏览器中将字符串解析为JS中的哈希值.我在较小的套装上降至1.4秒,在较大的套装上降至5秒.

JSON方法干净且易于理解,并且符合设计工作的方式.字符串解析方法是一个肮脏的黑客,我不喜欢它,但它的速度提高了六倍.我在比较这两种方法时学到的有趣的事情是,将我的hacky字符串"序列化"为JSON与"渲染"文本一样快(因为没有什么可做的,真的).这个过程的密集部分实际上是序列化哈希,但这正是我希望"更快"的JSON库做得更好的事情.

我是否从根本上误解了Oj应该为我做什么,或者我只是做错了什么?

lul*_*ala 2

正如这篇博文指出的,Rails 强制 json 编码方法to_json使用它自己的编码实现。这会影响数组、哈希和整数等基类。

这意味着在 json 编码过程中默认情况下根本不使用 multi_json 和 oj,这就是为什么你感觉它很慢。

您可以手动使用 Oj 进行编码,如 @yujingz 所指出的。

作为替代方案,我使用博客文章创建一个补丁 gem以改为使用 MultiJson,它应该自动使用 Oj 进行编码。