jjzjj

rack_datamapper

全部标签

ruby - 如何在 Rake 中获取当前的 Rack 环境?

有没有办法在Rake中获取有关当前Rack环境的信息?例如,我如何判断Rack是在development还是production模式下运行?我知道Rake不是Rack感知的。我试图避免在生产环境和开发环境之间在几乎相同的Rake任务中复制代码。 最佳答案 问题很旧,但从未获得最佳实践答案或根本没有令人满意的答案。真正的问题是:如何确定在Rake任务中使用了哪个环境,以便加载正确的配置/进入正确的if条件。Note:AsRakedoesn'tgivemuchaboutRack(RakeisnotusingHTTP)torelyonth

ruby-on-rails - 在 Sinatra 中使用 Rack::Session::Pool

我正在探索Sinatra,我想使用session,但我不想将它们存储在Cookie中,我发现Rack::Session::Pool效果很好。现在我希望session在一定持续时间后过期,但我不明白如何实例化Rack::Session::Pool并且他们在Sinatra中使用它。有什么线索吗? 最佳答案 Sinatra非常强大,TheWickedFlea的技巧没有奏效,但这个确实奏效了:useRack::Session::Pool,:domain=>'example.com',:expire_after=>60*60*24*365谢谢

ruby - 部署 Rack 应用程序的可靠方法 (Sinatra)

我正在寻找一种可靠的方式来部署Rack应用程序(在本例中为Sinatra应用程序)。请求将花费一些时间(0.25-0.5秒等待代理HTTP请求)并且可能会有相当大的流量。我应该使用传统的mongrel集群设置吗?使用HAProxy作为负载均衡器?恩金克斯?架子?您使用过哪些解决方案,有哪些优势? 最佳答案 Nginx/unicornFTW!前面的Nginx提供静态文件和unicorn处理Sinatra应用程序。优点:性能、使用unixsocks的良好负载平衡以及无需停机即可部署/升级(您可以在不停机的情况下升级Ruby/Nginx/

ruby - Rack 和 Rails Metal(Ruby)有什么区别?

我不明白!Rack:http://rack.rubyforge.org/金属导轨:http://weblog.rubyonrails.org/2008/12/17/introducing-rails-metal看了两篇文章,眼睛都模糊了。这两个组件如何关联?例子会很棒吗? 最佳答案 Rack是Ruby网络服务器可以实现的非常轻量级的规范。它是中间件,这意味着它位于Web服务器(例如Passenger)和Rails之间。RailsMetal是一种在您需要最佳性能时使用Rails处理HTTP请求的方法。它几乎将您带入金属并绕过标准Rai

ruby datamapper 不会加载

我试图按照本教程学习Sinatraruby​​框架:http://net.tutsplus.com/tutorials/ruby/singing-with-sinatra-the-recall-app-2/但是,在运行gem安装并在test.rb中编写一个简单的sinatra服务器后,如下所示:require'sinatra'require'datamapper'get'/'do"Hello,World!"end但是当我运行命令rubytest.rb时,出现以下错误:/usr/local/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.

ruby-on-rails - 如何修复 `new' :String 的未定义方法 "Rack::Cors"

我是RubyonRails的新手,正在学习如何使用Angular,但是在我运行“geminstallrack-cors”之后,当我尝试启动Rails应用程序时,我保持收到此错误:C:/Ruby23-x64/lib/ruby/gems/2.3.0/gems/actionpack-5.1.1/lib/action_dispatch/middleware/stack.rb:35:in`build':undefinedmethod`new'for"Rack::Cors":String(NoMethodError)Didyoumean?nextfromC:/Ruby23-x64/lib/ruby

ruby - Datamapper 中多对多关系的战略性预加载?

我正在使用DataMapper,一个用于ruby​​的开源ORM,我很想抓挠。目前,DataMapper可以对一对多关系使用StrategicEagerLoading(SEL),但不能对发生N+1查询的多对多关系使用。我想设法让这项工作正常进行,但我找不到在哪里做。所以两部分问题:如何运行测试套件,以便它显示失败(注意,现在所有应该失败的规范都标记为待定)?在何处以及如何为一对多关系实现SEL? 最佳答案 对于第二个问题,您可以尝试深入研究代码:/lib/dm-core/associations/relationship.rb#Ea

ruby - 在 Rack 中使用和运行的区别

rackup文件中的use和run方法有什么区别?似乎run总是在config.ru的末尾,但似乎您应该只能使用use。启发性资源也将不胜感激。 最佳答案 use用于中间件classMyCustomMiddlewaredefinitialize(app)@app=appenddefcall(env)ifconditionenv['set-header']='MiddlewareCanmodifytheresponse&passitintonextmiddleware'end@app.call(env)endrun接受一个响应调用的参

ruby-on-rails - 使用 Unicorn + Rack 进行带外垃圾收集

我正尝试在我的RubyonRails应用程序中运行带外垃圾收集(一旦请求完成响应)。我在config.ru中添加了以下内容:#ThisfileisusedbyRack-basedserverstostarttheapplication.require::File.expand_path('../config/environment',__FILE__)beginrequire'unicorn/oob_gc'rescueLoadError,NameErrorend#Out-of-bandGC,runsGCafterevery10threquestandaftertheresponse#h

ruby - 真正的 sinatra(ruby/rack) after_filter 最快的方法是什么?

好的,这是一个简单的任务。在我向客户端呈现html之后,我想使用请求中的信息执行数据库调用。我正在使用sinatra,因为它是一个轻量级的微框架,但我真的支持ruby​​中的任何东西,如果它更快/更容易(Rack?)。我只想获取url并根据url将客户端重定向到其他地方。那么如何使用rack/sinatra作为一个真正的after_filter。after_filter我的意思是在响应发送到客户端之后。还是没有线程就无法实现?我fork了sinatra并在过滤器之后添加,但是没有办法刷新响应,即使是假设流式传输文件(显然是二进制文件)的send_data也在等待after_filter