草庐IT

延迟任务

全部标签

ruby - 仅在特定服务器上调用 delayed_job capistrano 任务

我有一个专门用于delayed_job任务的服务器。我想在仅此服务器上启动、停止和重新启动delayed_jobworker。我正在使用delayed_job提供的Capistrano食谱。当我只有1个服务器时,这是我的配置:before"deploy:restart","delayed_job:stop"after"deploy:restart","delayed_job:start"after"deploy:stop","delayed_job:stop"after"deploy:start","delayed_job:start"现在我想让这些Hook仅应用于单独的delayed

ruby-on-rails - 在 rake 任务中打印到屏幕

我有一个长时间运行的rake任务。我时不时地在屏幕上打印更新,让我知道任务已经完成了多长时间。puts"Almostthere..."我的问题是所有puts语句似乎都缓冲在某处,直到任务完成后才会打印到屏幕上。届时,它们将被一次性全部打印出来。有什么方法可以强制他们在任务运行时打印吗? 最佳答案 STDOUT.sync=true 关于ruby-on-rails-在rake任务中打印到屏幕,我们在StackOverflow上找到一个类似的问题: https://

ruby - 在 Rakefile 中设置 rspec 2 任务

我有一个看起来像这样的Rakefile:require'rspec/core/rake_task'desc"RunallRSpectests"RSpec::Core::RakeTask.new(:spec)虽然这不起作用。例如,如果我尝试运行“rake-T”,我得到:code/projects/bellybuster[master]%rake-T--trace(in/Users/craig/code/projects/bellybuster)rakeaborted!nosuchfiletoload--rspec/core/rake_task/Users/craig/.rvm/rubie

ruby-on-rails - 我如何找到特定的延迟工作(不是通过 id)?

Delayed::Job将您的类、方法和参数序列化到处理程序字段中。我们目前求助于将这种序列化方法硬编码到我们的代码中。这太恶心了。我们应该如何构建处理程序以便我们可以查找现有的排队作业? 最佳答案 这是我做的:1)添加两个新列到delayed_jobs表db/migrations/20110906004963_add_owner_to_delayed_jobs.rbclassAddOwnerToDelayedJobs2)添加多态关联到Delayed::Job模型config/initializers/delayed_job.rbc

ruby-on-rails - Capistrano:不知道如何构建任务 'deploy:new_release_path'

我是第一次部署到DigitalOceanUbuntudroplet。我已经配置了所有内容并执行了所有步骤,现在我正在执行命令:capproductiondeploy:initial。对于此命令,我收到此错误消息:capaborted!Don'tknowhowtobuildtask'deploy:new_release_path'(see--tasks)/Users/Christopher/.rbenv/versions/2.3.1/lib/ruby/gems/2.3.0/gems/rake-12.0.0/lib/rake/task_manager.rb:58:in`[]'/Users/

ruby 任务 : joining numbers to intervals

我有一组唯一编号。像这样:[1,2,3,4,7,8,10,12]。它可以是未排序的。我需要的是获取此数组的间隔:intervals_for[1,2,3,4,7,8,10,12]#=>"1-4,7-8,10,12"我有自己的解决方案:defintervals_for(array)array.sort!new_array=[]array.eachdo|a|ifnew_array.lastanda==new_array.last.last+1new_array.last1?"#{a.first}-#{a.last}":a.first}.join(",")end但我认为这里有更干净的解决方案

ruby-on-rails - 为什么 Rake 任务增强在我的本地环境和部署到 Heroku Cedar 时有所不同?

我在lib/tasks/foo.rake中有这个:Rake::Task["assets:precompile"].enhancedoprint">>>>>>>>hellofromprecompile"endRake::Task["assets:precompile:nondigest"].enhancedoprint">>>>>>>>hellofromprecompile:nondigest"end当我在本地运行rakeassets:precompile时,两条消息都会被打印出来。当我推送到heroku时,只打印非摘要消息。然而,accordingtothebuildpack,推送正在

ruby-on-rails - 如何编写 Rake 任务将数据导入 Rails 应用程序?

目标:使用CRON任务(或其他预定事件)更新数据库,每晚从现有系统导出数据。所有数据都是在现有系统中创建/更新/删除的。该网站不直接与该系统集成,因此Rails应用程序只需要反射(reflect)数据导出中出现的更新。我有一个包含约5,000种产品的.txt文件,如下所示:"1234":"productname":"attr1":"attr2":"ABCManufacturing":"2222""A134":"anotherproduct":"attr1":"attr2":"FoobarWorld":"2447"...所有值都是用双引号(")括起来的字符串,用冒号(:)分隔字段是:id

ruby-on-rails - Google-maps-for-Rails - rake 任务中(对象)的未定义方法 `gmaps'

当我运行涉及启用了gmaps4rails的模型的rake任务时,我收到此错误,如果我评论该模型,使其不是acts_as_gmappable,它会正确完成。entercodeheretroy$rakepopulate:scans--trace**Invokepopulate:scans(first_time)**Invokeenvironment(first_time)**Executeenvironment**Executepopulate:scanshttp://goo.gl/fb/977zeSat,16Jul201119:43:59GMT47.676506-122.12187291

ruby-on-rails - spork 可以处理 rake 任务吗?

Rake任务遇到与运行测试相同的问题:Rails启动过程在任务运行之前需要很长时间。有没有办法将spork和rake整合在一起? 最佳答案 您可以使用irakegem,它可以从控制台执行rake任务。将此添加到Gemfile:gem'irake'然后捆绑并启动控制台$bundleinstall$railsconsole...并等待Rails环境加载(仅一次)。然后你可以这样做:rake"db:migrate"如果你想列出任务,你可以:Rake::Task.tasks.each{|t|putst.name};nil