<div dir="ltr">Wow! I am glad to know I am wrong because this opens up opportunities to do distributed programming on my Macbook :)<div>Since I am very new to this, do you mind sharing any resources, links that I can read to learn about "How to do" them?</div><div><br></div><div>Thanks a lot Christopher</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Sat, Jan 17, 2015 at 11:46 AM, Christopher Meiklejohn <span dir="ltr"><<a href="mailto:cmeiklejohn@basho.com" target="_blank">cmeiklejohn@basho.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word"><span class=""><br><div><blockquote type="cite"><div>On Jan 17, 2015, at 8:23 PM, Harit Himanshu <<a href="mailto:harit.subscriptions@gmail.com" target="_blank">harit.subscriptions@gmail.com</a>> wrote:</div><br><div><div dir="ltr"><br><div class="gmail_extra">This is really dumb question and I am pretty sure that there is limit to how much distributed programming could be learnt using single machine(I am using Mac in this case).<br><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div><br></div><div>I am reading through Programming Erlang, Chapter 14, Distributed Programming where Joe talk about how to run Name Server in distributed mode as </div><div><br></div><div><div><ol><li> I write and test my program in a regular nondistributed Erlang session. This is what we’ve been doing up to now, so it presents no new challenges.</li><li> I test my program on two different Erlang nodes running on the same computer.</li><li> I test my program on two different Erlang nodes running on two physically separated computers either in the same local area network or anywhere on the Internet.</li></ol></div></div></div></blockquote></div></div></div></div></blockquote></div></span><div>You can get pretty far using all of the networking tools provided with your operating system to simulate various network conditions.  I do all of my daily distributed programming and research using a stock MacBook.</div><br><div>Consider Kyle Kingsbury’s work on Jepsen where he’s able to find bug in several major distributed databases.  There are also tools such as ‘tc’ which can be used to add arbitrary latency between processes.</div><div><br></div><div>For what it’s worth, Basho does a significant amount of fault testing on a single machine by using fault-injection tools, or by facilities like ‘intercepts’ provided by Riak Test.</div><div><br></div><div>My advice is this: do everything locally on your machine until you have a reason to move to separate infrastructure; it will be easier to develop and debug.</div><div><br></div><div>- Chris</div><span class="HOEnZb"><font color="#888888"><div><br></div><div><div><div>Christopher Meiklejohn</div><div>Senior Software Engineer</div><div>Basho Technologies, Inc.</div><div><a href="mailto:cmeiklejohn@basho.com" target="_blank">cmeiklejohn@basho.com</a></div><br></div></div><div><br></div></font></span></div></blockquote></div><br></div>