You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@cassandra.apache.org by "ASF GitHub Bot (JIRA)" <ji...@apache.org> on 2016/11/10 15:42:58 UTC

[jira] [Commented] (CASSANDRA-12673) Nodes cannot see each other in multi-DC, non-EC2 environment with two-interface nodes due to outbound node-to-node connection binding to private interface

    [ https://issues.apache.org/jira/browse/CASSANDRA-12673?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15654368#comment-15654368 ] 

ASF GitHub Bot commented on CASSANDRA-12673:
--------------------------------------------

GitHub user mmajercik opened a pull request:

    https://github.com/apache/cassandra/pull/84

    removed local bind for outbound connections

    Fix for CASSANDRA-12673

You can merge this pull request into a Git repository by running:

    $ git pull https://github.com/mmajercik/cassandra 12673-2.2

Alternatively you can review and apply these changes as the patch at:

    https://github.com/apache/cassandra/pull/84.patch

To close this pull request, make a commit to your master/trunk branch
with (at least) the following in the commit message:

    This closes #84
    
----
commit a3058bce8e8eff7f44205712d93c15eda1548a0b
Author: mmajercik <mm...@specter.firstmobileaffiliate.com>
Date:   2016-11-10T15:31:03Z

    removed local bind for outbound connections

----


> Nodes cannot see each other in multi-DC, non-EC2 environment with two-interface nodes due to outbound node-to-node connection binding to private interface
> ----------------------------------------------------------------------------------------------------------------------------------------------------------
>
>                 Key: CASSANDRA-12673
>                 URL: https://issues.apache.org/jira/browse/CASSANDRA-12673
>             Project: Cassandra
>          Issue Type: Improvement
>          Components: Core
>         Environment: Multi-DC, non-EC2 environment with two-interface nodes
>            Reporter: Milan Majercik
>            Priority: Minor
>             Fix For: 2.2.x
>
>
> We have a two-DC cluster in non-EC2 environment with each node containing two interfaces, one using private addresses for intra-DC communication and the other using public addresses for inter-DC communication. After proper configuration setup needed for this kind of environment we observed nodes cannot see each other.
> The configuration changes made for this purpose are as follows:
> *listen_address*: bound to private interface
> *broadcast_address*: bound to public address
> *listen_on_broadcast_address*: true
> *endpoint_snitch*: GossipingPropertyFileSnitch
> *prefer_local*=true (in cassandra-rackdc.properties)
> Upon restart, cassandra node contacts other nodes with their public addresses which is essential for making contacts to foreign data centers. After exhaustive investigation we found cassandra binds outbound node-to-node connections to private interface (the one specified in listen_address) that poses a problem for our environment as these data centers _do not allow connections from private interface to public network_.
> A portion of cassandra code responsible for local binding of outbound connections can be found in method {{org.apache.cassandra.net.OutboundTcpConnectionPool.newSocket}}:
> {code}
>             if (!Config.getOutboundBindAny())
>                 channel.bind(new InetSocketAddress(FBUtilities.getLocalAddress(), 0));
> {code}
> After we commented out these two lines and deployed cassandra.jar across the cluster, the nodes were able to see each other and everything appears to be working fine, including two-DC setup.
> Do you think it's possible to remove these two lines without negative consequences? Alternatively, if the local binding serves some specific purpose of which I'm ignorant would it be possible to make it configurable?



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)