<div dir="ltr"><div class="gmail_default" style="color:#336666">Also (I am fuzzy on the details for this), Bitcoind will detect when a node is misbehaving and (I believe) it will blacklist misbehaving nodes for a period of time so it doesn&#39;t continually keep trying to connect to tarpit nodes, for example.</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Mar 4, 2015 at 6:13 PM, Kevin Greene <span dir="ltr">&lt;<a href="mailto:kgreenek@gmail.com" target="_blank">kgreenek@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 dir="ltr"><div class="gmail_default" style="color:rgb(51,102,102)">Bitcoind protects against this by storing the addresses it has learned about in buckets. The bucket an address is stored in is chosen based on the IP of the peer that advertised the addr message, and the address in the addr message itself. The idea is that the bucketing is done in a randomized way so that no attacker should be able to fill your database with his or her own nodes.</div><div class="gmail_default" style="color:rgb(51,102,102)"><br></div><div class="gmail_default" style="color:rgb(51,102,102)">From <a href="https://github.com/bitcoin/bitcoin/blob/master/src/addrman.h" target="_blank">addrman.h</a>:</div><div class="gmail_default" style="color:rgb(51,102,102)"><br></div><div class="gmail_default" style="color:rgb(51,102,102)"><div class="gmail_default">/** Stochastic address manager</div><div class="gmail_default"> *</div><div class="gmail_default"> * Design goals:</div><div class="gmail_default"> *  * Keep the address tables in-memory, and asynchronously dump the entire to able in peers.dat.</div><div class="gmail_default"> *  * Make sure no (localized) attacker can fill the entire table with his nodes/addresses.</div><div class="gmail_default"> *</div><div class="gmail_default"> * To that end:</div><div class="gmail_default"> *  * Addresses are organized into buckets.</div><div class="gmail_default"> *    * Address that have not yet been tried go into 256 &quot;new&quot; buckets.</div><div class="gmail_default"> *      * Based on the address range (/16 for IPv4) of source of the information, 32 buckets are selected at random</div><div class="gmail_default"> *      * The actual bucket is chosen from one of these, based on the range the address itself is located.</div><div class="gmail_default"> *      * One single address can occur in up to 4 different buckets, to increase selection chances for addresses that</div><div class="gmail_default"> *        are seen frequently. The chance for increasing this multiplicity decreases exponentially.</div><div class="gmail_default"> *      * When adding a new address to a full bucket, a randomly chosen entry (with a bias favoring less recently seen</div><div class="gmail_default"> *        ones) is removed from it first.</div><div class="gmail_default"> *    * Addresses of nodes that are known to be accessible go into 64 &quot;tried&quot; buckets.</div><div class="gmail_default"> *      * Each address range selects at random 4 of these buckets.</div><div class="gmail_default"> *      * The actual bucket is chosen from one of these, based on the full address.</div><div class="gmail_default"> *      * When adding a new good address to a full bucket, a randomly chosen entry (with a bias favoring less recently</div><div class="gmail_default"> *        tried ones) is evicted from it, back to the &quot;new&quot; buckets.</div><div class="gmail_default"> *    * Bucket selection is based on cryptographic hashing, using a randomly-generated 256-bit key, which should not</div><div class="gmail_default"> *      be observable by adversaries.</div><div class="gmail_default"> *    * Several indexes are kept for high performance. Defining DEBUG_ADDRMAN will introduce frequent (and expensive)</div><div class="gmail_default"> *      consistency checks for the entire data structure.</div><div class="gmail_default"> */</div></div></div><div class="gmail_extra"><br><div class="gmail_quote"><span class="">On Wed, Mar 4, 2015 at 5:40 PM, Thy Shizzle <span dir="ltr">&lt;<a href="mailto:thashiznets@yahoo.com.au" target="_blank">thashiznets@yahoo.com.au</a>&gt;</span> wrote:<br></span><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class=""><div><div style="color:#000;background-color:#fff;font-family:Helvetica Neue-Light,Helvetica Neue Light,Helvetica Neue,Helvetica,Arial,Lucida Grande,Sans-Serif;font-size:16px"><div dir="ltr">  Hi, so just a thought as my node relays addresses etc. If I wanted to really slow down communication over the P2P network, what&#39;s stopping me from popping up a heap of dummy nodes that do nothing more than exchange version and relay addresses, except I send addr messages with all 1000 addresses pointing to my useless nodes that never send invs or respond to getdata etc so clients connect to my dumb nodes instead of legit ones. I&#39;m thinking that if I fill up their address pool with enough addresses to dumb nodes and keep them really fresh time wise, it could have a bit of an impact especially if all 8 outbound connections are used up by my dumb nodes right?<br><br>I don&#39;t want to do this obviously, I&#39;m just thinking about it as I&#39;m building my node, what is there to stop this happening?</div></div></div><br></span>------------------------------------------------------------------------------<br>
Dive into the World of Parallel Programming The Go Parallel Website, sponsored<br>
by Intel and developed in partnership with Slashdot Media, is your hub for all<br>
things parallel software development, from weekly thought leadership blogs to<br>
news, videos, case studies, tutorials and more. Take a look and join the<br>
conversation now. <a href="http://goparallel.sourceforge.net/" target="_blank">http://goparallel.sourceforge.net/</a><br>_______________________________________________<br>
Bitcoin-development mailing list<br>
<a href="mailto:Bitcoin-development@lists.sourceforge.net" target="_blank">Bitcoin-development@lists.sourceforge.net</a><br>
<a href="https://lists.sourceforge.net/lists/listinfo/bitcoin-development" target="_blank">https://lists.sourceforge.net/lists/listinfo/bitcoin-development</a><br>
<br></blockquote></div><br></div>
</blockquote></div><br></div>