Úvod do P2P sítí Počítačové sítě Lekce 13 Ing. Jiří Ledvina, CSc.

Slides:



Advertisements
Podobné prezentace
Základy databázových systémů
Advertisements

Přednáška č. 5 Proces návrhu databáze
Souborové systémy.
Architektury a techniky DS Tvorba efektivních příkazů I Přednáška č. 3 RNDr. David Žák, Ph.D. Fakulta elektrotechniky a informatiky
Manažerské informační systémy Ing. Dagmar Řešetková
Komunikace v DS Přednášky z distribuovaných systémů Ing. Jiří Ledvina, CSc.
Adresářová služba Active directory
Databázové systémy Mgr. Lenka Švancarová. Úvod Doposud jsme uvažovali jen o modelu databázového systému, kde jsou veškerá data a systém řízení báze dat.
VLAN Projektování distribuovaných systémů Lekce 2 Ing. Jiří ledvina, CSc.
Internet, WWW, HTML a spol.. Hlavní zásady inženýrství reprodukovatelnost měřitelnost a parametrizovatelnost přenositelnost typizace a standardizace dokumentace.
Architektura databází Ing. Dagmar Vítková. Centrální architektura V této architektuře jsou data i SŘBD v centrálním počítači. Tato architektura je typická.
CZ.1.07/1.4.00/ VY_32_INOVACE_169_IT 9 Výukový materiál zpracovaný v rámci projektu Vzdělávací oblast: Informační a komunikační technologie Předmět:Informatika.
Relační databáze.
ICQ. Co je ICQ? ICQ je nejpoužívanější a nejpopulárnější komunikační program. ICQ je zkratka slangového výrazu „I seek you“ (hledám tě). Slouží ke komunikaci.
Databázové systémy. Práce s daty Ukládání dat Aktualizace dat Vyhledávání dat Třídění dat Výpočty a agregace.
Databázové systémy Architektury DBS.
Metainformační systém založený na XML Autor: Josef Mikloš Vedoucí práce: Ing. Jan Růžička, Ph.D. V/2004.
Informatika pro ekonomy II přednáška 10
Celní služby 2000 Radek Sedláček TranSoft a.s Radek Sedláček TranSoft a.s
Základy počítačových sítí elektronická pošta Základy počítačových sítí Lekce 5 Ing. Jiří ledvina, CSc.
David Šupita, Adam Řešetka, Petr Horák
Public Key Infrastructure Přednášky z Distribuovaných systémů Ing. Jiří Ledvina, CSc.
Shrnutí A – Principy datové komunikace B – TCP/IP 1.
CZ.1.07/1.4.00/ VY_32_INOVACE_168_IT 9 Výukový materiál zpracovaný v rámci projektu Vzdělávací oblast: Informační a komunikační technologie Předmět:Informatika.
DATABÁZOVÉ SYSTÉMY. 2 DATABÁZOVÝ SYSTÉM SYSTÉM ŘÍZENÍ BÁZE DAT (SŘBD) PROGRAM KTERÝ ORGANIZUJE A UDRŽUJE NASHROMÁŽDĚNÉ INFORMACE DATABÁZOVÁ APLIKACE PROGRAM.
Asynchronous Transfer Mode Projektování distribuovaných systémů Lekce 1 Ing. Jiří ledvina, CSc.
BootP Ing. Jiří Ledvina, CSc /12 Úvod Původně používání RARP Reverse Address Resolution protocol Dovoluje pouze distribuci adres na lokálním.
INTERNET – struktura, fungování a přehled využití
Databázové modelování
2 Petr Žitný znalosti.vema.cz 3 Báze znalostí Nová služba zákazníkům ▸Báze naplněná informacemi, ke které mají uživatelé přímý přístup Základní cíl ▸Poskytovat.
Základy informatiky část 6
Databázové systémy Informatika pro ekonomy, př. 18.
Strukturované a nestrukturované P2P sítě, DHT
Strukturované a nestrukturované P2P sítě, DHT Projektování distribuovaných systémů Lekce 14 Ing. Jiří Ledvina, CSc.
Distribuovaná sdílená paměť Přednášky z Distribuovaných systémů Ing. Jiří Ledvina, CSc.
Distribuované algoritmy - přehled Přednášky z Distribuovaných systémů Ing. Jiří Ledvina, CSc.
Internet.
Datovýsklad Datový sklad V budoucích službách státního archivu.
Internet.
Databázové systémy Přednáška č. 5 Datové typy a Fyzická organizace dat.
Protokoly úrovně 3 nad ATM Projektování distribuovaných systémů Lekce 2 Ing. Jiří ledvina, CSc.
Směrování -RIP. 2 Základy směrování  Předpoklady:  Mějme směrovač X  Směrovač nemůže znát topologii celé sítě  X potřebuje určit směrovač pro přístup.
Internet protocol Počítačové sítě Ing. Jiří Ledvina, CSc.
Architektura databází DBS=SŘBD+DB
Návrh a implementace algoritmů pro údržbu,
Úvod do P2P sítí Přednášky z Distribuovaných systémů
Kontakty slajdy: ftp://ulita.ms.mff.cuni.cz/predn/POS.
Databázové systémy Úvod, Základní pojmy. Úvod S rozvojem lidského poznání roste prudce množství informací. Jsou kladeny vysoké požadavky na ukládání,
Sítě - nástin 5. AG. Sítě Abychom pochopili princip internetu, nesmíme se zapomenout pobavit o sítích. Abychom pochopili princip internetu, nesmíme se.
E- MAIL Ing. Jiří Šilhán. E LEKTRONICKÁ POŠTA NEBOLI vývoj od počátku sítí – původní návrh pouze pro přenos krátkých textových zpráv (ASCII) základní.
 nejvíce využívaná služba internetu založená na www stránkách  poskytuje virtuální informační prostor, přístupný pomocí prohlížeče  výhodou www stránek.
