5. P2P 파일 분배

2023. 3. 22. 16:56·컴퓨터 네트워크/Ch2. 애플리케이션 계층
Reference :
컴퓨터 네트워킹 하향식 접근 [8판] / 퍼스트 북 / James F. Kurose, Keith W. Ross
건국대학교 컴퓨터 네트워크 수업 / 김기천 교수님

피어는 서비스 제공하자 소유하는 것이 아니라 사용자가 제어하는 데스크톱과 랩톱이 소유한다

각 피어는 수신한 파일의 임의의 부분을 다른 피어들에게 재분배ㄱㄴ⇒서버의 분배 프로세스 도울 수

예시) 비트토렌트

비트토렌트는 P2P 파일 전송 프로토콜의 이름이자 그것을 이용하는 응용 소프트웨어의 이름이다. 비트토렌트를 이용하면 파일을 인터넷 상에 분산하여 저장하여 놓고 다수의 접속을 사용하여 여러 곳에서 동시에 파일을 가져오게 되어 전송 속도가 빨라진다

구글 독스나 스프레드시트는 SaaS(Software as a Service) 방식!

 

P2P는 SaaS와 다르게 서버가 없이도 파일을 제공하는 PC와 파일을 전송 받을 PC만 있으면 파일 전송이 가능

P2P 구조의 확장성 -클라이언트-서버 구조와의 비교를 통해서..

$u_s$: 서버의 접속 링크 업로드 속도

$u_i$: i번째 피어의 접속 링크 업로드 속도

$d_i$: i번째 피어의 접속 링크 다운로드 속도

$F$: 분배되는 파일의 크기

$N$: 파일의 복사본을 얻고자 하는 피어들의 수

모든 병목 현상은 네트워크 접속 부분에 있다고 가정

  • 클라이언트-서버 구조 분배시간: $D_(cs)$
    • 서버는 파일 복사본을 N개의 피어 각각에게 전송해야 한다
    • 따라서 서버는 NF 비트를 전송해야 한다
    • 서버의 업로드 속도가 $u_s$이기 때문에 파일을 분배하는 시간: NF/$u_s$이다.
    • $d_(min)$: 가장 낮은 다운로드 속도를 가진 피어의 다운로드 속도
    • $d_(min)$=min{d1,d2,...$d_N$} ⇒ 최소 분배 시간은 적어도 F/$d_(min)$
    • Dcs=max{NFus,Fdmin}
  • P2P 구조
    • 최소 분배 시간: F/$u_s$ ⇒ 서버가 한 번 보낸 비트는 서버가 다시 보낼 필요가 없는데, 이는 클라이언트-서버와 달리 피어들이 그들 사이에 이 비트를 재분배할 수 있기 때문이다.
    • 클라이언트-서버 구조와 마찬가지로 최소 분배 시간은 적어도 F/$d_(min)$
    • 시스템의 전체 업로드 용량=서버의 업로드 속도 + 각 피어들의 업로드 속도
    • $u_(total)$=$u_s$+$u_1$+...+$u_N$
    • 최소분배 시간=NF/($u_s$+$u_1$+...+$u_N$)
DP2P=max{Fus,Fdmin,NFus+∑i=1Nui}

 

비트토렌트

  • 용어
    • 토렌트: 특정 파일의 분배에 참여하는 모든 피어들의 모임
    • 청크: 토렌트에 참여하는 피어들이 다운로드하는 것
  • 과정
    • 각 토렌트는 트랙커라고 부르는 기반구조 노드를 갖고 있다.
    • 한 피어가 토렌트에 가입할 때 트랙커에 자신을 등록하고 주기적으로 자신이 아직 토렌트에 있음을 알린다.
      • 새로운 피어가 토렌트에 가입할 때 트랙커는 참여하고 있는 피어 집합에서 임의로 피어들의 부분집합 50개를 선택하여 이들 50개 피어들의 IP주소를 새로운 피어에게 보내낸다.
      • 새로운 피어는 이 리스트에 있는 모든 피어들과 동시에 TCP 연결을 설정한다.
      • 연결한 피어들을 ‘이웃피어’라고 부르자.
      • 시간이 지나면서 이들 중 일부는 떠나고 다른 피어들이 TCP 연결을 시도한다.
      • 이러한 방식으로 트랙커는 토렌트에 참여하는 피어들을 추적한다.
  • 청크
    • 이웃으로부터 어느 청크를 먼저 요구할 건지?
    • 이웃들 중 어느 피어에게 청크를 요청할 건지? ⇒ 가장 드문 것 먼저!
