草庐IT

Spring之异步任务@Async详解分析

全部标签

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

ruby-on-rails - ElasticSearch Rails - 设置自定义分析器

我通过elasticsearch-rails(https://github.com/elasticsearch/elasticsearch-rails)在Rails4中使用ElasticSearch我有一个带有电子邮件属性的用户模型。我正在尝试使用文档中描述的“uax_url_email”分词器:classUser我按照wiki(https://github.com/elasticsearch/elasticsearch-rails/wiki)和elasticsearch-model文档(https://github.com/elasticsearch/elasticsearch-ra

ruby - 有没有办法用内存分配报告来分析 ruby​​ 1.9.2 脚本?

我的ruby​​应用程序遇到了瓶颈,但我无法弄清楚它在哪里变慢了。我找到了memprof,但它不支持1.9。我还发现ruby​​-prof似乎在1.9.2上运行良好,但内存分配需要修补的ruby​​解释器,我只能找到ruby​​1.8的补丁。是否有ruby​​分析器可以完成这项工作? 最佳答案 您是否尝试过分析GC?Ruby1.9.2包括GC::Profiler。GC::Profiler.enableGC.startputsGC::Profiler.report您可能还想查看ObjectSpace.count_objects。

ruby-on-rails - 带有 splat 参数的 Rake 任务

我正在尝试创建一个rake任务,它需要一个必需的第一个参数,然后是我想将它们组合到一个数组中的任意数量的附加参数:rakecourse["COURSENAME",123,456,789]我尝试了以下方法,但args[:numbers]只是一个带有123的字符串,而不是所有数字。task:course,[:name,*:numbers]=>:environmentdo|t,args|putsargs#{:name=>"COURSENAME",:numbers=>"123"}end 最佳答案 从rake10.1.0开始,您可以使用Rak

ruby - 在 RSpec 中调用相同的 rake 任务两次

我正在尝试使用rspec测试rake任务,为此我需要调用它两次,但是它只被调用一次。it'firsttest'doRake::Task['my_rake_task'].invoke#raketaskwasprocessedendit'secondtest'doRake::Task['my_rake_task'].invoke#raketaskwasNOTprocessedend 最佳答案 如果rake任务已经被调用过,除非你调用它,否则它不会再次运行:@rake[@task_name].reenable或调用它@rake[@task

ruby - 如何从 rake 任务启动 IRB 控制台?

我正在尝试编写一个rake任务来设置一个镜像我的项目的环境。task:environmentdorequire'rubygems'require'sequel'#require'my_projects_special_files'endtask:foo=>[:environment]dorequire'irb'IRB.startend导致irb提示“foo”不存在(任务名称)10:28:01:irb_test>>rakefoo--trace(in/Users/mwlang/projects/personal/rake/irb_test)**Invokefoo(first_time)**

ruby-on-rails - 在 Rails 3 生成器中多次调用任务

我正在编写一个Rails3生成器来创建两个不同的模型。这是我正在尝试做的一个非常简单的例子:defmy_generator_taskinvoke"model",["foo"]invoke"model",["bar"]end问题是Thorinvokemethod只调用一次任务,因此对“模型”任务的第二次调用永远不会发生,并且永远不会创建“bar”模型。有谁知道一种优雅的方式来实现这一目标,最好是以一种不会破坏使用生成器运行“railsdestroy”的能力的方式? 最佳答案 再想一想,这样也可以在不迁移的情况下运行多个模型生成器Rai

ruby - Thor 可执行文件 - 忽略任务名称

雷神维基页面,MakinganExectable,向您展示了如何创建一个看起来像这样的thor支持的CLI命令:庆典./mythorcommandfoo这需要您将thor任务foo作为第一个参数传递。我还可以使用thor的default_method运行不带任何参数的thor可执行文件:庆典./神话命令但是,我想传入一个可变字符串作为第一个参数:庆典./mythorcommand"somevalue"这不起作用,因为thor命令期望第一个参数是任务名称。有没有办法忽略任务名称并将第一个参数发送到默认方法?如果这个功能不存在,我认为添加一个将所有命令行参数传递到一个任务/方法中的方法会非