<div dir="ltr">Steve:<div>Several reasons.</div><div>One is the mod_ha_cluster is an N+1 Cluster, not a active/passive pair. That way if any single node fails, there&#39;s something to pick up the slack.</div><div><br></div>

<div>Secondly, in order to recover live calls, you need a list of the calls. That currently requires some sort of odbc (or postgres) with replication. Again, that&#39;s abstracted as part of mod_ha_cluster.</div><div><br>

</div><div>Third: The docs mention a similar of pooling for registration, that you can register to one server and you&#39;re regged on them all without needing a DB to sync everything.</div><div><br></div><div>Fourth, according to the docs: single configuration for all FS instances, rather than manually ensuring each one has the same config.</div>

<div><br></div><div>Fifth: Voicemail clustering? Or we&#39;ll have to wait for mod_voicemail&#39;s APIs to be rewritten for that, perhaps...</div><div><br></div><div>There&#39;s certainly <i>something </i>special possible with mod_ha_cluster that can&#39;t be done with existing solutions cleanly, if at all...</div>

<div><br></div><div><span style="font-family:Verdana,Arial,Helvetica,sans-serif">-Avi</span></div><div><br><div class="gmail_quote">On Sun, Feb 10, 2013 at 10:16 PM, Steven Ayre <span dir="ltr">&lt;<a href="mailto:steveayre@gmail.com" target="_blank">steveayre@gmail.com</a>&gt;</span> wrote:<br>

<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Fair enough.<div><br></div><div>I still don&#39;t see the need to reinvent the wheel just to avoid depending on a 3rd party well developed and extensively tested piece of software. Corosync provides an API that can be used for passing messages between nodes in a cluster.</div>



<div><div><div><br></div><div>-Steve</div><div><div class="h5"><div><br></div><div><br><br><div class="gmail_quote">On 10 February 2013 18:14, Eliot Gable <span dir="ltr">&lt;<a href="mailto:egable+freeswitch@gmail.com" target="_blank">egable+freeswitch@gmail.com</a>&gt;</span> wrote:<br>



<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div>On Sun, Feb 10, 2013 at 12:08 PM, Steven Ayre &lt;<a href="mailto:steveayre@gmail.com" target="_blank">steveayre@gmail.com</a>&gt; wrote:<br>




