当我运行“脚本/服务器”时,一切正常,但是当我运行我的单元测试(raketest:units)时,我得到了下面的错误,我不知道如何解决这个问题.错误NameError:undefinedlocalvariableormethod`logger'for#/Users/kamilski81/Sites/pe/vitality_mall/vendor/rails/actionpack/lib/action_controller/test_process.rb:471:in`method_missing'/Users/kamilski81/Sites/pe/vitality_mall/lib/
我有一个使用delayed_job运行的后台任务。我可以看到它确实从日志语句运行。与在前台运行相比,它似乎没有正确的结果,所以我想在IRB控制台中调试它。我正在运行后台任务rakejobs:work并且它不会触发调试器语句。如何加载调试器? 最佳答案 启动一个标准的rails控制台rubyscript/console并在此处启动一个worker,这将看到并触发调试器语句。worker=Delayed::Worker.newworker.start 关于ruby-on-rails-如何调试
简单来说就是标准库LoggerRuby中的线程安全类?Google发现的唯一有用信息是论坛上有人说它“似乎”是线程安全的。而且我不想花时间测试记录器来弄清楚它是否正确。目前我正在使用log4r这是线程安全的,但如果标准库已经做到了,那就太过分了。 最佳答案 快速查看logger.rb会发现如下代码:defwrite(message)@mutex.synchronizedoif@shift_ageand@dev.respond_to?(:stat)begincheck_shift_logrescueraiseLogger::Shift
我正在安排一项工作,比如在10分钟内运行。如何在不使用模型中任何类型的肮脏额外字段等的情况下正确取消此特定作业。是否有删除特定作业或与特定模型、实例等相关的作业的调用? 最佳答案 免责声明:我不是delayed_job的专家用户...“是否有删除特定作业或与特定模型、实例等相关的作业的调用?”Delayed::Job只是一个ActiveRecord对象,因此您可以找到并销毁任何这些记录。根据您的用例,这可以用不同的方式处理。如果有人要手动销毁它们,这可以通过您的网络应用程序中的管理界面来处理。#listalljobsDelayed:
我无法从delayed_job获得任何日志输出,而且我不确定我的作业是否开始。这是我的Procfile:web:bundleexecrailsserverworker:bundleexecrakejobs:workworker:bundleexecclockworkapp/clock.rb这是工作:classScanningJobdefperformlogger.info"loggingfromdelayed_job"enddefafter(job)Rails.logger.info"loggingfromafterdelayed_job"endend我看到发条输出到系统输出,我可以看
Delayed::Job的自动重试功能很棒,但现在有一个作业我想手动重试。有没有一种方法我可以调用工作本身,比如...Delayed::Job.all[0].perform或者跑,或者什么的。我尝试了一些东西,并梳理了文档,但无法弄清楚如何执行作业的手动重试。 最佳答案 手动调用作业Delayed::Job.find(10).invoke_job#10isthejob.id如果成功运行,这不会删除作业。您需要手动将其删除:Delayed::Job.find(10).destroy 关于r
网络上是否有关于如何使用Monit监控delayed_job的示例??我能找到的所有东西都使用God,但我拒绝使用上帝,因为在Ruby中长时间运行的进程通常很糟糕。(上帝邮件列表中的最新帖子?GodMemoryUsageGrowsSteadily。)更新:delayed_job现在带有samplemonitconfig基于这个问题。 最佳答案 下面是我如何让它工作的。使用collectiveideaforkofdelayed_job除了积极维护之外,这个版本还有一个不错的script/delayed_job可以与monit一起使用的
有点像记录器中的T恤功能。 最佳答案 您可以编写一个伪IO类来写入多个IO对象。像这样的东西:classMultiIOdefinitialize(*targets)@targets=targetsenddefwrite(*args)@targets.each{|t|t.write(*args)}enddefclose@targets.each(&:close)endend然后将其设置为您的日志文件:log_file=File.open("log/debug.log","a")Logger.newMultiIO.new(STDOUT,
google-closure库还包含一个loggingsystem大多数开发人员应该很熟悉。这很好。不幸的是,您从中获得的输出不如使用某些浏览器/插件提供的console.log时的表现力。例如,如果您在Chrome中编写console.log(window),控制台将显示一个您可以交互式检查的对象。使用google-closure记录器时,它不会那样做。我假设它会在内部简单地将对象的字符串表示形式传递给console.log。所以你失去了很多便利。正因为如此,我仍然继续使用console.log。但是,如果运气不好,您忘记将其从生产代码中删除,您的代码将在没有console.log(
我正在尝试在对应于Alfresco模板页面的javascript文件中使用logger.log("Hello")。我设置了以下内容:-在custom-log4j.properties中(覆盖log4j.properties)log4j.appender.File=org.apache.log4j.DailyRollingFileAppenderlog4j.appender.File.File=alfresco.loglog4j.appender.File.Append=truelog4j.appender.File.DatePattern='.'yyyy-MM-ddlog4j.appe