Počítačové sítě ● Síťové architektury ● Internet – historie a současnost ● Místní a rozsáhlé sítě ● Síťové prvky ● Adresace v sítích TCP/IP ● URI ● Síťové.
Internet. je celosvětový systém navzájem propojených počítačových sítí („síť sítí“), ve kterých mezi sebou počítače komunikují pomocí rodiny protokolů.
 = jedná se o vzájemné propojení lokálních počítačových sítí pomocí vysokorychlostních datových spojů  vznikl spojením mnoha menších sítí  v každé.
SMĚROVÁNÍ V POČÍTAČOVÝCH SÍTÍCH Část 4 – Směrování v IPv6 Zpracovala: Mgr. Marcela Cvrkalová Střední škola informačních technologií a sociální péče, Brno,
Databáze ● úložiště dat s definovaným přístupem ● typy struktury – strom, sekvence, tabulka ● sestává z uspořádaných záznamů ● databáze – struktura – záznam.
X36MTI Libor Bánovský. Klient – server: ● Připojení více klientům k jednomu serveru ● Sdílení zdrojů serveru ● Pro velké soubory mnoho diskových operací.
Transportní vrstva v TCP/IP Dvořáčková, Kudelásková, Kozlová.
Shrnutí A – Principy datové komunikace B – TCP/IP 1.
Paměti PC HDD, CD/DVD, USB Flash RAM a ROM Vnější paměť Disková paměť
Vypracoval / Roman Málek
Inf Elektronická komunikace
C-síť (circle – net) Petr Kolman.
Virtuální privátní sítě
Informatika pro ekonomy přednáška 8
Číslo projektu OP VK Název projektu Moderní škola Název školy
Přednášky z distribuovaných systémů
Základy počítačových sítí elektronická pošta
Přednášky z Distribuovaných systémů
HASH.
Transkript prezentace:

Úvod do P2P sítí Počítačové sítě Lekce 13 Ing. Jiří Ledvina, CSc.

Počítačové sítě2 Úvod Základní rozdělení P2P systémů sdílející obsah vyhledávající obsah Sdílení obsahu přímý přenos mezi uzly – identické pro všechny uzly strukturované nebo nestrukturované ukládání dat automatická replikace dat

Počítačové sítě3 Úvod Jiné dělení P2P systémů Pro paralelní výpočty Mnohonásobné výpočty Rozdělené výpočty Přístup k souborům a informacím Sdílení obsahu Přístup k souborům Filtrování, vyhledávání Kooperující (RT) Instant messaging Sdílené aplikace hry

