DHT ( anglicky d istributed hash table - „distribuovaná hashovací tabulka “) je třída decentralizovaných systémů distribuovaných vyhledávacích služeb, které fungují jako hashovací tabulka. Jako datová struktura může být hashovací tabulka asociativní pole obsahující páry ( klíč – hodnota ). Termín DHT je také spojen s řadou principů a algoritmů , které vám umožňují zaznamenávat data, distribuovat informace mezi určitou sadu uzlů úložiště a obnovovat je distribuovaným vyhledáváním podle klíče. Rysem distribuované tabulky je schopnost distribuovat informace mezi sadu uzlů úložiště takovým způsobem, že každý zúčastněný uzel může najít hodnotu spojenou s daným klíčem. Odpovědnost za udržování vztahu mezi jménem a hodnotou je rozdělena mezi uzly, přičemž změna sady členů způsobuje minimální počet přerušení. To vám umožní snadno škálovat DHT a také neustále sledovat přidávání a odstraňování uzlů a chyb v jejich práci.
DHT je rámec, který lze použít k vytvoření mnoha komplexních služeb, jako jsou distribuované systémy souborů , distribuce souborů typu peer-to-peer a sítě pro doručování obsahu , kooperativní webová mezipaměť, multicast , anycast , služba názvů domén a rychlé zasílání zpráv . Hlavní distribuované sítě, které používají DHT: I2P síť , BitTorrent , eDonkey síť ( Kad Network ) , YaCy , Tox a Coral Content Distribution Network . Přes síť DHT je možné vytvářet vyhledávače .
Výzkum DHT byl zpočátku motivován zejména peer-to-peer systémy jako I2P , Napster , Gnutella , Freenet , které využívaly zdroje distribuované přes internet k vytvoření jediné aplikace. Zejména využívali širokopásmový internet a místo na pevném disku k poskytování služby distribuce souborů.
Tyto systémy se liší v tom, jak nalezly data kolegů:
DHT používají strukturovanější směrování klíčů k dosažení decentralizace I2P , Gnutella a Freenetu a účinnosti a zaručených výsledků Napsteru . Jednou nevýhodou je, že stejně jako Freenet podporuje DHT pouze vyhledávání v přesné shodě a nikoli vyhledávání podle klíčových slov, i když tyto funkce lze navrstvit na DHT.
První čtyři DHT – CAN , Chord , Pastry a Tapestry – byly představeny kolem roku 2001 . Od té doby je tato oblast výzkumu poměrně aktivní. Mimo akademickou sféru byla technologie DHT přijata jako součást BitTorrentu a Coral Content Distribution Network .
DHT se vyznačuje následujícími vlastnostmi:
Klíčovou technikou pro dosažení tohoto cíle je, že každý uzel by se měl koordinovat pouze s několika uzly v systému – typicky O(log n ), kde n je počet účastníků (viz níže) – takže je potřeba jen omezené množství práce. provedené při každé změně počtu účastníků.
Některé projekty DHT se snaží poskytovat ochranu před uživateli se zlými úmysly a umožňují účastníkům zůstat v anonymitě, i když je to méně běžné než v mnoha jiných systémech P2P (zejména při sdílení souborů); viz Anonymní sítě .
A konečně, DHT se musí vypořádat s tradičnějšími problémy distribuovaného systému, jako je vyvažování zátěže, integrita dat a výkon (zejména zajištění rychlého dokončení operací, jako je směrování a ukládání dat nebo vyhledávání).
Strukturu DHT lze rozdělit na několik hlavních složek. Je založen na abstraktním klíčovém prostoru, jako je sada 160bitových řetězců (počet bitů se může lišit). Schéma rozdělení prostoru klíčů rozděluje vlastnictví klíče mezi zúčastněné uzly. Překryvná síť pak propojí uzly a pomůže najít vlastníka jakéhokoli klíče v prostoru klíčů.
Se všemi komponentami na místě je typické použití DHT pro ukládání a zobrazování informací následovně: předpokládejme, že klíčový prostor je 160bitové řetězce. Pro uložení souboru s daným jménem a informacemi do DHT je z názvu souboru nalezen hash SHA1 (160bitová hodnota) , ze kterého se vytvoří 160bitový klíč k (hash), po kterém se vytvoří zpráva. put(k, data), где data - содержание самого файлаa odeslány do kteréhokoli zúčastněného uzlu v DHT. Zpráva prochází z jednoho uzlu do druhého přes překryvnou síť, dokud nedosáhne jediného uzlu zodpovědného za klíč k, v souladu se schématem rozdělení prostoru klíčů, kde bude pár (k, data) uložen. Jakýkoli jiný klient může získat obsah souboru vytvořením klíče (k), tj. získáním hash názvu souboru , aby našel data spojená s klíčem odesláním zprávy get(k). Zpráva opět projde přes překrytí do uzlu odpovědného za klíč, který odpoví, že požadovaná data jsou k dispozici.
Komponenty dělení klíčového prostoru a překryvné síťové komponenty jsou popsány níže, aby představily základní myšlenky společné pro většinu systémů DHT. Mnoho vývojů se v detailech liší.
Většina DHT používá různé varianty konzistentního hashování k mapování klíčů na uzly. Srdcem této metody rozdělení je funkce , která definuje abstraktní pojem vzdálenosti mezi klávesami a , která nemá nic společného s geografickou vzdáleností nebo zpožděním sítě. Každému uzlu je přiřazen jeden klíč, nazývaný jeho identifikátor (ID). Uzel s ID vlastní všechny klíče , pro které je nejbližší ID vypočteno pomocí .
Příklad. Chord DHT zachází s klávesami jako s body na kruhu a je to vzdálenost ujetá ve směru hodinových ručiček kolem kruhu od klávesy k . Kruh klíčového prostoru je tedy rozdělen na souvislé segmenty, jejichž konce jsou identifikátory uzlů. Pokud a jsou sousední ID, pak uzel s ID obsahuje všechny klíče mezi a .
Konzistentní hašování má hlavní vlastnost, že odstranění nebo přidání pouze jedné sady klíčů patřících uzlům sousedních ID neovlivní ostatní uzly.
DHT i PEX ve skutečnosti plní hlavní funkci BitTorrent trackeru – pomáhají účastníkům sdílení souborů dozvědět se o sobě navzájem. Oni mohou:
Ve veřejných (otevřených) trackerech, kde si kdokoli může stáhnout torrent a podílet se na distribuci, slouží DHT a PEX ve prospěch všech účastníků.
U soukromých (uzavřených) trackerů je především důležité, aby se distribuce mohli účastnit pouze registrovaní uživatelé a dodržovali určitá pravidla. Na první žádost klienta má soukromý tracker možnost zabránit jeho distribuci, aniž by mu sdělil adresy ostatních zúčastněných klientů. Proto je pro soukromý tracker důležité, aby klienti tyto adresy nedostávali přes DHT/PEX.
DHT a PEX se objevily v klientech Azureus a BitComet kolem léta 2005. Správci mnoha soukromých trackerů nebyli s touto novou funkcí spokojeni, a proto začali tyto nové klientské verze na trackeru zakazovat.
Poté vývojáři klientů navrhli nový klíč uvnitř souboru torrent: private . Pokud se rovná 1, pak je klient povinen automaticky zakázat DHT / PEX pro tento torrent, bez ohledu na přání uživatele. Takový torrent se nazývá Secure Torrent.
Téměř všechny moderní soukromé trackery samy o sobě prosazují private:1 ve všech torrentech zveřejněných na trackeru a také zakazují několik zastaralých verzí klientů, kteří podporují DHT nebo PEX, ale ještě nevědí o soukromém klíči . Předpokládá se, že uživatelé sledovačů jednoduše nemohou používat DHT / PEX na distribucích a není problém. Ve skutečnosti, aby nebylo zohledněno hodnocení, stačí nahradit váš přístupový klíč jakýmkoli jiným. A ani ho nemusíte krást. Stačí si zaregistrovat jiný účet, abyste si z něj vzali přístupový klíč.
Tato část se vztahuje pouze na soukromé trackery, kde soukromý klíč není vnucován do torrentů , a na některých distribucích (v závislosti na tom, zda distributor sám vložil soukromý klíč do torrentu ) lze použít DHT a PEX.
Často existuje názor, že DHT povolené v klientovi ovlivňuje sledování klientských statistik trackerem, například „distribuováno přes DHT, takže statistiky prošly kolem trackeru“. To není pravda.
Za prvé, DHT/PEX se používá pouze k získání partnerských adres. Sdílení souborů ani jejich statistiky nejsou vedeny. Klient hlásí statistiky stažených a nahraných dat pouze do trackeru.
To znamená, že „distribuováno prostřednictvím DHT“ ve skutečnosti znamená „Dostal jsem informace o některých (nebo všech) peerech prostřednictvím DHT a pravděpodobně mě někteří kolegové také našli prostřednictvím DHT.
Zadruhé, ačkoli klienti obvykle vědí, odkud získali své partnerské adresy, žádný klient nerozděluje provoz na „přijato/odesláno účastníkům DHT“ a „přijato/odesláno kolegům přijatým ze sledovače“. I v případě potřeby by to pro klienta bylo obtížné - některé peery mohou být přijímány jak z trackeru, tak přes DHT nebo PEX a klient často neví, jak peer, který s ním zahajuje spojení, získal svou adresu.
Klient hlásí trackeru celková data o stažených objemech a poskytnutých všem peerům, se kterými komunikoval , bez ohledu na to, zda se klient o jednotlivých peerech dozvěděl přes tracker, DHT nebo PEX, nebo zda tento peer dokonce sám zahájil připojení. . To znamená, že i když se na distribuci objeví „leví“ uživatelé (kteří nemají přístup k trackeru) kvůli DHT / PEX, klient bude stále hlásit trackeru vše, co si stáhli a rozdali.
Správné účtování statistik závisí pouze na stavu trackeru: tracker funguje - statistiky se berou v úvahu, pokud nefunguje - nebere se v úvahu. Pouze v případě dlouhodobě nefunkčního trackeru může hrát DHT / PEX nepřímou roli, která zabraňuje postupnému vymírání sdílení souborů na takové „distribuci bez zohlednění statistik“.
Implementace distribuované sítě v klientech BitTorrent je založena na variantě DHT nazvané Kademlia . Obecně lze říci, že DHT (Distributed hash table) znamená decentralizovaný distribuovaný systém pro kombinování velkého množství neustále mizejících a objevujících se uzlů a efektivní přenos zpráv mezi nimi. Na základě struktur DHT jsou postaveny různé složitější systémy, jako je sdílení souborů P2P , kooperativní ukládání do mezipaměti webu, služby DNS atd.
DHT používá protokol UDP . Klienti BitTorrent „poslouchají“ na stejném čísle portu UDP, které používají pro příchozí TCP spojení. Pokud aktivně používáte DHT, pak je otevření tohoto UDP portu pro přístup zvenčí žádoucí, ale není nutné - DHT tak bude fungovat.
Každý připojený klient je samostatným uzlem v síti DHT. Má své vlastní jedinečné ID (identifikátor), náhodně vybrané ze stejného 160bitového prostoru jako infohash'a torrenty.
Každý uzel udržuje směrovací tabulku obsahující kontaktní informace pro mnoho „nejbližších“ uzlů a pro několik vzdálenějších. „Blízkost“ dvou uzlů se vypočítává z „podobnosti“ jejich ID a nemá nic společného s jejich geografickou blízkostí.
Když chce uzel najít partnery pro distribuci, porovnává infohash této distribuce s ID uzlů, které zná, a pak odešle požadavek na uzel, jehož ID je tomuto infohash nejpodobnější. Tento uzel mu vrátí adresu uzlu, jehož ID je ještě blíže infohash torrentu.
Poté náš uzel odešle požadavek tomuto novému uzlu a obdrží od něj adresu dalšího uzlu, jehož ID je ještě více podobné infohash torrentu.
Požadavky od klientů podílejících se na distribuci torrentu s konkrétním infohash tak postupně proudí do uzlů, jejichž ID jsou tomuto infohashe nejpodobnější. Tyto uzly si pamatují předchozí požadavky a všem následujícím žádajícím uzlům budou vráceny adresy předchozích kolegů ze stejné distribuce.
BitTorrent ( klientské programy ) | Protokol výměny souborů|
---|---|
Autoři | Osoby Eric Clinker Bram Cohen Navin Společnosti BitTorrent Inc. Vuse, Inc. |
Technika |
|
Sledovači | |
Motory |
|
Související články |