Setting millisecond-timeouts with curl

I'm currently working on a project where I need to curl to an external server to get some information. If this takes too long, I fall back to a local solution. The timeout for this should be really, really low, so we decided on a 250ms timeout. While testing with this timeout feature, for some reason it *always* used the local fallback. I couldn't figure out why, as when I did a manual curl to the external server, it took 50ms at maximum, way below the timeout value. Turns out it is a problem with libcurl.

So how did I found out about this? Thanks to Steve Kamerman, who took the time to comment to the PHP documentation. It turns out this issue is caused by the way libcurl behaves on linux and unix systems, where a SIGALRM is raised during the name resolution that is being caught by libcurl as a timeout alarm. Because of this, the request times out immediately instead of after the actual timeout.

The solution is to tell curl to ignore signals alltogether. This is not a perfect solution of course, because you're now suppressing something that can be useful in other situations, but in this case we decided the timeouts to be too important for the software to not use timeouts. So now it looks like this:

$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl, CURLOPT_TIMEOUT_MS, 250);
curl_setopt($curl, CURLOPT_NOSIGNAL, 1);

It now works like a charm!


Add comment

Comments

gravatar Free Fax Broadcasting Services: -childs examination fees and so on. sending faxes is just as easy. before getting your hands on the no fax payday loans you have to follow the probable prerequisites. mso-bidi-font-family:arial;color:#333333"> plus, by using online fax you can save a lot of money, can you really ask for more than that?
March 9, 2013
gravatar Business Directory: I find your content useful, thank you
March 15, 2013
gravatar Small Business Directory: I will be back to read more of your posts again
March 15, 2013
gravatar Business Directory: every day I take the time to see the article with useful content
March 15, 2013
gravatar Business Listings: articles are more highly affected content, I like the way you write
March 15, 2013
gravatar Small Business Listings: I often interested in the content useful to their work
March 15, 2013
gravatar Small Business Directory: I was glad I did not miss out on your web page
March 15, 2013
gravatar Business Directory: sometimes see something interesting, such as watching your posts
March 15, 2013
gravatar Small Business Directory:
with more content and highly supported authentication, we need such information.
March 15, 2013
gravatar Business Directory: I like your content articles, it is very special.
March 15, 2013
gravatar Business Listings: I always think about what I read and I like your post
March 15, 2013
gravatar www.automatenspiele7.com: Thousands of candles can be lighted from a single candle, and the life of the candle will not be shortened. Happiness never decreases by being shared.
March 29, 2013
gravatar casino online: with more content and highly supported authentication, we need such information.
April 18, 2013
gravatar Stegplatten: I was very pleased to find this site. I wanted to thank you for this great read!! I definitely enjoying every little bit of it and I have you bookmarked to check out new stuff you post.
April 22, 2013
gravatar mesothelioma lawyer illinois: I wish to know more about this because it actually catches my attention. Keep on posting valuable information about this dude! Thank you so much for sharing.
May 9, 2013
gravatar unitedfinances.com: focus of my time and enjoy reading these articles useful for your work.
May 16, 2013
gravatar garden fertilizer: to stimulate root formation and growth and improve the ability to resist diseases. cheap grow big liquid concentrate fertilizer size we use granular and liquid organic fertilizer.
May 17, 2013
gravatar National Tax Asset Fund: I was very pleased to find this site. I wanted to thank you for this great read!! I definitely enjoying every little bit of it and I have you bookmarked to check out new stuff you post.
May 20, 2013
gravatar digital recorder pouch: sport, then finding out information as. usb flashdrive/voice recorder d1400 who would ever know that is flash drive is a voice recorder ready to record whatever you need to. the sony icd-sx712 digital voice recorder has a speaker microphone and is a digital voice recorder, and it is a pretty cheap deal. yet another voice recorder question: i suddenly have potential access to a reasonable grant (theoretical max.
May 22, 2013
gravatar fast loans: Your post is really useful. Thanks for sharing with us.
June 3, 2013
gravatar Matt Considine: I would like to with thanks for the efforts you have made in writing this post. I am hoping the same most effective work from you in the future as well.
June 8, 2013

Php5_zce_logo

Tags

1337 2008 2010 2011 4developers access modifiers accessibility AdaLovelaceDay09 advent agavi agile alfred amsterdam amsterdamphp apache api apple article articles atk atkMetaNode audioscrobbler autoloading automation azure backwards compatibility barcelona barcodes bash bbc bbq beatstad belgium best practices bittorrent blogging blogs boards of canada book books bughuntday bundle caching cake cal evans calendar career cat cerf certificate cfp cilex clear cms cologne common sense communities community components composer conference conferences contest continuous integration contribute contribution crisis css curl custom d-day data migration datetime DbFinderPlugin decorator decorators deployment deps devdays development directoryindex directoryiterator docblox doctrine doctrine2 documentation download dpc dpc09 dpc10 dpc11 DPC2008 dreamhost drupal dv7 eclipse ed editors efficiency enterprise errors event events expertise ezcomponents facebook filter-branch filteriterator finland flickr fork framework frameworks free ticket freelance freeze frontend fun game games geoip germany getting real git github globiterator gnome-do google google calendar googletalk graceful degradation hack hackers hidden gem hiphop howto hp HR html http i386 ibuildings icann ide ideasofmarch idm imovie inclusivity indy ingewikkeld integration international php conference internet interview ipad IPC ipc ipc08 ipc10 ipc11se iterators iterm2 javascript jenkins jenkins-php job job openings jobeet john peel joomla joomladays kiva kubuntu launcher launchy left on the web libcurl libraries library lighttpd lime linktuesday linux live london loudblog m2ts mac magazines malware mambo manchester marjolein mediterra meeting meme meta methodology micro-financing microframework microsoft migration movie music mysql namespace namespaces netbeans netherlands newsfire nllgg northeastphp nos odmarco open source opinion ORM osx paradiso paris partnership pavilion pear pecl performance personal pfc10 pfc11 pfcongres pfcongrez pfz pfz.nl photo php PHP php5.3 phpabstract phpazure phpBB phpbb phpbelgium phpbenelux phpbnl10 phpday phpdoc phpdocumentor phpgg phpitalia phpnw phpnw08 phpnw11 phpnw12 phpstorm phptek phptek09 phpuk2009 phpUnderControl phpunit php|architect php|tek podcast politics portability postcrossing presentation presentations private projects protected prototype PSR-0 public python qa qr codes re2c recruiting refactoring review rewrite ruby on rails san francisco schedule scifi script security sensio seven things sexism sfdaycgn sflive2011 shell scripting silex simplexml slides smfony software sogeti solar sound speakers spl ssh standard standards star trek static steer strings stylesheets subversion symfony symfony live symfony2 Symfony2 symfonycamp symfonyday symfonylive symfonyUnderControlPlugin talk talks tech techademy technology techportal tek09 telecommuting terratec terrorism testfest testing textmate textpattern the right tool timeout tips tld todo tomas tools training twig uncon unet usability usergroup validation vhost video vim vinyl virus warp webinar weblogging webservices wiki windows winphp women wordpress work workshop world world of warcraft wpi writing wunderlist xml xpath xsd yara year youtube zc11 ZCE zemanta zend zend framework zend server zend studio zendcon Zend_Form zite
© 2004 - 2013 Stefan Koopmanschap + Powered by Symfony, photos powered by Flickr, links powered by Delicious, Shanghai smilies by Iconbuffet. Feeds: rss / atom. Left on the Web v4.4.0.1