java - 在java中调度可运行的任务
全部标签 我有一个rubyonrails应用程序,我试图在其中找到每隔几秒运行一些代码的方法。我发现了很多使用cron或类似cron的实现的信息和想法,但这些只是准确到分钟,并且/或需要外部工具。我想每15秒左右启动一次任务,并且我希望它完全独立于应用程序中(如果应用程序停止,任务也停止,并且没有外部设置)。这用于缓存数据的后台生成。每隔几秒,任务就会收集一些数据,然后将其存储在缓存中,供所有客户端请求使用。该任务非常慢,因此需要在后台运行并且不阻塞客户端请求。我是ruby的新手,但有很强的perl背景,我解决这个问题的方法是创建一个间隔计时器和处理程序,它fork、运行代码,然后在完成
在命令行我可以像这样运行多个任务rakeenvironmenttask1task2task3我如何以编程方式执行此操作?我知道我可以像这样运行一项任务Rake::Task['task1'].invoke 最佳答案 你可以调用两个任务:require'rake'task:task1do|t|ptendtask:task2do|t|ptendRake::Task["task1"].invokeRake::Task["task2"].invoke我更喜欢有先决条件的新口味:require'rake'task:task1do|t|ptend
我正在编写一个Rake脚本,其中包含带参数的任务。我弄清楚了如何传递参数以及如何使任务依赖于其他任务。task:parent,[:parent_argument1,:parent_argument2,:parent_argument3]=>[:child1,:child2]do#PerformParentTaskFunctionalitiesendtask:child1,[:child1_argument1,:child1_argument2]do|t,args|#PerformChild1TaskFunctionalitiesendtask:child2,[:child2_argum
我有以下Rakefile:task:test_commas,:arg1do|t,args|putsargs[:arg1]end并希望使用包含逗号的单个字符串参数来调用它。这是我得到的:%rake'test_commas[foo,bar]'foo%rake'test_commas["foo,bar"]'"foo%rake"test_commas['foo,bar']"'foo%rake"test_commas['foo,bar']"'foo%rake"test_commas[foo\,bar]"foo\我目前正在使用此pullrequesttorake中提出的解决方法,但有没有办法在不修
我有一个带有一些基本模型的Rails应用程序。该网站显示从其他来源检索的数据。所以我需要编写一个Ruby脚本来在我的数据库中创建新实例。我知道我可以使用测试Hook来做到这一点,但我不确定这在这里是否有意义。我不确定这个任务应该是什么样子,我如何调用它,或者它应该在我的源代码树中的什么位置(lib\tasks?)。例如,这是我的第一次尝试:require'active_record'require'../app/models/mymodel.rb'test=MyModel.newtest.name='test'test.save这失败了,因为它无法连接到数据库。这对我的新手来说意义不大
我在名为file_locker_task.rake的文件中定义了一个rake任务,如下所示namespace:myspacedotask:process=>:environmentdoFileLocker.lock_filesendend如何从命令行执行此rake任务?我试过:rakemyspace:process和rakeprocess但两者都抛出如下错误:rakeaborted!Don'tknowhowtobuildtask'process' 最佳答案 从您的Rails主目录运行rake-T-A以查看rake知道的所有任务。你的
假设我有一个需要编译一些文件的目标。该目标有另一个目标作为先决条件,即获取文件的目标。让我们这样说:task:obtaindo#obtainfilesfromsomewhereendtask:compile=>:obtaindo#docompilationend假设:obtain目标并不总是将文件放在同一个文件夹中。我如何将:compile传递给:obtain找到的路径?环境变量? 最佳答案 在我看来,使用ENV['something']更可取,因为如果你这样做(而不是$global或@instance变量),你可以将它们视为任务参
我从另一个Rake任务调用了三个Rake任务。第一个Rake任务要求在执行前设置环境变量。以下工作正常,但这意味着我丢失了关键任务的所有输出:namespace:deploydotask:staging=>:environmentdo`EXAMPLE=somethingrakedb:rebuild`Rake::Task["rakeenvs:push:staging"].invokeRake::Task["rakeapp:push:staging"].invokeendend如何使用环境变量调用第一个任务并将其输出显示到终端? 最佳答案
不可能从循环内调用相同的rake任务morethanonce.但是,我希望能够调用rakefirst并循环遍历数组并在每次迭代时使用不同的参数调用second。由于invoke只在第一次执行,我尝试使用execute,但是Rake::Task#execute不使用splat(*)运算符,只接受一个参数。desc"firsttask"task:firstdoother_arg="bar"[1,2,3,4].each_with_indexdo|n,i|ifi==0Rake::Task["foo:second"].invoke(n,other_arg)else#thisdoesn'twork
我是去年9月22日才正式学习Java的,因为在国营单位工作了4年,在天津一个月工资只有5000块,而且看不到任何晋升的希望,如果想要往上走,那背后就一定要有关系才行。而且国营单位的气氛是你干的多了,领导觉得你有野心,你干的不多,领导却觉得你这个人不错。我才26周岁,实在的受不了这种工作氛围,情绪已经压制了很多久,一心想着要跳出来,却一直找不到合适的机会。因为身边的朋友有在北京做Java开发的,他工作了四五年的时间,可以在北京拿到3万的月薪,说心里话我是真的羡慕,这远超出了我的认知范围。所以经过朋友的推荐,我开始学习Java,一共学了大概5个多月的时间,今年的3月6号在天津找到了一份Java开发