How to Process Items in an Array in Parallel using Ruby (and open-uri)

前端 未结 5 1645
灰色年华
灰色年华 2021-02-20 12:41

I am wondering how i can go about opening multiple concurrent connections using open-uri? i THINK I need to use threading or fibers some how but i\'m not sure.

Exampl

相关标签:
5条回答
  • 2021-02-20 13:18

    I hope this gives you an idea:

    def do_something(url, secs)
        sleep secs #just to see a difference
        puts "Done with: #{url}"
    end
    
    threads = []
    urls_ary = ['url1', 'url2', 'url3']
    
    urls_ary.each_with_index do |url, i|
        threads << Thread.new{ do_something(url, i+1) }
        puts "Out of loop #{i+1}"
    end
    threads.each{|t| t.join}
    

    Perhaps creating a method for Array like:

    class Array
        def thread_each(&block)
            inject([]){|threads,e| threads << Thread.new{yield(e)}}.each{|t| t.join}
        end
    end
    
    [1, 2, 3].thread_each do |i|
        sleep 4-i #so first one ends later
        puts "Done with #{i}"
    end
    
    0 讨论(0)
  • 2021-02-20 13:19
    module MultithreadedEach
      def multithreaded_each
        each_with_object([]) do |item, threads|
          threads << Thread.new { yield item }
        end.each { |thread| thread.join }
        self
      end
    end
    

    Usage:

    arr = [1,2,3]
    
    arr.extend(MultithreadedEach)
    
    arr.multithreaded_each do |n|
      puts n # Each block runs in it's own thread
    end
    
    0 讨论(0)
  • 2021-02-20 13:24

    A simple method using threads:

    threads = []
    
    [1, 2, 3].each do |i|
      threads << Thread.new { puts i }
    end
    
    threads.each(&:join)
    
    0 讨论(0)
  • 2021-02-20 13:32

    There's also a gem called Parallel which is similar to Peach, but is actively updated.

    0 讨论(0)
  • 2021-02-20 13:35

    There is a gem called peach (https://rubygems.org/gems/peach) which lets you do this:

    require "peach"
    
    array_of_urls_to_process.peach do |url|
      do_something(get_doc(url))
    end
    
    0 讨论(0)
提交回复
热议问题