I’m writing a rake task that would be called every minute (possibly every 30 seconds in the future) by Whenever, and it contacts a polling API endpoint (per user in our database). Obviously, this is not efficient run as a single thread, but is it possible to multithread? If not, is there a good event-based HTTP library that would be able to get the job done?
Share
Beware of Rails startup times, it might be better to use a forking model such as Resque or Sidekiq, Rescue provides https://github.com/bvandenbos/resque-scheduler which should be able to do what you need, I can’t speak about Sidekiq, but I’m sure it has something similar available (Sidekiq is much newer than Resque)
I’d suggest you look at ActiveRecord’s
find_eachfor tips on making your finder process more efficient, once you have your batches you can easily do something using threads such as:This will start no more than
batch_sizeof threads, waiting after eachbatch_sizeto finish.It would be possible to do something like this, but then you will have an uncontrollable number of threads, there’s an alternative you might benefit from here, it gets a lot more complicated including a ThreadPool, and shared list of work to do, I’ve posted it as at Github so’as not to spam stackoverflow: https://gist.github.com/6767fbad1f0a66fa90ac