草庐IT

Concurrency

全部标签

ruby - Ruby 1.9.1 中的 native 线程,对我有什么好处?

所以,Ruby1.9.1现在是declaredstable.Rails应该与它一起工作,并且正在慢慢地将gem移植到它。它具有native线程和全局解释器锁(GIL)。自从GIL到位后,原生线程是否比1.9.1中的绿色线程有任何优势? 最佳答案 1.9中的线程是原生的,但它们被“放慢了速度”,一次只允许一个线程运行。这是因为如果线程真的并行运行,它会混淆现有代码。优点:IO现在在线程中是异步的。如果一个线程阻塞在IO上,那么另一个线程将继续执行直到IO完成。C扩展可以使用真正的线程。缺点:任何非线程安全的C扩展都可能存在使用Thre

ruby - 使用什么异步 Ruby 服务器?

我们开始使用Ruby开发新游戏项目。我们决定使用其中一种异步Ruby服务器,但我们无法决定选择哪一种。选项是:歌利亚抽筋+消瘦/彩虹rack-fiber_pool+rack+thin/rainbowseventmachine_httpserver它们似乎都在处理HTTP请求。Cramp还支持开箱即用的Websocket和服务器端事件。您知道这些服务器的优缺点吗? 最佳答案 我使用eventmachine_httpserver公开了一个RESTfulAPIinanEventMachine-basedIRCbot绝对不会推荐它用于任何严

Ruby 并发/异步处理(简单用例)

我一直在研究ruby​​的并行/异步处理能力,并阅读了许多文章和博客文章。我查看了EventMachine、Fibers、Revactor、Reia等。不幸的是,我无法为这个非常简单的用例找到简单、有效(且非IO阻塞)的解决方案:File.open('somelogfile.txt')do|file|whileline=file.gets#(R)ReadfromIOline=process_line(line)#(P)Processthelinewrite_to_db(line)#(W)WritetheoutputtosomeIO(DBorfile)endend你看到了吗,我的小脚本正

ruby - Ruby 线程不能在写入时发生冲突吗?

在过去的C#和Java工作中,我习惯于这样的声明不是线程安全的:x+=y;但是,在与Ruby并行运行上述代码时,我未能观察到任何线程间的冲突。我读过Rubyautomaticallypreventsmultiplethreadsfromwritingtothesamedataconcurrently.这是真的?因此+=运算符在Ruby中是线程安全的吗? 最佳答案 好吧,这取决于您的实现和很多事情。在MRI中,有一个GVL(GiantVMLock)这样的东西,它控制哪个线程一次实际执行代码。你看,在MRI中,一次只有一个线程可以执行R

ruby - 并发::Promise.all?不起作用

在执行所有promise后,我正在尝试进行一些计算。但是proc从不调用:cbr_promise=Concurrent::Promise.execute{CbrRatesService.call}bitfinex_promise=Concurrent::Promise.execute{BitfinexService.call}proc=Proc.newdoputs10endConcurrent::Promise.all?([cbr_promise,bitfinex_promise]).then{proc}使用concurrent-ruby制作gem。例如,我是否应该创建一个每100毫秒

ruby - 处理并发 ruby​​ 线程池中的异常

如何处理并发ruby​​线程池中的异常(http://ruby-concurrency.github.io/concurrent-ruby/file.thread_pools.html)?例子:pool=Concurrent::FixedThreadPool.new(5)pool.postdoraise'somethinggoeswrong'end#howtorescuethisexceptionhere更新:这是我的代码的简化版本:defprocesspool=Concurrent::FixedThreadPool.new(5)products.eachdo|product|new_

ruby - 异步发出多个 HTTP 请求

require'net/http'urls=[{'link'=>'http://www.google.com/'},{'link'=>'http://www.yandex.ru/'},{'link'=>'http://www.baidu.com/'}]urls.eachdo|u|u['content']=Net::HTTP.get(URI.parse(u['link']))endprinturls此代码以同步方式工作。第一个请求,第二个,第三个。我想异步发送所有请求并在所有请求完成后打印urls。最好的方法是什么?Fiber适合吗? 最佳答案

ruby - 是否有适用于 Ruby 的异步日志记录库?

同步日志记录会导致很大的性能损失,因为它可能会阻塞。是否有一个独立的Ruby库可以进行异步日志记录(log4r似乎没有)?我可以修改标准库记录器以异步记录吗?我正在寻找类似log4j的AsyncAppender的东西-但最好是使用Ruby的代码块将尽可能多的工作转移到后台线程的实现。 最佳答案 我知道你不应该真正回答你自己的问题,但在ruby​​中似乎一切都很简单:require'thread'require'singleton'require'delegate'require'monitor'classAsyncincludeSi

ruby - Ruby 纤程可以并发吗?

我正在努力提高我的程序的速度,有人告诉我Ruby纤程比线程更快,并且可以利用多核。我环顾四周,但我就是找不到如何同时实际运行不同的光纤。使用线程,您可以执行此操作:threads=[]threads我看不出如何用纤维做这样的事情。我能找到的只有yield和resume,它们看起来只是纤维之间的一堆启动和停止。有没有办法用纤程实现真正的并发? 最佳答案 不,您不能使用Fiber进行并发。Fiber根本不是一个并发结构,它们是一个控制流结构,就像Exception一样。这就是Fiber的重点:它们从不并行运行,它们是合作的并且是确定性的

ruby-on-rails - 如何进行 Ruby on Rails 并发测试?

使用ruby​​onrails3进行并发测试的最佳方法是什么?我的网站上有很多竞争条件,目前测试它们是一门不精确的科学,非常耗时。提前感谢您的任何回复。 最佳答案 我相信Tourbus可以提供帮助。 关于ruby-on-rails-如何进行RubyonRails并发测试?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/6125343/