Spring之异步任务@Async详解分析
全部标签 我见过任务具有参数和依赖任务的示例,例如:task:name,[:first_name,:last_name]=>[:pre_name]do|t,args|args.with_defaults(:first_name=>"John",:last_name=>"Dough")puts"Firstnameis#{args.first_name}"puts"Lastnameis#{args.last_name}"end如果它是一个任务依赖项,你将如何将参数传递给name任务:task:sendLetter=>:name#dosomethingend 最佳答案
我正在编写一个Rake任务,我想传递一个数组作为参数之一。这是我目前的情况。task:change_statuses,:ids,:current_status,:new_statusdo|task,args|puts"argswere#{args.inspect}"end我试过以这些方式运行任务:#Firstargumentasarrayrake"change_statuses[[1,2,3],active,inactive]"#Firstargumentasstringrake"utility:change_account_statuses['1,2,3',foo,bar]"我的预期
我想传递多个参数,但我不知道数字。比如型号名称。如何将这些参数传递给rake任务以及如何在rake任务中访问这些参数。喜欢,$raketest_rake_task[par1,par2,par3] 最佳答案 您可以使用args.extras遍历所有参数,而无需明确说明您有多少个参数。例子:desc"Bringiton,parameters!"task:infinite_parametersdo|task,args|putsargs.extras.countargs.extras.eachdo|params|putsparamsende
我想在我们的Rails应用程序中包含有关Rake任务的信息。我们使用YARD用于文档,目前像lib/tasks/development.rake这样的页面默认显示为未格式化的文本。我可以使用#@markuprubyfromtheYARDdocumentation将它们呈现为Ruby源代码.但是,这只会呈现任何内联注释,即使它们包含像#@!methodfoo这样的YARD指令。这意味着theYARDdocumentationontaggingDSLs似乎不适用。我错过了什么吗?如何让YARD识别.rake文件中的代码与文档?注意我会很高兴有一个忽略实际代码并只生成文档副本的解决方案,
Rspec和Cucumber以某种方式将其纳入我的默认rake任务(这很好,因为我希望它们在那里)。但是我已经尝试在默认任务中添加额外的任务,但没有任何效果。将任务添加到默认rake任务的正确方法是什么? 最佳答案 通常你的Rakefile会有这样的东西:task:default=>[:spec]您只需要将更多任务添加到此列表中即可。 关于ruby-如何将Rake任务添加到默认Rake任务?,我们在StackOverflow上找到一个类似的问题: https:
在RubyonRails中分析Controller操作的最佳方法是什么。目前,我正在使用蛮力方法,在我认为会成为瓶颈的部分之间插入putsTime.now调用。但这感觉真的非常脏。一定有更好的方法。 最佳答案 我不久前学习了这项技术,发现它非常方便。当它就位时,您可以将?profile=true添加到任何访问Controller的URL。您的操作将照常运行,但它不会将呈现的页面传送到浏览器,而是发送一个详细的、格式良好的ruby-prof页面,显示您的操作花费时间的地方。首先,将ruby-prof添加到你的Gemfile中,
require'net/http'urls=[{'link'=>'http://www.google.com/'},{'link'=>'http://www.facebook.com/'},{'link'=>'http://www.yahoo.com/'}]urls.eachdo|u|u['content']=Net::HTTP.get(URI.parse(u['link']))endprinturls这将作为程序代码工作。我只想访问服务器,没有关于顺序的问题。我怎么能在ruby中做到这一点。一种选择是使用线程。这是一个使用线程的例子。require'net/http'urls=[{'
因此,我正在编写一个小gem,其中有一个“/tasks”目录,其中包含一些特定的rake任务。如何在需要gem的任何地方自动执行这些任务?例如,我希望在安装gem后,我可以在我的rails根目录中运行“rakemygemrake:task”。 最佳答案 对于Rails3应用程序,您可能需要考虑为您的gem制作Railtie。您可以这样做:lib/your_gem/railtie.rbrequire'your_gem'require'rails'moduleYourGemclassRailtielib/your_gem.rbmodul
我有一个Rails应用程序,不幸的是,在向Controller发出请求后,它必须进行一些需要一段时间的处理。在Rails中为长时间运行的任务或请求提供反馈或进度的最佳实践是什么?这些Controller方法通常持续60秒以上。我不关心客户端...我计划每隔一秒左右发出一个Ajax请求并显示一个进度指示器。我只是不确定Rails的最佳实践,我要创建一个额外的Controller吗?我能做点什么聪明的事吗?我希望答案集中在仅使用Rails的服务器端。预先感谢您的帮助。编辑:如果重要的话,http请求是针对PDF的。然后我让Rails与Ruport一起生成这些PDF。问题是,这些PDF非常大
我试图完全理解Rack中并发请求处理的选项。我已经使用async_sinatra构建了一个长轮询应用程序,现在正在使用throw:async和/或Thin的--threaded标志试验裸机Rack。我对这个主题很满意,但有些事情我就是无法理解。(不,我没有将并发误认为是并行,是的,我确实理解GIL强加的限制)。Q1。我的测试表明thin--threaded(即rack.multithread=true)在单独的线程中同时运行请求(我假设使用EM),这意味着长时间运行的请求A将不阻止请求B(IO放在一边)。这意味着我的应用程序不需要任何特殊编码(例如回调)来实现并发(再次忽略阻塞数据库调