Microsoft MVP성태의 닷넷 이야기
웹 다운로드에 대한 고찰 [링크 복사], [링크+제목 복사],
조회: 10592
글쓴 사람
HuuuZen (hugh-zen at kakao.com)
홈페이지
첨부 파일
[Private.zip]    

웹에 업로드되어 있는 특정 미디어를 다운로드 받는 컴포넌트 구현 중에 미디어 파일이 너무 큰 경우에 나눠서 다운로드 받는 방법에 대해서 고민을 해보고 있습니다.
HTTP header에 Content-Range 헤더 값을 이용하면 (만약 서버측에서 지원을 해준다면) 전체 사이즈를 알 수 있고 해당 C# HttpWebRequest의 AddRange 함수를 통해서 특정 부분만을 서버측으로 요청해서 받을 수 있다고 판단하여 충분히 나눠 받는게 빠를 거라고 생각했는데 실제 구현해보니 sigle task 기반의 내용이 더 빠르네요;;

좀 당황했습니다.

10기가가 넘어가는 웹 압축 파일로도 테스트를 해봤는데 결과는 sigledownloader.cs 내용의 코드가 빨랐습니다.

여러개의 Task에서 Header Range로 파트를 구분해서 HttpClient 여러개로 다운로드 받는다고 하더라도 실제 TCP 소켓은 하나로 처리되는 걸까요?








[최초 등록일: ]
[최종 수정일: 3/7/2023]


비밀번호

댓글 작성자
 



2023-03-07 05시07분
다운로드 시 서버 또는 클라이언트 측의 네트워크 용량을 모두 소비하지는 않나요? 동일하게 소비하는 상황이라면 단일 연결이 빠를 것입니다.

예를 들어, CPU 1개에 100% 소비하는 스레드를 1개로 작업하는 것과, 동일하게 무한루프를 도는 스레드를 2개로 작업하는 것은, 첫 번째가 더 빠른 것과 같습니다.

아마도, 네트워크 용량을 모두 소비하지 않는다면 나눈 경우가 더 빠를 것입니다.

---------------------

대개의 경우, 서버 측의 네트워크 용량이 부족할 것입니다. 가령 torrent 같은 경우 이런 문제를 다중 peer로부터 파일을 분할해서 받기 때문에 더 빠르게 동작합니다. torrent도 단일 peer로부터 받는 경우라면 마찬가지로 느릴 것입니다.
정성태
2023-03-07 06시04분
[HuuuZen] 서버측의 네트워크 용량의 문제일 수 있겠는데.. 결국 클라이언트에서 WebClient를 다중으로 만들어 여러 Task에서 수행을 하더라도 결국 서버측 ip와 port는 (http or https 프로토콜에 대한 포트는 고정) 하나 이기 때문에 C# instance만 여러 개일 뿐이지 결국 클라이언트 socket은 하나이고 해당 Window size에 따라서 서버측에서 Send 해주는거 아닌가요? ...
[guest]
2023-03-07 06시31분
소켓이 하나만 생성되는지 확인해보면 되지 않을까요. 어떻게 확인할 수 있을까요? ^^
정성태
2023-03-08 09시24분
[HuuuZen] netstat 툴로 pid 찍어서 확인해보니 클라이언트에 만들어진 소켓은 다르네요.. 클라이언트 쪽 IP는 같으나 PORT가 다르니...
착각을 좀 했네요.. 그렇다면 말씀하신 네트워크 용량은 송신측의 SOCKET Window size가 아닌 네트워크 bandwidth를 이야기 하시는 걸까요?
[guest]
2023-03-08 09시26분
넵, 아마 그렇지 않을까 싶습니다. 테스트를 하고 계시니 원인을 가장 잘 파악하실 수 있을 것입니다.
정성태

... 16  17  18  19  20  21  22  23  24  [25]  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
5331sdd5/13/202014960안녕하세요 Settings관련하여 질문드립니다. [2]파일 다운로드1
5330하태5/7/202019956안녕하세요! 질문 드리겠습니다! C# dll에서 c++ CLR프로젝트를 참조 추가 할 수 있나요? [2]
5329김태령4/21/202014597젠킨스에서 원격 머신에 있는 실행 파일을 실행하면 백그라운드로 뜹니다 [2]
5328crea...4/17/202014649안녕하세요! [3]파일 다운로드1
5327김동욱4/17/202015782HttpListener 사용시 HTTP/2 질문입니다. [2]
5323나그네4/15/202014980해결 115p 네임스페이스의 ConsoleApp1.exe는 netcoreapp3.1 폴더에 있었습니다. [1]파일 다운로드1
5322나그네4/14/202014783질문 115p 네임스페이스의 ConsoleApp1.exe 컴파일 또는 빌드방법 [2]파일 다운로드1
5321나그네4/14/202016869오타인가요? [2]
5320kiki...4/10/202020204C# Serial 통신 관련 질문 입니다. [5]
5319권대현4/10/202015193C++(UWP)Dll에서 C#(UWP)Dll 호출이 가능한가요? [1]
5318이승준4/9/202016451동영상 관련 업계 근황? 입니다. [1]
5317kskk...4/7/202018640OpenCV 이용 해상도 설정 질문 입니다.. [3]
5316윤현수4/7/202015115pipe 비동기방식 질문 [1]파일 다운로드1
53154/6/202015802dll파일 로드 원리? 부분에서 도움받고싶습니다. [3]
5314강성욱3/31/202018397메서드 내에서 await 2번 등장할 때의 이해 [11]파일 다운로드1
5313강성욱3/27/202015931await 2번 [1]
53121a2a...3/20/202014702Re raw data write 질문 관련 [1]파일 다운로드1
53111a2a...3/20/202017119Raw data write 관련 질문 [1]파일 다운로드1
5310아스파넬3/15/2020169771초에 5회 함수호출 제한 관련 질문입니다. [1]
5309하태3/11/202018905안녕하십니까. c# Winform UI 질문드리겠습니다! [3]파일 다운로드1
5308질문3/9/202017777Window XP SP3 32bit 환경(Window Update 모두 완료)에서 .Net Framework 4.0.3 으로 빌드된 .dll 파일 gacutil.exe 등록 관련 문의 [5]
5306개발자3/9/202017149C#을 통해 인터넷 접속 가능한 이더넷을 선택할 수 있는지요? [1]
5305JaeS...3/9/202015619RAW파일 생성 질문드립니다 [8]파일 다운로드1
5303궁금하당2/27/202018762C#에서 C++ DLL읽기 (아래 글쓴이) [1]
5302궁금하당2/27/202020776C#에서 C++ DLL호출 ('PInvokeStackImbalance') [4]파일 다운로드1
5301질문합니...2/27/202015323소켓 대량 데이터 디자인 문의 [1]
... 16  17  18  19  20  21  22  23  24  [25]  26  27  28  29  30  ...