我在lib/models/alert_import中有一个文件alert_import',我想在我的任务中使用这样的东西:task:send_automate_alerts=>:environmentdo#STDERR.puts"Pathis#{$:}"Rake.application.rake_require'../../lib/models/alert_import'ai=AlertImport::Alert.new(2)ai.send_email_with_notifcationsend在这段代码中出现错误:找不到../../lib/models/alert_import在Ale
我正在寻找一种方法来检查Rakefile中是否存在某个rake任务。我有一个任务依赖项,如果该任务可用,我只想将其作为依赖项包含在内。在这种特殊情况下,该任务仅在Rails项目中可用,但我希望我的rake任务也能在更通用的Ruby应用程序环境中工作(不仅仅是Rails)。我想做这样的事情:iftasks.includes?('assets:precompile')task:archive=>[:clean,:vendor_deps,'assets:precompile']...endelsetask:archive=>[:clean,:vendor_deps]...endend在rak
我想从rake任务中调用Controller操作。我的问题是准备http请求的最佳方法是什么?感谢所有提示。编辑:有人有其他提示吗?我试过这个但没有用:controller_obj=Controller.newcontroller.your_method我遇到了这个异常:rakeaborted!uninitializedconstantController编辑2:我试过:sess=ActionController::Integration::Session.newsess.post('/route','codes=3')但是我得到了(我在rake文件中需要'action_control
我刚刚将Sinatra应用程序部署到heroku,该应用程序包含两个rake任务:task:create_db,[:db_id,:db_name]task:destroy_db,[:db_id,:token]当我运行时herokurunrake-T在控制台中,Heroku打印以下响应:(in/app)rakecreate_db[db_id,db_name]#Creationcountdatabasetaskrakedestroy_db[db_id,token]#Destroydatabasetask但是当我运行时:herokurunrakecreate_db['test','testd
我正在使用Whenevergem运行rake任务。当我运行rake任务时,它在开发环境下运行,但当它在预定时间运行时,它指的是生产环境。如何强制在开发环境下运行预定的rake任务。据我所知,我将不得不使用RAILS_ENV变量,但无法弄清楚将它放在哪里。我认为,这与此处的Whenevergem无关。 最佳答案 在任何bash类型的shell中,您通常可以在运行时覆盖环境:RAILS_ENV=developmentraketask:name...您也可以编写一个小脚本来为您执行此操作:#!/bin/shexportRAILS_ENV=
我正在尝试使用Albacore的ZipTask压缩rake构建的工件.我正在构建的解决方案包含三个项目,这些项目的工件需要单独压缩,但这里只提及ASP.NETMVC项目。这是解决方案的目录结构:rakefile.rbsolution.slnsrc/(otherprojectsthatarenotrelevant)website/(variousfoldersIdon'twantincludedintheartifacts)bin/Content/Scripts/Views/Default.aspxGlobal.asaxweb.config起初我写了这个任务:website_direct
生产环境的物理架构包括多台机器执行不同的工作(rake任务),所有这些机器都在同一个数据库上。如果其他作业正在运行,其中一个作业会对表执行大型UPDATE,这通常会返回postgres死锁。我已经有一个rake任务来优雅地停止其他作业,但我只能从本地机器上执行它。我想实现的是:task:big_update=>:environmentdostop_tasks_on_another_servers#dotheSQLUPDATE...endstop_tasks_on_another_servers应该在其他服务器上执行rake任务。我最好的尝试是使用https://github.com/c
我正在寻找在Heroku中运行超长任务的最佳方法。我将RubyOnRails用于我的Web应用程序,我有一个很长的任务,我想在每周日的晚上运行它。大约需要15~20分钟。我已经有Rufus-Scheduler,但我不确定这是最有效的解决方案。我还找到了关于BackgroundingTasksinHeroku的信息与DelayedJob.但这是处理它的最佳方式吗?谢谢。 最佳答案 这是我每晚运行的工作所使用的:https://devcenter.heroku.com/articles/scheduler如果您的作业配置为rake任务,
我正在使用whenever为Rails应用程序安排任务。我有这样的任务:every24.hoursdocommand"do_this"rake"do_that"end我的观点是,当我将它写入我的crontab时,只要使用-w,我就会看到它生成两个同时运行的独立任务。问题是,两者在逻辑上都是一个序列,这意味着rake任务“do_that”应该在命令“do_this”已经成功运行时运行。我试图像命令“do_this”&&rake“do_that”一样联系两者,但我收到了语法错误。是否存在任何技巧可以在任何时候创建任务之间的这种依赖关系?crontab是同时、并行地执行作业,还是处理队列中同
堆栈:Apache2rails2.3.8红帽Linuxruby企业版1.8.7在我的应用程序用户的crontab中获得了以下rake任务,这意味着每15分钟将记录拉入数据库表中:*/15****app_usercd/var/www/apps/my_app/current/&&rakething:do_stuffRAILS_ENV=production我可以在cron日志中看到cron守护进程正在运行这个任务,但是它应该将记录拉入的数据库表没有改变。当我在/var/www/apps/my_app/current目录中手动运行该任务时,该任务运行正常,没有出现错误,并按照我的预期将记录拉入