I have a Sinatra app that basically takes some input values and then finds data matching those values from external services like Flickr, Twitter, etc.
For example:
input:”Chattanooga Choo Choo”
Would go out and find images at Flickr on the Chattanooga Choo Choo and tweets from Twitter, etc.
Right now I have something like:
@images = Flickr::...find...images..
@tweets = Twitter::...find...tweets...
@results << @images
@results << @tweets
So my question is, is there an efficient way in Ruby to run those requests concurrently? Instead of waiting for the images to finish before the tweets finish.
Threads would work, but it’s a crude tool. You could try something like this:
You’d have to tinker a bit with the code though, and add proper error detection. I can’t remember right now if instance variables work when declared inside the thread block, local variables wouldn’t unless they were explicitly declared outside.
I wouldn’t call this an elegant solution, but I think it works, and it’s not too complex. In this case there is luckily no need for locking or synchronizations apart from the joins, so the code reads quite well.
Perhaps a tool like EventMachine (in particular the em-http-request subproject) might help you, if you do a lot of things like this. It could probably make it easier to code at a higher level. Threads are hard to get right.