저작자표시 (새창열림)

'컴퓨터 네트워크 > Ch2. 애플리케이션 계층' 카테고리의 다른 글

7. 소켓 프로그래밍: 네트워크 애플리케이션 생성  (0) 2023.03.22
6. 비디오 스트리밍과 콘텐츠 분배 네트워크  (0) 2023.03.22
4. DNS: 인터넷의 디렉터리 서비스  (2) 2023.03.22
3. 인터넷 전자메일  (1) 2023.03.22
2. 웹과 HTTP  (0) 2023.03.22
'컴퓨터 네트워크/Ch2. 애플리케이션 계층' 카테고리의 다른 글
  • 7. 소켓 프로그래밍: 네트워크 애플리케이션 생성
  • 6. 비디오 스트리밍과 콘텐츠 분배 네트워크
  • 4. DNS: 인터넷의 디렉터리 서비스
  • 3. 인터넷 전자메일
smile blog
smile blog
건국대 첨단바이오공학부 & 컴퓨터공학부 BT & IT 기술로 희망을 꿈 꿉니당
  • smile blog
    스마일 블로그
    smile blog
  • 전체
    오늘
    어제
    • 분류 전체보기 (820) N
      • 일상 생각들 (2)
      • 학과에 대해 (4)
        • 첨단바이오공학부 (4)
        • 컴퓨터공학부 (0)
      • -------- 프로젝트 -------- (0)
      • [DS] 토이 프로젝트 (1)
      • [Web, Game, XR] 토이 프로젝트 (11)
      • 경진대회 (1)
      • -------- 진로 -------- (0)
      • 생물정보학자 (18)
        • 데이터 과학이란? (0)
        • 되는 방법 (8)
        • 책 추천 (2)
        • 인강 (1)
        • 대학 (2)
        • 회사 (1)
        • 학원 (2)
        • 학회 (2)
      • 디지털 헬스케어 (72)
        • 방법 (8)
        • 생각들 (10)
        • 공부법 (4)
        • 책 추천 (2)
        • 학원 (2)
        • 참고 (2)
        • 대학 (3)
        • 회사 (3)
        • 인강 (2)
        • 게임 엔진들 (1)
        • 게임 프로그래머 개론 (2)
        • 게임 프로그래머 취업 전략 가이드 (7)
        • 취업 서류 (1)
        • 애정하는 게임들 (4)
        • XR 테크니컬 아티스트 (9)
        • 영화, 애니메이션 테크니컬 디렉터 (12)
      • -------- 기초 학문 -------- (0)
      • 생명과학 이야기 (2)
        • 대학 강의 (2)
      • 화학 이야기 (0)
      • 컴퓨터과학 이야기 (0)
      • 통계학 이야기 (0)
      • 수학 이야기 (1)
        • 공학 수학 (1)
      • 영어 이야기 (1)
      • 심리학 이야기 (7)
        • 현대인과 정신건강 (7)
      • -------- 컴퓨터 언어 -------- (0)
      • Python (3)
        • 나도코딩의 파이썬 입문 (1)
        • 파이썬 관련 정보 (1)
      • SQL (0)
      • C 언어 (32)
        • 혼자 공부하는 C언어 요약 (1)
        • [책 정리] 혼자 공부하는 C언어 (31)
      • C++ (33)
        • 명품 C++ 프로그래밍 요약 (1)
        • [책 정리] 명품 C++ 프로그래밍 (27)
        • C++ STL (0)
        • 뇌를 자극하는 C++ STL (5)
      • -------- 생명과학 -------- (0)
      • 생화학 (5)
        • 대학 강의 (5)
      • 분자세포생물학 (3)
        • 대학 강의 (3)
      • 유전자치료공학 (2)
        • 대학 강의 (2)
      • 생명정보학 (5)
        • 대학 강의 (5)
      • 약리학 (2)
        • 대학 강의 (2)
      • -------- 컴퓨터과학 -------- (0)
      • 자료구조와 알고리즘 (8)
        • 자료구조와 알고리즘의 정의 (3)
        • [책 정리] C언어로 쉽게 풀어쓴 자료구조 요약 (1)
        • [인강] 자료구조와 알고리즘 (2)
        • 코딩 테스트 대비하기! (1)
      • 컴퓨터 회로 (0)
      • 컴퓨터 구조 (43)
        • 컴퓨터 구조와 운영체제 요약 (1)
        • ---------------------------------------- (0)
        • [전공 책 정리] 컴퓨터 구조 및 설계 (1)
        • Ch1. 컴퓨터 추상화 및 관련 기술 (8)
        • Ch2. 명령어 : 컴퓨터 언어 (11)
        • Ch3. 컴퓨터 연산 (8)
        • Ch4. 프로세서 (11)
        • Ch5. 메모리 계층구조 (3)
        • Ch6. 병렬 프로세서 : 클라이언트에서 클라우드까지 (0)
      • 시스템 프로그래밍 (15)
        • [책 정리] 시스템 프로그래밍 유닉스 & 리눅스 (0)
        • [인강] 리눅스 시스템 프로그래밍 (2)
        • 리눅스에서 코딩이란? (8)
        • 대학교 강의 정리 (5)
      • 운영체제 (0)
      • 컴퓨터 네트워크 (37)
        • 모두의 네트워크 요약 (1)
        • [책 정리] 모두의 네트워크 (10)
        • ---------------------------------------- (0)
        • [전공 책 정리] 컴퓨터 네트워킹 하향식 접근 8판 (1)
        • Ch1. 컴퓨터 네트워크와 인터넷 (7)
        • Ch2. 애플리케이션 계층 (7)
        • Ch3. 트랜스포트 계층 (8)
        • Ch4. 네트워크 계층 : 데이터 평면 (3)
        • Ch5. 네트워크 계층 : 제어 평면 (0)
        • Ch6. 링크 계층과 근거리 네트워크 (0)
        • Ch7. 무선 및 이동 네트워크 (0)
        • Ch8. 컴퓨터 네트워크 보안 (0)
      • 데이터베이스 (1)
      • -------- 데이터과학 -------- (0)
      • 데이터 사이언스 (8)
        • 인강 (8)
      • 데이터 분석 (2)
        • 인강 (2)
      • 머신러닝 (2)
        • 대학 수업 (2)
      • 인공지능 (11)
        • 대학교 강의 정리 (10)
        • 인공지능 관련 정보 (1)
      • -------- +a -------- (0)
      • Visual Studio Community (7)
        • 설치법 (1)
        • 단축키 (1)
        • 오류 (5)
      • Visual Studio Code (0)
      • 노션 (1)
      • 깃허브 (7)
        • 깃허브 사용법 (5)
        • 유니티, 언리얼 & 깃허브 (1)
        • 깃허브 주의사항 (1)
      • 챗GPT 활용법 (0)
      • 기타 feat. 프로그래밍 (7)
        • 프로그래머로 살아남기 (5)
        • 코딩 vs 프로그래밍 (1)
        • 애플 비전 프로 (1)
      • 메타버스 (5)
      • -------- 예술 -------- (0)
      • 음악 (1)
      • 미술 (0)
      • -------- XR -------- (0)
      • 유니티 이야기 (23)
        • 레트로의 유니티 게임 프로그래밍 에센스 요약 (4)
        • 유니티 관련 정보 (1)
        • 유니티 디버깅 (13)
        • 유니티 인강 (3)
        • 대학교 게임 프로그래밍 강의 (2)
      • 언리얼 이야기 (0)
        • 인생 언리얼 교과서 요약 (0)
      • 컴퓨터 그래픽스 (6)
        • OpenGL (6)
      • 가상현실 & 증강현실 (4)
        • 유니티 vr (4)
      • HCI 와 UI UX (7)
        • [책 정리] HCI 개론 (6)
      • -------- Design -------- (0)
      • 캐릭터 (1)
        • 모델링 (0)
        • 리깅 (1)
      • 포토샵 (3)
      • 3ds Max (7)
      • Maya (9)
        • 블로그 (1)
        • 인강 (6)
        • 대학교 (2)
      • Blender (14)
        • 책 (1)
        • 인강 (7)
        • 기타 (3)
        • 대학교 (3)
      • 아트 작업물들 (2)
      • 에셋 사이트 (1)
      • -------- 건강관리 -------- (0)
      • 건강관리 ft. 정현 (12)
        • 목 디스크 (2)
        • 눈 관리 (2)
        • 일상생활 습관 (6)
        • 일상생활 꿀팁 (2)
        • 사무직 꿀팁 (0)
      • 헬스의 정석 ft. 정현 (28)
        • 헬스와 건강 (8)
        • 헬스 구체화 정보 (6)
        • 헬스 유튜버 (1)
        • 헬스 서적 (1)
        • 도전 바디프로필! (11)
        • 헬스장 패션 (1)
      • -------- etc -------- (0)
      • 진로 관련 잡다한 글들 (34)
        • 진도율 (9)
        • 진로 관련 글들 (15)
        • 학교 강의 관련 글들 (10)
      • 인생 꿀 Tip (23)
        • 컴퓨터 초기 설정 (9)
        • 원격 데스크톱 (1)
        • 노트북 발열 (1)
        • 전자기기 (2)
        • 중고기기 팔기 (1)
        • 아이패드 필기 어플 (1)
        • 에어팟 (1)
        • 커피 (1)
        • 맥북 (1)
        • lg 그램 (1)
        • 검색엔진에서 내 티스토리 검색 (1)
        • hELLO 다크 모드 없애기 (1)
        • 인터넷 연결 문제 (1)
        • 키보드 문제 해결 (1)
      • 유튜브 (3)
      • 청춘 그리고 추억 (1)
      • 인생 계획표 (2)
        • 2024년 2학기 (1)
        • 2024년 여름방학 (0)
        • 2024년 1학기 (0)
        • 2023년 겨울방학 (1)
      • 다양한 글들 (98)
        • C++ STL (6)
        • Win32 API (24)
        • PushPush 게임 (13)
        • 컴퓨터구조 (1)
        • 자료구조와 알고리즘 (50)
        • 게임의 정의 (3)
        • 영상 회사 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

    • Dream
    • 코딩을 시작한 이유
    • 나를 소개합니다!
    • 블로그 공부법
    • IT & 가치 있는 일들
  • 인기 글

  • 태그

    unity
    AI
    건국대
    의생명공학
    유니티
    컴퓨터구조
    함수
    리눅스
    명령어
    데이터사이언스
    블렌더
    자료구조
    C++ STL
    C++
    인공지능
    알고리즘
    첨단바이오공학부
    C언어
    생명공학
    데이터과학
    코드잇
    심리학
    컴퓨터 네트워크
    포인터
    배열
    연산자
    생물정보학
    리눅스 터미널
    의생명공학과
    스택
  • 최근 댓글

  • hELLO· Designed By정상우.v4.10.3
smile blog
5. P2P 파일 분배
상단으로

티스토리툴바