네트워크
[네트워크이론] 2.5 P2P 파일 분배
tbonelee
2024. 1. 1. 23:27
(Computer Networking a top-down Approach 책의 내용입니다)
- 항상 on인 서버가 필수 x
- 임의의 end system간의 통신
- 다른 피어에게 서비스를 요청하기도 하고, 다른 피어에게 대가로 서비스를 제공하기도 함
- self scalability : 새 피어의 추가는 서비스 capacity를 증가시키고 서비스 demands를 증가시킴
- 피어끼리 간헐적으로 연결되고 IP 주소도 바뀔 수 있음 -> 관리의 어려움
- examples :
- P2P file sharing (BitTorrent)
- Streaming (KanKan)
- VoIP (Skype)
Clinet-Server vs. P2P
- 가정
- 파일 크기 : $F$
- 서버의 업로드 속도 : $u_{s}$
- 클라이언트의 업로드 속도/다운로드 속도 : $u_{i}$, $d_{i}$
- 클라이언트-서버 구조에서 파일 하나를 $N$ 클라이언트 모두에게 배포하는데 걸리는 시간 $D_{C-S}$
- $d_{min} =$ min client download rate
- $$D_{C-S} \geq \max \left { NF/u_{s} , F/d_{min} \right } $$
- P2P 구조에서 파일 하나를 $N$ 클라이언트 모두에게 배포하는데 걸리는 시간 $D_{P2P}$
- $$ D_{P2P} \geq \max \left { F/u_{s} , F/d_{min} , NF / (u_{s} + \Sigma u_{i}) \right }$$
- $NF/(u_{s} + \Sigma u_{i})$ 에서 $N$이 커지면 $\Sigma u_{i}$ 도 커짐으로 어느정도 상쇄
BitTorrent
- 파일을 256Kb 청크로 분할
- torrent : 파일 청크를 교환하는 피어 그룹
- tracker : torrent에 참여하는 피어를 트래킹하는 노드
- 토렌트 안의 피어들이 청크를 수신/송신
- 갓 참여하게 되는 피어
- 당장은 청크를 갖고 있지 않지만 시간이 지남에 따라 다른 피어들로부터 받아서 축적하게 됨
- 트랙커에서 피어 목록을 받아서 일부에 연결하게 됨 ("neighbors")
- 각 피어는 다운로드와 동시에 다른 피어에게 청크를 업로드한다.
- 청크 요청 :
- 서로 다른 피어는 청크의 서로 다른 부분을 보유
- 하나의 피어는 주기적으로 다른 피어에게 그들이 가지고 있는 청크 목록을 요청
- 하나의 피어는 자신이 가지고 있지 않은 청크를 요청(가장 희소한 것부터)
- 청크 보내기 (Tit-for-tat) :
- 하나의 피어는 자신에게 가장 높은 속도로 보내주고 있는 피어 넷에게 청크를 보내준다.
- 나머지 피어에게는 보내지 않는다
- 매 10초마다 top4를 재평가
- 매 30초마다 나머지 피어 중 하나를 선택해서 청크를 보낸다
- "optimistically unchoke"
- 해당 피어가 top4 안에 들게 될 수도 있음
- ex)
- 1) A가 B를 "optimistically unchoke"
- 2) A가 B의 top4 providers가 됨 -> B가 보은
- 3) B가 A의 top4 providers가 됨
- 하나의 피어는 자신에게 가장 높은 속도로 보내주고 있는 피어 넷에게 청크를 보내준다.