草庐IT

重试队列

全部标签

ruby - 在 Ruby 中用队列代替方法链,用规则代替条件

RichHickey在他的演讲中描述了Clojure和Haskell的范例SimpleMadeEasy.作为一名ruby​​/rails程序员(这就是我真正知道的),我喜欢他的想法,但不理解其中的两个想法:使用队列,而不是方法链规则而不是条件改用队列显然,在Rails中我们喜欢方法链,但我想按照他描述的方式了解Ruby中的队列是什么样子(视频中的54:54):IfthingAcallsthingB,youjustcomplectedit.Youhaveawhenandwherething.AhastoknowwhereBisinordertocallB.Whenthathappensi

ruby-on-rails - RSpec 重试抛出异常然后返回值

我有一个重试blockdefmy_methodapp_instances=[]attempts=0beginapp_instances=fetch_and_rescan_app_instances(page_n,policy_id,policy_cpath)rescueExceptionattempts+=1retryunlessattempts>2raiseExceptionendpage_n+=1end其中fetch_and_rescan_app_instances访问网络,因此可以抛出异常。我想编写一个rspec测试,它第一次抛出异常,第二次调用时不抛出异常,所以我可以测试它是否

ruby-on-rails - 如何在 resque-retry 和 Rails 4 中测试重试和失败?

我正在尝试编写一个规范来测试resque-retry的重试功能,但我似乎无法让测试正确命中binding.pry。有没有一种方法可以使用rspec3测试此功能,以便我可以验证它们是否按预期运行?这是一个请求规范,我正在尝试通过固定装置模拟实时请求,但无论我尝试什么,我似乎都无法让作业重试。gem'resque',require:'resque/server'gem'resque-web',require:'resque_web'gem'resque-scheduler'gem'resque-retry'gem'resque-lock-timeout'我正在使用resque_rspec,

ruby - Delayed_job - 多个并行队列?

我正在使用delayed_job并转移到一个更强大的新服务器。所以现在我想运行并行作业,就像现在一样IhavethePOWER!,但对delayed_job是否可以运行多个并行队列感到困惑?Thisquestion建议有命名队列,但这些队列是否都在一个表中运行,因此是顺序的?在底部@JesseWolgamott建议您可以为每个队列创建一个表,然后并行运行。有没有人这样做过,他们能告诉我是怎么做到的吗? 最佳答案 这是可能的,而且我一直在这样做。在我们的例子中,我们需要多个作业来处理三种不同类型的作业,比如queue_a、queue_

ruby - 多个sidekiq实例可以处理同一个队列吗

我不熟悉Sidekiq的内部结构,想知道是否可以启动多个具有相同配置(处理相同队列)的Sidekiq实例。是否有可能2个或更多Sidekiq实例将处理来自队列的相同消息?更新:我需要知道在超过1台机器上运行Sidekiq时是否可能存在冲突 最佳答案 是的,sidekiq绝对可以针对同一个队列运行多个进程。Redis只会将消息交给随机进程。 关于ruby-多个sidekiq实例可以处理同一个队列吗,我们在StackOverflow上找到一个类似的问题: http

ruby - Ruby的标准库中有优先级队列数据结构的实现吗?

Ruby的标准库有优先级队列实现吗? 最佳答案 不,但是there'sone在KanweiLi'sAlgorithmsandContainersGSoC2008project. 关于ruby-Ruby的标准库中有优先级队列数据结构的实现吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4204250/

ruby - 线程和队列

我很想知道实现基于线程的队列的最佳方式是什么。例如:我有10个Action,我只想用4个线程执行。我想创建一个队列,将所有10个Action线性放置,并用4个线程启动前4个Action,一旦其中一个线程执行完毕,下一个线程将启动,等等-所以一次,线程数是4个或小于4个。 最佳答案 在标准库的thread中有一个Queue类。使用它你可以做这样的事情:require'thread'queue=Queue.newthreads=[]#addworktothequeuequeue我使用非阻塞标志pop的原因是在untilqueue.emp

ruby-on-rails - Ruby on Rails 中的消息队列

人们将哪些消息队列用于他们的Rails应用程序,以及选择它的决定背后的驱动力是什么。最新的Twitter对其内部队列Starling跌倒的宣传是否会影响任何现有的设计决策。我正在开发一个需要消息队列来处理一些后台任务的应用程序,我没有做过太多这方面的工作,而且我过去看到的大部分内容都是关于Starling和Workling的,并且老实说,应用程序不是很大,这个解决方案可能就足够了,但我很想获得集成最佳解决方案的经验,因为我确信我会在某个时候将一个集成到更大的应用程序中。您会为Rails应用程序推荐哪些消息队列???编辑:感谢您的建议,我将在本周末查看其中的一些建议。再次编辑:我环顾四周

ruby - Ruby 有像栈、队列、链表、映射或集合这样的容器吗?

我在网上查了几个Ruby教程,他们似乎什么都用数组。那么如何在Ruby中实现以下数据结构呢?堆栈队列链表map组 最佳答案 (从评论中移出)好吧,通过限制堆栈或队列方法(push、pop、shift、unshift),数组可以是堆栈或队列。使用push/pop提供LIFO(后进先出)行为(堆栈),而使用push/shift或unshift/pop提供FIFO行为(队列)。map是hashes,和一个Set类已经存在。您可以使用类实现链表,但数组将使用标准数组方法提供类似于链表的行为。 关

ruby-on-rails - 在 Delayed_job 中手动重试作业

Delayed::Job的自动重试功能很棒,但现在有一个作业我想手动重试。有没有一种方法我可以调用工作本身,比如...Delayed::Job.all[0].perform或者跑,或者什么的。我尝试了一些东西,并梳理了文档,但无法弄清楚如何执行作业的手动重试。 最佳答案 手动调用作业Delayed::Job.find(10).invoke_job#10isthejob.id如果成功运行,这不会删除作业。您需要手动将其删除:Delayed::Job.find(10).destroy 关于r