草庐IT

02.HTTP协议与应用开发

全部标签

ruby-on-rails - Rails 开发模式下的日志轮换?

对于Rails3.1(很快将是3.2),我有非常详细的日志,其中包含大量额外的工作人员信息。我通常会得到数GB的development.log文件。我看到过一些关于轮换生产日志的讨论,但是我没有发现任何似乎适用于development.log轮换的内容。您如何在每100.megabytes左右轮换您的development.log?或者我更喜欢实际截断文件头,以便只有最近的项目保留在日志中,最近的条目最多100MB。我已经玩了一点,并且越来越多地认为目前不存在这样的东西,也许我应该实现一些将以某种方式使用ruby​​File.truncate的东西,但是我到目前为止,我还不确定它在文件

ruby - 我应该如何在开发过程中试用我的 gem?

假设我有一个名为foo的gem,其文件结构如下:foo.gemspectest_foo.rblib/foo.rblib/foo/file1.rblib/foo/file2.rbtest_foo.rb文件包含一些我用来试用我的gem的代码。它使用以下行访问gem的代码:require'./lib/foo'然后,lib/foo.rb访问gem所需的其他文件,如下所示:require'./lib/foo/file1'require'./lib/foo/file2'由于test_foo.rb在gem目录的根目录下,所以需要要求lib/foo中的文件从根目录开始的完整路径。一切正常,并且允许我通

ruby - 为什么在 Net::HTTP 上使用 Faraday?

为什么有人会使用Faradaygem而不是直接使用Net::HTTP?使用这样的包装器有什么好处? 最佳答案 直接使用Net::HTTP适配器就可以了,它只是将您的代码绑定(bind)到一个特定的接口(interface),这可能与其他工具不同。人们会使用Faraday的主要原因是它包装了多个适配器,其中之一是Net::HTTP。如果您使用Faraday并开始使用Net:HTTP,您可以稍后决定使用Excon,Typhoeus,Patron或EventMachine无需更改超过一两行配置。如果您直接使用Net::HTTP,则必须更改

ruby-on-rails - PHP 开发人员学习 Ruby 和 Ruby on Rails

关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于StackOverflow来说是偏离主题的,因为它们往往会吸引自以为是的答案和垃圾邮件。相反,describetheproblem以及迄今为止为解决该问题所做的工作。关闭9年前。Improvethisquestion我对学习Rails很感兴趣已经有一段时间了,我觉得现在正是浸入其中并实际动手实践的好时机。在过去的一周里,我阅读了所有我能找到的关于Ruby和RubyonRails的免费电子书。我刚刚读完RubyEssentials。我也一直在玩htt

ruby-on-rails - 创建日历/计划程序应用程序 - Ruby on Rails

我正在考虑使用RubyonRails开发一个应用程序,它是一种规划器。我想让用户能够查看日期列表,单击特定日期,然后添加诸如:膳食、费用、事件、待办事项和练习之类的内容。真的,我这样做是为了我和我成长中的家庭。我很好奇如何最好地实现它。我当然可以看到Meals、Expenses等需要belong_to:user但我很好奇如何实现belongs_to:day或类似的东西。使用created_at或updated_at不一定能让我提供future日期的View。我可以看到如果我创建一个天数表,然后通过时间和日期字段添加天数,这将如何工作,但要求人们创建实际天数似乎有点奇怪。或者也许我可以创

ruby-on-rails - 为什么在部署 Rails 应用程序时需要 Apache 服务器?

虽然我们可以用webrick或mongrel部署它 最佳答案 大多数Ruby应用程序服务器只会运行一个Ruby进程(Ruby有一个全局解释器锁,这使得多线程变得毫无意义),这意味着它一次只能处理一个请求。至少可以说,这不会给你很好的表现。有两种解决方法:运行多个Ruby应用程序服务器并在它们前面放置一个负载平衡器或反向代理,例如Nginx或Apache在一堆Mongrels或瘦服务器前面(您运行的进程数反射(reflect)了您将能够并行处理的请求数)。或者你运行Passenger,它是一个Apache或Nginx模块,管理一个应用

ruby - Net::HTTP 中的服务器名称指示支持?

我正在尝试让Ruby的Net::HTTP实现与SNI一起工作。mail.google.com和gmail.com都位于同一个IP地址上,因此当通过SSL连接时,Google服务器需要知道要使用哪个证书。默认情况下,它会返回mail.google.com证书,如果您尝试实现WebFinger,这就是一个问题。WebFinger要求您检索https://gmail.com/.well-known/host-meta以获取LRDD信息,但是,出于安全原因,验证SSL证书至关重要信息。由于Google在这种情况下提供默认的mail.google.com证书,因此SSLpost_connecti

ruby - 后台工作人员在 Rails 应用程序中查看通信

假设我有一个包含帖子的博客应用程序。创建帖子后,将创建一个工作人员来处理一些后台操作。我的情况是,在提交表单后我想显示某种加载消息(gif加载器等),当工作人员完成时我想隐藏加载消息并显示工作人员提供的一些数据。我的问题是,传达工作人员已完成工作并将其显示在用户前端的最佳方式是什么。worker回调看起来像这样defworker_finish#messagetheuserend 最佳答案 我认为您可能忽略了拥有后台工作人员的意义,基本上,您试图做的是弄巧成拙。--如果用户提交表单并且你在你的Controller中排队作业,只是为了让

ruby - 如何在 Node.js/RoR 中监控 20 个网站(Ping 或 HTTP)的正常运行时间

每5分钟(例如)ping20个网站的列表以了解该网站是否响应HTTP202的最佳方法是什么?最简单的想法是将20个URLS保存在数据库中,然后运行数据库并对每个URL执行ping操作。但是,当一个人不回答时会发生什么?之后的人会怎样?此外,是否有更好但更简单的解决方案?恐怕该列表会增长到20000个网站,然后没有足够的时间在我需要ping的5分钟内全部ping通它们。基本上,我是在描述PingDom、UptimeRobot等的工作原理。我正在使用node.js和RubyonRails构建这个系统。我也倾向于使用MongoDB来保存所有ping和监控结果的历史记录。建议?非常感谢!

ruby-on-rails - 使用 cookie 制作 Ruby Net::HTTP::Get 请求

我想通过ruby​​打开我的stackoverflow.com页面。我希望看到它就像我通过了身份验证一样。我从GoogleChrome中获取了usrcookie并创建了以下代码段:require'net/http'require'cgi'url="http://stackoverflow.com/users/1650525/alex-smolov"uri=URI(url)http=Net::HTTP.new(uri.host,80)request=Net::HTTP::Get.new(uri.request_uri)cookie=CGI::Cookie.new("usr","[myco