Bug #10747
closedDNS resolution should fall back to TCP on Errno::EACCES
Description
On some platforms, users may be restricted from global binding to a UDP port, which is necessary for UDP-based DNS lookups. In this case, an exception like the following is currently raised:
ruby -r resolv -e 'puts Resolv.getaddress "www.ruby-lang.org"'
resolv.rb:655:inbind': Permission denied - bind(2) (Errno::EACCES) resolv.rb:655:inbind_random_port'
resolv.rb:791:ininitialize' resolv.rb:560:innew'
resolv.rb:560:inmake_udp_requester' resolv.rb:513:ineach_resource'
resolv.rb:406:ineach_address' resolv.rb:115:inblock in each_address'
resolv.rb:114:ineach' resolv.rb:114:ineach_address'
resolv.rb:92:ingetaddress' resolv.rb:43:ingetaddress'
This error should be caught, and the resolver should fall back to TCP, as it does in other cases where this is necessary. A possible patch for this (written against 2.0.0p353 in RHEL) is attached.
Ideally, it would also be nice to be able to specify tcp by default when initializing a DNS object on such platforms, to avoid repeated bind attempts which are known to fail, but I am not sure of the best way to introduce such an option.
Files
        
           Updated by jeremyevans0 (Jeremy Evans) over 6 years ago
          Updated by jeremyevans0 (Jeremy Evans) over 6 years ago
          
          
        
        
      
      - File resolv-tcp-fallback-eacces.patch resolv-tcp-fallback-eacces.patch added
- Status changed from Open to Assigned
- Assignee set to akr (Akira Tanaka)
I'm not sure I would consider this a bug, but it seems like a reasonable change. Attached is an updated patch that applies against master.
        
           Updated by jeremyevans (Jeremy Evans) about 6 years ago
          Updated by jeremyevans (Jeremy Evans) about 6 years ago
          
          
        
        
      
      - Status changed from Assigned to Closed
Applied in changeset git|f37cc1c719f12d2cad6032aa4e6f4236f0604992.
Fallback to TCP in resolv if UDP bind raises EACCES
Original patch from Andy Grimm.
Fixes [Bug #10747]