<div dir="ltr"><div class="gmail_quote">Hi.<br><br>What about using Wackamole and server side AFR?<br><br>Wackamole (<a href="http://www.backhand.org/wackamole/" target="_blank">http://www.backhand.org/wackamole/</a>) allows to set a P2P kind of fault tolerance, where remaining server would take the IP of the crashed one. Then the client could continue working with the remaining server.<br>
<br>What do you think about this?<br><br>Also, can someone provide more info about server side - I remember I only seen some config examples, but never any info how it actually works.<br><br>Regards.<br><br><br><div class="gmail_quote">
2008/12/8 Keith Freedman <span dir="ltr"><<a href="mailto:freedman@freeformit.com" target="_blank">freedman@freeformit.com</a>></span><div><div></div><div class="Wj3C7c"><br><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
<div>At 06:17 AM 12/8/2008, Daniel Maher wrote:<br>
<blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
Stas Oskin wrote:<br>
<br>
> Based on my limited knowledge of GlusterFS, the most reliable and<br>
> recommended way (in wiki) is client-side AFR, where the clients aware of<br>
> the servers status, and replicate the files accordingly.<br>
<br>
I've reviewed the AFR-related sections of the documentation on the wiki...<br>
<a href="http://www.gluster.org/docs/index.php/GlusterFS_Translators_v1.3#Automatic_File_Replication_Translator_.28AFR.29" target="_blank">http://www.gluster.org/docs/index.php/GlusterFS_Translators_v1.3#Automatic_File_Replication_Translator_.28AFR.29</a><br>
<a href="http://www.gluster.org/docs/index.php/Understanding_AFR_Translator" target="_blank">http://www.gluster.org/docs/index.php/Understanding_AFR_Translator</a><br>
<br>
Nowhere in those sections is it stated, either directly or implicitly,<br>
that client-side AFR is more reliable than server-side AFR. I'm not<br>
saying that the statement is incorrect, but rather that the<br>
documentation noted above doesn't seem to suggest that this is the case.<br>
</blockquote>
<br></div>
the issue isn't reliability, it's availability.<br>
<br>
if a client only talks to one server and that server goes down then the client has nothing to 'fail over' to. however, if the client talks to both servers then if one goes down it'll keep talking to the other one.<br>
<br>
There are costs and benefits to each approach.<br>
server side AFR is handy to insure that the filesystems are in sync, so no matter which server a client connects to, it'll have the correct data.<br>
with client side AFR you lend yourself to more configuration problems.<br>
For example.<br>
if client 1 only knows about server 1, it will update files happily and no AFR takes place<br>
if client 2 is doing client side AFR between server 1 and server 2, then it keeps both servers in sync, and occasionally when it accesses a file that client 1 updated on server 1, then client 2 takes the responsibility of replicating that file to server 2.<br>
<br>
I really think a better approach would be to always have server side AFR, and then when a gluster client connects to a server, it's given the AFR config, so that it has a 'failover pool' that it can use in case it's connection to it's primary server gets interrupted.<br>
<br>
Hopefully this will make it into a future version of gluster, because I think it will really simplify administration and increase availability.<br>
There could be an option to make the client responsible for the replication, but the control and config should be centralized at the server, to eliminate cases where some clients are replicating to certain servers and not others.<br>
<br>
my .02 <br>
</blockquote></div></div></div></div></div>