&gt; That covers redundancy in case of a network card or cable failure, but isn&#39;t<br>
&gt; what partitioning is about. Multiple NICs cannot prevent partitioning.<br>
&gt;<br>
&gt; As an example, partitioning might happen when a network switch between two<br>
&gt; network segments fails so you have nodes A+B in segment 1 able to talk to<br>
&gt; each other but unable to talk to nodes C+D in segment 2, while C+D can talk<br>
&gt; to each other but not A+B.<br>
&gt;<br>
&gt; Pacemaker/corosync contain a lot of algorithms to fence off partitions<br>
&gt; without quorum and can resort to things like STONITH if required to force a<br>
&gt; node to shutdown rather than risk it causing disruption to the cluster (for<br>
&gt; example if it tries to take over traffic to a virtual IP you could end up in<br>
&gt; a case where you have two servers sending ARP responses for the same IP).<br>
&gt;<br>
<br>
</div>Steve,<br>
<br>
As Avi pointed out, I mentioned having multiple physical networks as a<br>
guard against a network split / partition. If one network is split<br>
such that A and B can talk to each other over it and C and D can talk<br>
to each other over it, you would indeed have an issue if you only had<br>
one network. However, with two or more networks, all four nodes will<br>
still be able to talk to each other over the other network(s).<br>
<br>
Now, granted, if you have a network split in all networks, then you<br>
are still screwed. Pacemaker and other solutions deal with this, as<br>
you mentioned, using something called &quot;quorum&quot; where you need a<br>
majority of nodes to be able to see each other, and they fence the<br>
remaining nodes. As I documented on my wiki page for the module, I do<br>
have plans to eventually support such functionality. However, that is<br>
a bit further down the road as it will take some time to develop<br>
STONITH interfaces to various hardware or even to reuse the STONITH<br>
modules from Pacemaker or another project. In any case, I feel it is<br>
more important to get the base functionality developed and debugged as<br>
utilizing multiple networks is a good way to prevent network splits<br>
from being an issue.<br>
<br>
That being said, there are other issues to contend with when<br>
discussing network splits. For example, if A and B can see the<br>
Internet but C and D cannot, but C is a Master and B is a slave, you<br>
still have an issue to address. In this case, mod_ha_cluster must be<br>
able to determine that C and D cannot see the Internet. They need to<br>
perform very fast pings to some IP address, or have some external host<br>
sending them data in some way that they can detect when traffic<br>
to/from the Internet has stopped. I can place a media bug on the audio<br>
streams to make this determination fairly accurately. I can also rely<br>
on a ping mechanism to make the determination. Once the determination<br>
is made, mod_ha_cluster then has to promote B to a master to take over<br>
C.<br>
<br>
So, there are certainly still other issues to address when a network<br>
split occurs, but split-brain is easily avoided by simply adding<br>
redundant networks.<br>
<div><div><br>
_________________________________________________________________________<br>
Professional FreeSWITCH Consulting Services:<br>
<a href="mailto:consulting@freeswitch.org" target="_blank">consulting@freeswitch.org</a><br>
<a href="http://www.freeswitchsolutions.com/" target="_blank">http://www.freeswitchsolutions.com</a><br>
<br>
FreeSWITCH-powered IP PBX: The CudaTel Communication Server<br>
<a href="http://www.cudatel.com/" target="_blank">http://www.cudatel.com</a><br>
<br>
Official FreeSWITCH Sites<br>
<a href="http://www.freeswitch.org/" target="_blank">http://www.freeswitch.org</a><br>
<a href="http://wiki.freeswitch.org/" target="_blank">http://wiki.freeswitch.org</a><br>
<a href="http://www.cluecon.com/" target="_blank">http://www.cluecon.com</a><br>
<br>
FreeSWITCH-users mailing list<br>
<a href="mailto:FreeSWITCH-users@lists.freeswitch.org" target="_blank">FreeSWITCH-users@lists.freeswitch.org</a><br>
<a href="http://lists.freeswitch.org/mailman/listinfo/freeswitch-users" target="_blank">http://lists.freeswitch.org/mailman/listinfo/freeswitch-users</a><br>
UNSUBSCRIBE:<a href="http://lists.freeswitch.org/mailman/options/freeswitch-users" target="_blank">http://lists.freeswitch.org/mailman/options/freeswitch-users</a><br>
<a href="http://www.freeswitch.org/" target="_blank">http://www.freeswitch.org</a><br>
</div></div></blockquote></div><br></div></div></div></div></div>
<br>_________________________________________________________________________<br>
Professional FreeSWITCH Consulting Services:<br>
<a href="mailto:consulting@freeswitch.org">consulting@freeswitch.org</a><br>
<a href="http://www.freeswitchsolutions.com/" target="_blank">http://www.freeswitchsolutions.com</a><br>
<br>
FreeSWITCH-powered IP PBX: The CudaTel Communication Server<br>
<a href="http://www.cudatel.com/" target="_blank">http://www.cudatel.com</a><br>
<br>
Official FreeSWITCH Sites<br>
<a href="http://www.freeswitch.org/" target="_blank">http://www.freeswitch.org</a><br>
<a href="http://wiki.freeswitch.org/" target="_blank">http://wiki.freeswitch.org</a><br>
<a href="http://www.cluecon.com/" target="_blank">http://www.cluecon.com</a><br>
<br>
FreeSWITCH-users mailing list<br>
<a href="mailto:FreeSWITCH-users@lists.freeswitch.org">FreeSWITCH-users@lists.freeswitch.org</a><br>
<a href="http://lists.freeswitch.org/mailman/listinfo/freeswitch-users" target="_blank">http://lists.freeswitch.org/mailman/listinfo/freeswitch-users</a><br>
UNSUBSCRIBE:<a href="http://lists.freeswitch.org/mailman/options/freeswitch-users" target="_blank">http://lists.freeswitch.org/mailman/options/freeswitch-users</a><br>
<a href="http://www.freeswitch.org/" target="_blank">http://www.freeswitch.org</a><br>
<br></blockquote></div><br></div></div>