Kademlia - Kademlia - Wikipedia
Kademlia je distribuovaná hash tabulka pro decentralizované peer-to-peer počítačové sítě navrhli Petar Maymounkov a David Mazières v roce 2002.[1][2] Specifikuje strukturu sítě a výměnu informací prostřednictvím uzel vyhledávání. Uzly Kademlia mezi sebou komunikují pomocí UDP. Virtuální nebo překryvná síť je tvořen účastnickými uzly. Každý uzel je označen číslem nebo ID uzlu. The ID uzlu slouží nejen jako identifikace, ale algoritmus Kademlia používá ID uzlu k vyhledání hodnot (obvykle soubor hash nebo klíčová slova). Ve skutečnosti ID uzlu poskytuje přímé mapování na hash souborů a tento uzel ukládá informace o tom, kde získat soubor nebo prostředek.
Při hledání nějaké hodnoty musí algoritmus znát přidružený klíč a zkoumat síť v několika krocích. Každý krok najde uzly, které jsou blíže ke klíči, dokud kontaktovaný uzel nevrátí hodnotu, nebo nebudou nalezeny žádné další uzly. To je velmi efektivní: jako mnoho jiných DHTs, Kademlia pouze kontakty uzlů během vyhledávání z celkového počtu uzly v systému.
Další výhody se nacházejí zejména v decentralizované struktuře, která zvyšuje odolnost proti a útok odmítnutí služby. I když je zaplavena celá sada uzlů, bude to mít omezený vliv na dostupnost sítě, protože se síť obnoví úplným propojením sítě kolem těchto „děr“.
I2P Implementace Kademlia je upravena tak, aby zmírňovala zranitelnosti Kademlia, jako je Útoky Sybil.[3]
Detaily systému
Sítě pro sdílení souborů první generace typu peer-to-peer, jako například Napster, spoléhal na centrální databázi pro koordinaci vyhledávání v síti. Sítě druhé generace typu peer-to-peer, jako např Gnutella, používá se k vyhledání souborů pomocí zaplavení a prohledává každý uzel v síti. Používají sítě peer-to-peer třetí generace Distribuované hashovací tabulky vyhledat soubory v síti. Distribuované hashovací tabulky uložit zdroj umístění v celé síti. Hlavním kritériem pro tyto protokoly je rychlé vyhledání požadovaných uzlů.
Kademlia používá výpočet „vzdálenosti“ mezi dvěma uzly. Tato vzdálenost se počítá jako exkluzivní nebo (XOR) ze dvou ID uzlů, přičemž výsledek je jako nepodepsaný celé číslo. Klíče a ID uzlů mají stejný formát a délku, takže vzdálenost mezi nimi lze vypočítat přesně stejným způsobem. ID uzlu je obvykle velké náhodné číslo, které je vybráno s cílem být pro konkrétní uzel jedinečný (viz UUID ). Může se stát a stane se, že geograficky široce oddělené uzly - například z Německa a Austrálie - mohou být „sousedy“, pokud si zvolí podobná náhodná ID uzlů.
Exkluzivní nebo byl vybrán, protože funguje jako funkce vzdálenosti mezi všemi ID uzlů. Konkrétně:
- vzdálenost mezi uzlem a sebou samým je nulová
- je symetrický: „vzdálenosti“ vypočtené z A do B a z B do A jsou stejné
- následuje nerovnost trojúhelníku: vzhledem k tomu, že A, B a C jsou vrcholy (body) trojúhelníku, pak je vzdálenost od A do B kratší než (nebo rovna) součet vzdálenosti od A do C plus vzdálenost od C do B.
Tyto tři podmínky jsou dostatečné k zajištění toho exkluzivní nebo zachycuje všechny důležité a důležité funkce funkce „skutečné“ vzdálenosti, přičemž je levné a snadno se vypočítá.[1]
Každá iterace vyhledávání Kademlia se blíží o kousek blíže k cíli. A základní Síť Kademlia s 2n uzly budou pouze trvat n kroky (v nejhorším případě) k nalezení tohoto uzlu.
Směrovací tabulky pevné velikosti
V této části je zjednodušeno použití jediné bit; viz část zrychlené vyhledávání Další informace o směrovacích tabulkách.
Směrovací tabulky pevné velikosti byly uvedeny v verze před zahájením řízení originálu a jsou použity v pozdější verzi pouze pro některé matematické důkazy. Skutečná implementace Kademlia nemá směrovací tabulku pevné velikosti, ale dynamickou.
Směrovací tabulky Kademlia se skládají z a seznam pro každý bit ID uzlu. (např. pokud ID uzlu sestává ze 128 bitů, uzel si ponechá 128 takových seznamy.) Seznam obsahuje mnoho záznamů. Každý záznam v a seznam uchovává data potřebná k vyhledání jiného uzlu. Data v každém seznam položka je obvykle IP adresa, přístav, a ID uzlu jiného uzlu. Každý seznam odpovídá konkrétní vzdálenosti od uzlu. Uzly, které mohou jít do nth seznam musí mít odlišné nth bit z ID uzlu; prvních n-1 bitů ID kandidáta se musí shodovat s těmi ID uzlu. To znamená, že je velmi snadné naplnit první seznam protože 1/2 uzlů v síti jsou daleko kandidáti. Další seznam může používat pouze 1/4 uzlů v síti (o kousek blíže než první) atd.
S ID 128 bitů bude každý uzel v síti klasifikovat další uzly v jedné ze 128 různých vzdáleností, jedna konkrétní vzdálenost na bit.
Protože se v síti vyskytují uzly, přidávají se do seznamy. To zahrnuje operace ukládání a načítání a dokonce pomáhá ostatním uzlům najít klíč. Každý nalezený uzel bude považován za zahrnutý do seznamy. Proto je znalost sítě uzlem velmi dynamická. Díky tomu je síť neustále aktualizována a dodává odolnost vůči poruchám nebo útokům.
V literatuře Kademlia se seznamy jsou označovány jako k-kbelíky. k je celé číslo systému, například 20. Každý k-kbelík je a seznam mít až k záznamy uvnitř; tj. pro síť s k = 20 bude mít každý uzel seznamy obsahující až 20 uzlů pro určitý bit (konkrétní vzdálenost od sebe).
Protože možné uzly pro každého k-kbelík rychle klesá (protože bude jen velmi málo uzlů, které jsou tak blízko), spodní bit k-kbelíky bude plně mapovat všechny uzly v této části sítě. Vzhledem k tomu, že množství možných ID je mnohem větší, než může být libovolná populace uzlů, některé k-kbelíky odpovídající velmi krátkým vzdálenostem zůstanou prázdné.
Zvažte jednoduchou síť vpravo. Velikost sítě je 2 ^ 3 nebo osm maximálních klíčů a uzlů. Zúčastňuje se sedm uzlů; malé kruhy dole. Uvažovaný uzel je uzel šest (binární 110) v černé barvě. Tam jsou tři k-kbelíky pro každý uzel v této síti. Uzly nula, jedna a dva (binární 000, 001 a 010) jsou kandidáty na nejvzdálenější k-kbelík. Uzel tři (binární 011, nezobrazeno) se neúčastní sítě. Uprostřed k-kbelík, jsou umístěny uzly čtyři a pět (binární 100 a 101). Nakonec třetí k-kbelík může obsahovat pouze uzel sedm (binární 111). Každý ze tří k-kbelíky jsou uzavřeny v šedém kruhu. Pokud je velikost k-kbelík byly dva, pak nejvzdálenější 2 vědro může obsahovat pouze dva ze tří uzlů. Například pokud má uzel šest uzel jeden a dva v nejvzdálenějším 2 kbelíku, musel by požádat o vyhledání ID uzlu k těmto uzlům, aby našel umístění (IP adresu) nulového uzlu. Každý uzel ví jeho okolí dobře a má kontakt s několika uzly daleko, což může pomoci najít další uzly daleko.
Je známo, že uzly, které byly po dlouhou dobu připojeny k síti, pravděpodobně v budoucnu zůstanou připojeny po dlouhou dobu.[4][5] Kvůli této statistické distribuci vybere Kademlia dlouhé připojené uzly, aby zůstaly uloženy v k-kbelích. To v budoucnu zvýší počet známých platných uzlů a zajistí stabilnější síť.
Když k-kbelík je plný a k tomu je objeven nový uzel k-kbelík, nejméně nedávno viděný uzel v k-kbelík je PING. Pokud se zjistí, že uzel stále žije, nový uzel se umístí do sekundárního seznamu, náhradní mezipaměti. Náhradní mezipaměť se používá, pouze pokud je uzel v k-kbelík přestane reagovat. Jinými slovy: nové uzly se používají, pouze když zmizí starší uzly.
Zprávy protokolu
Kademlia má čtyři zprávy.
- PING - slouží k ověření, zda je uzel stále naživu.
- STORE - Uloží pár (klíč, hodnota) v jednom uzlu.
- FIND_NODE - Příjemce požadavku vrátí k uzly ve svých vlastních segmentech, které jsou nejblíže požadovanému klíči.
- FIND_VALUE - Stejné jako FIND_NODE, ale pokud má příjemce požadavku ve svém úložišti požadovaný klíč, vrátí odpovídající hodnotu.
Každý RPC zpráva obsahuje náhodnou hodnotu od iniciátora. Tím je zajištěno, že při přijetí odpovědi odpovídá dříve odeslanému požadavku. (vidět Magic cookie )
Lokalizace uzlů
Vyhledávání uzlů může probíhat asynchronně. Množství současných vyhledávání je označeno α a je obvykle tři. Uzel iniciuje požadavek FIND_NODE dotazem na své α uzly k-kbelíky které jsou nejblíže požadovanému klíči. Když tyto uzly příjemců obdrží požadavek, podívají se do jejich k-kbelíky a vrátit k nejbližší uzly k požadovanému klíči, který znají. Žadatel aktualizuje seznam výsledků s výsledky (ID uzlu), které obdrží, a uchová si k nejlepší (uzly k, které jsou blíže hledanému klíči), které odpovídají na dotazy. Poté je žadatel vybere k nejlepší výsledky a vydejte jim žádost a opakujte tento proces znovu a znovu. Protože každý uzel má lepší znalosti o svém vlastním okolí, než jakýkoli jiný uzel, získanými výsledky budou další uzly, které jsou pokaždé blíže a blíže hledanému klíči. Iterace pokračují, dokud nejsou vráceny žádné uzly, které jsou blíže než nejlepší předchozí výsledky. Když se iterace zastaví, nejlepší k uzly v seznamu výsledků jsou ty v celé síti, které jsou nejblíže požadovanému klíči.
Informace o uzlu lze rozšířit o zpáteční časy nebo RTT. Tyto informace budou použity k výběru časového limitu specifického pro každý konzultovaný uzel. Když vyprší časový limit dotazu, lze zahájit další dotaz, který nikdy nepřekoná α dotazy současně.
Vyhledání zdrojů
Informace se nacházejí mapováním na klíč. A hash se obvykle používá pro mapu. Uzly úložiště budou mít informace kvůli předchozí zprávě STORE. Vyhledání hodnoty se řídí stejným postupem jako vyhledání nejbližších uzlů klíče, kromě toho, že hledání skončí, když má uzel požadovanou hodnotu ve svém úložišti a vrátí tuto hodnotu.
Hodnoty jsou uloženy na několika uzlech (z nich), aby uzly mohly přicházet a odcházet a stále mít hodnotu k dispozici v nějakém uzlu. Uzel, který ukládá hodnotu, bude pravidelně prozkoumávat síť, aby nalezl uzly k, které jsou blízké klíčové hodnotě, a replikuje na ně hodnotu. To kompenzuje zmizení uzlů.
Také u populárních hodnot, které mohou mít mnoho požadavků, se zatížení v uzlech úložiště zmenší tím, že retrívr uloží tuto hodnotu do nějakého uzlu poblíž, ale mimo nejbližších. Toto nové úložiště se nazývá mezipaměť. Tímto způsobem je hodnota uložena dále a dále od klíče, v závislosti na množství požadavků. To umožňuje populárním vyhledáváním rychleji najít skladiště. Protože se hodnota vrací z uzlů dále od klíče, zmírňuje to možné „aktivní body“. Uzly v mezipaměti po určité době hodnotu sníží v závislosti na jejich vzdálenosti od klíče.
Některé implementace (např. Kad ) nemají replikaci ani ukládání do mezipaměti. Účelem je rychle odstranit staré informace ze systému. Uzel, který poskytuje soubor, bude pravidelně obnovovat informace do sítě (provádět zprávy FIND_NODE a STORE). Když všechny uzly se souborem přejdou do režimu offline, nikdo nebude obnovovat jeho hodnoty (zdroje a klíčová slova) a informace nakonec ze sítě zmizí.
Připojení k síti
Uzel, který se chce připojit k síti, musí nejprve projít a bootstrap proces. V této fázi musí spojující uzel znát IP adresa a port jiného uzlu - uzel bootstrap (získaný od uživatele nebo z uloženého seznamu) - který se již účastní sítě Kademlia. Pokud se spojující uzel dosud v síti nezúčastnil, vypočítá a náhodný ID číslo, které již nemá být přiřazeno žádnému jinému uzlu. Toto ID používá až do opuštění sítě.
Spojovací uzel vloží uzel bootstrap do jednoho ze svých k-kbelíky. Spojovací uzel poté provede vyhledání uzlu svého vlastního ID proti uzlu bootstrap (jediný další uzel, který zná). „Vlastní vyhledávání“ naplní ostatní uzly k-kbelíky s novým ID uzlu a naplní k-kbelíky spojovacího uzlu uzly v cestě mezi ním a uzlem bootstrap. Poté spojovací uzel obnoví vše k-kbelíky dále od k-kbelíku, do kterého spadá uzel bootstrapu. Tato aktualizace je jen vyhledáním náhodného klíče, který je uvnitř k-kbelík rozsah.
Zpočátku uzly jeden mají k-kbelík. Když k-kbelík zaplní, lze jej rozdělit. K rozdělení dojde, pokud je rozsah uzlů v k-kbelík překlenuje vlastní id uzlu (hodnoty vlevo a vpravo v binárním stromu). Kademlia uvolňuje i toto pravidlo pro jeden „nejbližší uzel“ k-kbelík, protože obvykle jeden jediný segment bude odpovídat vzdálenosti, kde jsou všechny uzly, které jsou nejblíže tomuto uzlu, mohou být větší než k, a chceme, aby je všechny znal. Může se ukázat, že poblíž uzlu existuje vysoce nevyvážený binární pod strom. Li k je 20 a existuje 21+ uzlů s předponou „xxx0011 .....“ a nový uzel je „xxx000011001", nový uzel může obsahovat více k-kbelíky pro dalších 21+ uzlů. Tím je zaručeno, že síť ví o všech uzlech v nejbližší oblasti.
Zrychlené vyhledávání
Kademlia používá XOR metrický definovat vzdálenost. ID dvou uzlů nebo ID uzlu a klíč jsou XORed a výsledkem je vzdálenost mezi nimi. Pro každý bit vrátí funkce XOR nulu, pokud jsou dva bity stejné, a jeden, pokud jsou dva bity odlišné. XOR metrické vzdálenosti drží nerovnost trojúhelníku: vzhledem k tomu, že A, B a C jsou vrcholy (body) trojúhelníku, pak je vzdálenost od A do B kratší než (nebo rovna) součet vzdálenosti od A do C do B.
The Metrika XOR umožňuje Kademlii rozšířit směrovací tabulky nad jednotlivé bity. Lze umístit skupiny bitů k-kbelíky. Skupina bitů se nazývá předpona. Pro m-bit předpona, budou 2m-1 k-kbelíky. Chybějící k-kbelík je dalším rozšířením směrovacího stromu, který obsahuje ID uzlu. An m-bit prefix snižuje maximální počet vyhledávání od log2 n na log2m n. Tyto jsou maximum hodnoty a průměrná hodnota bude mnohem menší, což zvyšuje šanci na nalezení uzlu v a k-kbelík který sdílí více bitů než jen předponu s cílovým klíčem.
Uzly mohou ve své směrovací tabulce používat směsi předpon, například Síť Kad používá eMule.[Citace je zapotřebí ] Síť Kademlia může být dokonce heterogenní při implementaci směrovací tabulky, a to na úkor komplikování analýzy vyhledávání.
Akademický význam
I když metrika XOR není pro pochopení Kademlie nutná, je při analýze protokolu zásadní. Aritmetika XOR tvoří abelianská skupina umožňující uzavřenou analýzu. Další protokoly a algoritmy DHT vyžadují simulace nebo složitá formální analýza za účelem předpovědi chování a správnosti sítě. Použití skupin bitů jako směrovací informace také zjednodušuje algoritmy.
Matematická analýza algoritmu
Chcete-li analyzovat algoritmus, zvažte síť Kademlia o uzly s ID , z nichž každý je řetězec délky který se skládá pouze z jedniček a nul. Lze jej modelovat jako a trie, ve kterém každý list představuje uzel, a označená cesta od kořene k listu představuje jeho ID. Pro uzel , nechť být sada uzlů (ID), které sdílejí předponu délky . Poté naplňte -th kbelík z lze modelovat jako přidání ukazatelů z listu na listy (ID) vybrané náhodně jednotně z . Směrování lze tedy považovat za skákání mezi listy podél těchto ukazatelů, takže každý krok jde co nejvíce k cílovému ID, tj. Chamtivým způsobem.
Nechat být počet skoků potřebných k přechodu z listu na cílové ID Za předpokladu, že jsou vybírány deterministicky z , bylo prokázáno, že
kde je -th Harmonické číslo. Od té doby tak jako , když je velký je ohraničen shora asi , jsou však vybrána ID a cíl.[6] To ospravedlňuje intuici pouze v Kademlii uzly jsou kontaktovány při hledání cílového uzlu.
Aby byl model blíže ke skutečným sítím Kademlia, lze také předpokládat, že budou náhodně vybrány jednotně bez nahrazení z . Pak lze dokázat, že pro všechny a ,
kde je konstanta závislá pouze na s tak jako . Tak pro velký, konverguje na konstantní uzavření . To znamená, že počet uzlů, které je třeba kontaktovat při hledání cílového uzlu, je ve skutečnosti v průměru.[7]
Použití v sítích pro sdílení souborů
Kademlia se používá v Sdílení souborů sítí. Při vyhledávání podle klíčových slov Kademlia lze najít informace v síti pro sdílení souborů, aby je bylo možné stáhnout. Protože neexistuje centrální instance pro uložení indexu existujících souborů, je tento úkol rovnoměrně rozdělen mezi všechny klienty: Pokud chce uzel sdílet soubor, zpracuje obsah souboru a vypočítá z něj číslo (hash ), který identifikuje tento soubor v síti pro sdílení souborů. Hodnoty hash a ID uzlu musí mít stejnou délku. Poté vyhledá několik uzlů, jejichž ID je blízké hash, a má vlastní IP adresu uloženou v těchto uzlech. tj. publikuje se jako zdroj pro tento soubor. Vyhledávací klient použije Kademlia k vyhledání uzlu v síti, jehož ID má nejmenší vzdálenost od hash souboru, poté načte seznam zdrojů, který je v daném uzlu uložen.
Protože klíč může odpovídat mnoha hodnotám, např. mnoho zdrojů stejného souboru, každý úložný uzel může mít různé informace. Poté jsou zdroje požadovány ze všech uzlů k poblíž klíče.
Souborový hash se obvykle získává ze speciálně vytvořeného Internetu magnetický odkaz nalezeny jinde nebo zahrnuty do indexovacího souboru získaného z jiných zdrojů.
Vyhledávání názvu souboru se provádí pomocí klíčová slova. Název souboru je rozdělen na jeho základní slova. Každé z těchto klíčových slov je hašováno a uloženo v síti spolu s odpovídajícím hashem souboru a souboru. Hledání zahrnuje výběr jednoho z klíčových slov, kontaktování uzlu s ID nejbližším hash klíčového slova a získání seznamu názvů souborů, které obsahují klíčové slovo. Protože každý název souboru v seznamu má připojený hash, lze vybraný soubor získat běžným způsobem.
Implementace
Sítě
Veřejné sítě využívající Kademlia algoritmus (tyto sítí jsou navzájem nekompatibilní):
- I2P - anonym překryvná síť vrstva.[8]
- Síť Kad - vyvinut původně společností eMule komunita nahradit serverovou architekturu Síť eDonkey2000.
- Ethereum - Protokol pro zjišťování uzlů v síťovém zásobníku blockchainu Etherea je založen na mírně upravené implementaci Kademlia.[9]
- Síť overnet: S KadC je k dispozici knihovna C pro zpracování její Kademlia. (vývoj sítě Overnet je ukončen)
- BitTorrent Používá DHT na základě implementace algoritmu Kademlia pro torrenty bez sledování.
- Osiris sps (všechny verze): slouží ke správě distribuovaného a anonymního webového portálu.
- Retroshare - F2F decentralizovaná komunikační platforma se zabezpečeným VOIP, instant messaging, přenos souborů atd.
- Tox - Plně distribuovaná platforma pro zasílání zpráv, VoIP a videochat
- Gnutella DHT - původně LimeWire[10][11] rozšířit protokol Gnutella pro hledání alternativních umístění souborů, které nyní používají ostatní klienti gnutella.[12]
- IPFS - Peer-to-peer distribuovaný souborový systém založený na libp2p.[13]
- TeleHash je síťový síťový protokol, který používá Kademlia k řešení přímých spojení mezi stranami.[14]
- iMule - Sdílení souborů obslužný software pro I2P.
- OpenDHT - knihovna poskytující implementaci Kademlia, kterou používá Jami a další.
- GNUnet - alternativní síťový zásobník pro vytváření bezpečných, decentralizovaných a na ochranu soukromí distribuovaných aplikací. Používá randomizovanou verzi Kademlia nazvanou R5N[15]
Viz také
Reference
- ^ A b *Kademlia: Informační systém typu peer-to-peer založený na metrice XOR
- ^ „Papíry Davida Mazièrese“. www.scs.stanford.edu.
- ^ „Síťová databáze - I2P“.
- ^ Stefan Saroiu, P. Krishna Gummadi a StevenD. Gribble. Studie měření systémů sdílení souborů peer-to-peer. Technická zpráva UW-CSE-01-06-02, University of Washington, Department of Computer Science and Engineering, červenec 2001.
- ^ Daniel Stutzbach a Reza Rejaie. Porozumění churn v sítích peer-to-peer Oddíl 5.5 Předvídatelnost provozuschopnosti, konference o měření internetu, Rio de Janeiro, říjen 2006.
- ^ Cai, X. S .; Devroye, L. (2013). "Pravděpodobnostní analýza sítí Kademlia". Algoritmy a výpočet. Přednášky z informatiky. 8283: 711. arXiv:1309.5866. doi:10.1007/978-3-642-45030-3_66. ISBN 978-3-642-45029-7.
- ^ Cai, Xing Shi; Devroye, Luc (2015). "Analýza Kademlie pro náhodná ID". Internetová matematika. 11: 1–16. arXiv:1402.1191. doi:10.1080/15427951.2015.1051674. ISSN 1542-7951.
- ^ „Intro - I2P“. geti2p.net.
- ^ „GitHub - ethereum / wiki: The Ethereum Wiki“. 25. března 2019 - prostřednictvím GitHub.
- ^ „Slyck News - LimeWire získává nejlepší pozici na webu Download.com“. www.slyck.com.
- ^ „Mojito - LimeWire“. wiki.limewire.org. Archivovány od originál dne 17. února 2009.
- ^ "Seznam změn Gtk-gnutella". sourceforge.net. Archivovány od originál dne 23. července 2011. Citováno 23. ledna 2010.
- ^ „Papír IPFS“ (PDF).
- ^ „# 7: Jeremie Miller - TeleHash“. Citováno 2016-03-12.
- ^ „R5N: Randomizované rekurzivní směrování pro sítě s omezeným směrováním“ (PDF).
externí odkazy
- Xlattické projekty Specifikace a definice Kademlia.