Počítačové sítě4 Úvod Rozdělení podle decentralizace Čisté P2P systémy Členové jsou servery i klienti (servent) Bez centrálního serveru Bez centrálního směrovače Hybridní P2P Centrální server pro udržování informací o členech Odpovídání na dotazy (indexy) Členové udržují informaci (soubory) Směrování pomocí převodu reference – adresa Kombinované obojí

Počítačové sítě5 Vyhledávání v P2P sítích Vyhledávání obsahu centralizované decentralizované založené na pravděpodobnostním vyhledávání

Počítačové sítě6 P2P směrování P2P overlay networks Členové jsou uzly Sousední členové jsou propojeni virtuálními hranami (TCP, IP adresa) Změna topologie Nový uzel musí nabootovat informaci Periodický ping Test životaschopnosti při přenosu zpráv Rekonfigurace – přidávání uzlů, ztráta souseda

Počítačové sítě7 Typy P2P P2P systémy Nestrukturované Napster (centralizované) Gnutella (distribuované) Kazaa/FastTrack (hierarchické) Strukturované Chord – uzly v kruhu Pastry – overlay síť, ID Scribe - kruh CAN

Počítačové sítě8 Model klient/server Architektura klient/server server musí být výkonný, spolehlivý, známý zdroj dat klienti požadují data od serverů často používaný, úspěšný model Omezení architektury klient/server těžko dosažitelná škálovatelnost představuje úzké místo z hlediska chyb vyžaduje administraci mohou existovat nevyužité zdroje o řešení těchto problémů se snaží P2P sítě

Počítačové sítě9 Model peer-to-peer P2P počítání P2P počítání je sdílení výpočetních zdrojů a služeb přímou výměnou mezi systémy Tyto zdroje a služby zahrnují výměnu informace, cykly zpracování, vyrovnávací paměti a diskové paměti pro ukládání souborů P2P počítání využívá existujících výpočetních zdrojů, pamětí, propojení počítačů a dovoluje uživatelům využívat společný výpočetní výkon ku prospěchu všech

Počítačové sítě10 Architektura P2P sítí všechny uzly jsou jak klienti, tak i servery zpracovávají a spotřebovávají data jakýkoliv uzel může zahájit spojení neexistuje centrální zdroj dat

Počítačové sítě11 Charakteristiky P2P sítí klienti jsou současně servery i směrovače uzly se podílí úložišti dat, pamětí, CPU uzly jsou autonomní (bez administrace) síť je dynamická : uzly se mohou často připojovat i odpojovat uzly spolupracují přímo, každý s každým (ne prostřednictvím serverů) uzly mohou být velice odlišné

Počítačové sítě12 Vlastnosti P2P sítí Výhody P2P sítí efektivní využívání zdrojů využívají nevyužité zdroje (paměť, CPU) v síti škálovatelnost možnost replikace geografická distribuovanost neexistuje centrální bod (chyby) jednoduchá administrace uzly se organizují samy není třeba dislokovat servery aby byly pokryty požadavky systému je vlastní odolnost proti chybám, replikace, vyrovnání zátěže

Počítačové sítě13 Aplikace P2P sítí sdílení souborů (Napster, Gnutella, Kazaa) síťové hry (DOOM) sdílené aplikace (ICQ, sdílené tabule) distribuované výpočty

Počítačové sítě14 Aplikace P2P sítí Sdílení souborů Napster, Gnutella, Kazaa, Freenet Rozsáhlé sdílení souborů Zpřístupnění souborů (hudba, video) na vlastním počítači ostatním Ostatní uživatelé se připojí do sítě, vyhledávají soubory a stahují si je Problém – zasahování do autorských práv

Počítačové sítě15 Napster 5/1999 – 2001 (soud), konec sdílení hudebních souborů centralizované řešení uživatelé zapíší seznam svých souborů do Napster serveru další uživatelé pošlou požadavek se seznamem požadovaných souborů do Napster serveru (vyhledávání podle klíčů) Napster server pošle seznam IP adres počítačů, které soubory obsahují Uživatel se připojí přímo k vybranému uživateli a soubor stáhne

