From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on dcvr.yhbt.net X-Spam-Level: X-Spam-ASN: AS4713 221.184.0.0/13 X-Spam-Status: No, score=-3.1 required=3.0 tests=BAYES_00,DKIM_ADSP_CUSTOM_MED, FORGED_GMAIL_RCVD,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,RCVD_IN_DNSWL_MED, SPF_PASS,WEIRD_PORT shortcircuit=no autolearn=ham autolearn_force=no version=3.4.2 Received: from neon.ruby-lang.org (neon.ruby-lang.org [221.186.184.75]) by dcvr.yhbt.net (Postfix) with ESMTP id 39C9A20248 for ; Thu, 28 Feb 2019 12:11:46 +0000 (UTC) Received: from neon.ruby-lang.org (localhost [IPv6:::1]) by neon.ruby-lang.org (Postfix) with ESMTP id 64E01121416; Thu, 28 Feb 2019 21:11:42 +0900 (JST) Received: from o1678948x4.outbound-mail.sendgrid.net (o1678948x4.outbound-mail.sendgrid.net [167.89.48.4]) by neon.ruby-lang.org (Postfix) with ESMTPS id 685D4121240 for ; Thu, 28 Feb 2019 21:11:39 +0900 (JST) Received: by filter0056p3las1.sendgrid.net with SMTP id filter0056p3las1-25637-5C77CFF5-29 2019-02-28 12:11:34.066092426 +0000 UTC m=+366879.242829992 Received: from herokuapp.com (ec2-35-153-142-167.compute-1.amazonaws.com [35.153.142.167]) by ismtpd0004p1iad1.sendgrid.net (SG) with ESMTP id q7g3K3lBQ5uXVFUVie8TRQ for ; Thu, 28 Feb 2019 12:11:33.952 +0000 (UTC) Date: Thu, 28 Feb 2019 12:11:34 +0000 (UTC) From: aditya.prakash132@gmail.com To: ruby-core@ruby-lang.org Message-ID: References: Mime-Version: 1.0 X-Redmine-MailingListIntegration-Message-Ids: 67092 X-Redmine-Project: ruby-trunk X-Redmine-Issue-Id: 15628 X-Redmine-Issue-Author: sonalkr132 X-Redmine-Sender: sonalkr132 X-Mailer: Redmine X-Redmine-Host: bugs.ruby-lang.org X-Redmine-Site: Ruby Issue Tracking System X-Auto-Response-Suppress: All Auto-Submitted: auto-generated X-SG-EID: ync6xU2WACa70kv/Ymy4QrNMhiuLXJG8OTL2vJD1yS5opby0jqiKFro1vU+mEnZE9KMYaD6RCC+BYI elJpJz0QBW75S3/IBto34A5WWs+TLpt3D/tfp4RcxX+L2/DIAsqKSa9em2CN86+1XUvBNet+/ZW7fg YNYD+VixJvQohRWU+3hcxQGQJ6AMYv4wmGPR8YNeslICWjWTRg7r4tu3Ag== X-ML-Name: ruby-core X-Mail-Count: 91642 Subject: [ruby-core:91642] [Ruby trunk Feature#15628] init_inetsock_internal should fallback to IPv4 if IPv6 is unreachable X-BeenThere: ruby-core@ruby-lang.org X-Mailman-Version: 2.1.15 Precedence: list Reply-To: Ruby developers List-Id: Ruby developers List-Unsubscribe: , List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Errors-To: ruby-core-bounces@ruby-lang.org Sender: "ruby-core" Issue #15628 has been updated by sonalkr132 (Aditya Prakash). Related: [rubygems/rubygems#2662](https://github.com/rubygems/rubygems/pull/2662) ---------------------------------------- Feature #15628: init_inetsock_internal should fallback to IPv4 if IPv6 is unreachable https://bugs.ruby-lang.org/issues/15628#change-76906 * Author: sonalkr132 (Aditya Prakash) * Status: Open * Priority: Normal * Assignee: * Target version: ---------------------------------------- Hi, This is not really bug but more of a missing feature. Let me layout steps to reproduce what I am trying to achieve: * Add local entries for `example.com` ``` $ echo "::1 example.com www.example.com 127.0.0.1 example.com www.example.com" | sudo tee --append /etc/hosts ``` * Add rule to `DROP` ipv6 packets: `sudo ip6tables -P INPUT DROP` * Start a server: `ruby -rwebrick -e 'WEBrick::HTTPServer.new(Port: 8000).start'` * Making request using Net:HTTP with timeout (`Net::OpenTimeout`) after after 60 seconds: `ruby -rnet/http -e "Net::HTTP.get(URI('http://example.com:8000'))"` As far as I understand, [init_inetsock_internal](https://github.com/ruby/ruby/blob/4444025d16ae1a586eee6a0ac9bdd09e33833f3c/ext/socket/ipsocket.c#L42) needs to fallback to ipv4 for Net::HTTP.get to work. IPv6 route being broke is expected and hence, [RFC8305](https://tools.ietf.org/html/rfc8305) recommends fallback to IPv4. Support for IPv6 fallback is spotty across languages and http clients, for example, [golang supports it](https://github.com/golang/go/blob/master/src/net/dial.go#L47) but python doesn't, making request with `curl` works but `wget` hangs. -- https://bugs.ruby-lang.org/