Počítačové sítě16 Napster Centrální Napster server Zajišťuje správné odpovědi Je však úzkým místem z hlediska škálovatelnosti Je také úzkým místem z hlediska chyb Citlivý na DoD Prohledávání je centralizované Přenos souborů je přímý (peer-to-peer)

Počítačové sítě17 Napster

Počítačové sítě18 Gnutella dovede sdílet libovolné soubory na rozdíl od Napster provádí decentralizované prohledávání dotazuje se sousedů sousedé se dotazují svých sousedů, atd. počet úrovní prohledávání je dán TTL uzly, které obsahují vyhledávané soubory odpoví

Počítačové sítě19 Gnutella Decentralizovaný Záplavové směrování „naslepo“ Záplavové dotazy v oblasti (TTL) Odpovědi posílány zpět podle cesty dotazu Výběr souboru ke stažení Přímé stažení z vybraného člena Nevýhoda - neefektivní

Počítačové sítě20 Gnutella decentralizované prohledávání odstraněn problém místa citlivého na chyby není tak citlivý na DoS nemůže zaručit správné výsledky záplavové dotazování prohledávání je distribuované, ale dosud ne škálovatelné Stahování pomocí HTTP GET request

Počítačové sítě21 Gnutella Zprávy Advertisement Query Push Request Formát zprávy Message ID (16) - párování Function ID (1) – typ TTL (1) Hops (1) Payload Length (4)

Počítačové sítě22 Kazaa (síť FastTrack) hybrid centralizované Napster a decentralizované Gnutella super-peer vystupují jako lokální centra vyhledávání každý super-peer je obdobou Napster serveru pro malou část sítě super-peer jsou vybírány systémem automaticky na základě jejich parametrů (paměť, šířka pásma,... ) a dostupnosti (čas pro připojení)

Počítačové sítě23 Kazaa (síť FastTrack) uživatelé přenesou svůj seznam souborů do super-peer super-peer si periodicky vyměňují seznam souborů uživatelé posílají dotazy do super-peer systém slouží ke sdílení souborů existuje možnost nesdílet data, pouze je stahovat

Počítačové sítě24 Anonymita P2P sítí Napster, Gnutella ani Kazaa nezajišťují anonymitu Uživatelé vědí kde co je a kdo co požaduje Freenet Navržen mimo jiné k zajištění anonymity

Počítačové sítě25 Freenet 6/1999 data jsou přenášena v opačném směru než dotaz není možné zjistit, je-li uživatel iniciátorem nebo pouze data přenáší dál není možné zjistit, jestli uživatel data posílá dál nebo je také spotřebovává chytré dotazy požadavky jsou směrovány do správného uzlu postupně

Počítačové sítě26 Freenet

Počítačové sítě27 Strukturované P2P sítě druhá generace P2P sítí samo organizující se struktura vyrovnávání zátěže odolné proti chybám založeno na distribuované hashovací tabulce

Počítačové sítě28 Distribuované hashovací tabulky DHT Distribuované hashovací tabulky (Distributed Hash Tables – DHT) distribuovaná verze hashovací tabulky (datová struktura) ukládá páry (klíč, hodnota) klíč je podobný jménu souboru hodnota může být obsah souboru cíl: efektivní vkládání, prohledávání, rušení párů (klíč, hodnota) každý uzel ukládá do systému podmnožinu párů (klíč, hodnota) základní operace: nalezení uzlu, který obsahuje klíč mapování klíčů na uzly efektivně směrovat požadavky vložení, prohledání, rušení do tohoto uzlu

Počítačové sítě29 Distribuované hashovací tabulky DHT Základní rozhraní DHT identifikátor uzlu (Node id): m-bitový identifikátor (obdoba IP adresy) klíč: posloupnost slabik hodnota: posloupnost slabik operace: put(key, value) – uložení do uzlu, odpovídajícímu klíči value=get(key) – obnovení hodnoty spojené s klíčem z odpovídajícího uzlu

Počítačové sítě30 Distribuované hashovací tabulky DHT Aplikace DHT nad rozhraním DTH mohou být realizovány služby sdílení souborů archivační složby databáze jmenné a adresářové služby chat publikování/čtení

Počítačové sítě31 Distribuované hashovací tabulky DHT Požadované vlastnosti DHT rovnoměrné mapování klíčů do všech uzlů sítě každý uzel udržuje informaci pouze o malém počtu uzlů efektivní směrování zpráv do uzlů připojení a odpojení uzlů ovlivní pouze malý počet uzlů

Počítačové sítě32 Distribuované hashovací tabulky DHT Směrovací protokoly DHT DHT rozhraní bylo realizováno v několika implementací Chord (MIT) Pastry (Microsoft Research UK, Rice University) Tapestry (UC Berkeley) CAN – Content Addressable Network (UC Berkeley) SkipNet (Microsoft research US, Univ. Of Washington) Kademlia (New York University) Viceroy (UC Berkeley) P-Grid (EPFL Switzerland) Freenet (Ian Clarke) Tyto systémy jsou často označovány jako P2P overlay networks

Počítačové sítě33 Chord Node id: unikátní m-bitový identifikátor (hash IP adresy, jiné unikátní ID) Klíč: m-bitový (160) identifikátor (hash sekvence slabik – SHA-1) Klíč – SHA-1 – ID IP adresa – SHA-1 - ID Hodnota: sekvence slabik API Insert(key, value) – uložení klíče a hodnoty do r uzlů Lookup(key) Update(key, newval) Join(n) Leave()

Počítačové sítě34 Chord Uzly jsou organizovány do kruhu identifikátorů Klíče jsou přiřazeny číselně následujícím uzlům Hashovací funkce zajišťuje distribuci uzlů i klíčů v kruhu

Počítačové sítě35 Chord Vyhledávací tabulka velikost tabulky O(logN)

Počítačové sítě36 Chord Vyhledávání hledání uzlu s číslem nejbližším vyšším než je hodnota klíče

Počítačové sítě37 Chord Vlastnosti v systému s N uzly a K klíči s vysokou pravděpodobností každý uzel obsahuje nanejvýš K/N klíčů každý uzel udržuje informaci o přibližně O(logN) jiných uzlech počet prohlížených uzlů závisí na O(logN) není zaručeno dodání výsledků není zaručena konzistentnost replik uzly v kruhu mohou být umístěny v síti kdekoliv (umístění bez vazby na síť)

Počítačové sítě38 Pastry Cambridge, Microsoft Obecná infrastruktura pro P2P aplikace Propojuje soubor uzlů Uzly mají přiřazeny ID (16B) Přenos zprávy do živého uzlu nejblíže klíči ROUTE(msg, key) Škálovatelné směrování O(log (N)) kroků Směrovací tabulky O(log (N)) položek Odolné proti chybám (přidání, ubrání uzlů) – automatické opravy

Počítačové sítě39 CAN CAN (Content-Addreable Network) založeno na d-dimenzionálním kartézském systému každý uzel vlastní odlišnou zónu v prostoru každý klíč je hashován na bod prostoru

Počítačové sítě40 CAN

Počítačové sítě41 Bit Torrent Bram Cohen Sdílení velkých souborů Dovoluje vytvářet repliky Jistá podoba s DFS Dělí soubor na mnoho kousků a podkousků (256KB/16KB) Replikace různých kousků na různých serverech Jakmile má člen kompletní soubor, nabízí jej ostatním Schopnost smontovat celý soubor z jednotlivých kousků z různých serverů (členů)

Počítačové sítě42 Základní komponenty Seed Člen, který vlastní celý soubor Leacher Člen, který má nekompletní kopii souboru Torrent Soubor obsahující Jméno a délku souboru Seznam SHA-1 hashů všech částí souboru kvůli verifikaci integrity Typicky se umisťuje na web server Obsahuje adresu Trackeru

Počítačové sítě43 Tracker Centralizovaný proces, který udržuje vazbu na členy (peers) Nedistribuuuje soubor, pouze obsahuje metadata Vrací náhodný seznam členů (max 50) Registruje členy a seznamy souborů (seed, leacher)

Počítačové sítě44 Fragmentace souborů Část (piece) souboru je dále dělena na podčásti (sub- peace) Dokud není část souboru přenesena, přenáší se podčásti pouze z této části Podporuje rychlou kompletaci části Výkonnost přenosu závisí na vhodném výběru členů, ze kterých se části stahují Je tendence decentralizovat zatížení Žádosti o části se posílají na více uzlů současně, duplicitní odpovědi se ruší – rozdělení zátěže