Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

제니퍼: 9. 성능 관리 퀴즈 세 번째 문제 (닷넷 개발자 컨퍼런스)


제니퍼: 7. 성능 관리 퀴즈 첫 번째 문제 (닷넷 개발자 컨퍼런스)
; https://www.sysnet.pe.kr/2/0/875

제니퍼: 8. 성능 관리 퀴즈 두 번째 문제 (닷넷 개발자 컨퍼런스)
; https://www.sysnet.pe.kr/2/0/876

위의 문제에 이어서!




[퀴즈 3] 왜 100개까지만 요청이 제한되는가?


ASP.NET으로 웹 페이지를 하나 만들고, 코드는 단지 "Thread.Sleep(20 * 1000);"만 넣은 상태입니다. 클라이언트 응용 프로그램에서는 스레드 120개를 만들어서 해당 웹 페이지에 요청을 동시에 보냅니다.

이때 ASP.NET을 호스팅하는 환경은 "Windows 서버 + IIS 6/7/7.5 + CLR 2.0"입니다.

정상적이라면 120개 정도의 동시 요청이 처리되고 있어야 하는데, 확인해 보면 100까지만 동시 요청이 처리됩니다. 그 이유는? (환경만 일치한다면, 직접 확인해 보실 수 있습니다.)




위의 문제들에서 알 수 있는 점은, 기본 상태의 윈도우 서버 시스템에서 처리가 긴 작업(Long-running process)이 일시에 몰리는 경우 해당 시스템이 그 이상의 작업을 할 수 있는데도 불구하고 서비스가 제한된다는 것을 보여주고 있습니다.

물론, 스레드가 100개 이상이 될 수 있도록 시스템을 만드느냐에 대해서는 고려 사항이 있을 수 있습니다. 단지 여기서 중요한 점은, 서버가 적절하게 모니터링 되고 있어야 그에 대한 적절한 판단을 할 수 있다는 점입니다.

모니터링하고 있는 시스템이 공유 리소스에 대한 접근을 하는 aspx들에 대한 요청이 몰리게 되고 잠금으로 인해 시간이 걸리는 상황에서는 100개까지의 제한을 둘 필요는 없습니다. 왜냐하면, 공유 리소스를 접근하지 않는 다른 aspx 페이지들까지도 요청을 못 받아들이기 때문입니다. (혹은, 제니퍼의 PLC(Peak Load Control) 기능같은 방법도 해결책이 될 수 있습니다.)

혹시, 지금 여러분들의 웹 서버를 한 대 더 늘려야겠다고 판단하고 계시지 않은가요?
그렇다면, 정말 그 웹 서버를 늘려야 할 이유가 어떤 것인지 정확하게 모니터링이 된 걸까요?







[최초 등록일: ]
[최종 수정일: 6/12/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 76  77  78  [79]  80  81  82  83  84  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
11961정성태6/27/201917869Graphics: 37. C# - PLplot - 출력 모음(Family File Output)
11960정성태6/27/201918972Graphics: 36. C# - PLplot의 16색 이상을 표현하는 방법과 subpage를 이용한 그리드 맵 표현
11959정성태6/27/201920130Graphics: 35. matplotlib와 PLplot의 한글 처리
11958정성태6/25/201924677Linux: 18. C# - .NET Core Console로 리눅스 daemon 프로그램 만드는 방법 [6]
11957정성태6/24/201922991Windows: 160. WMI 쿼리를 명령행에서 간단하게 수행하는 wmic.exe [2]
11956정성태6/24/201921523Linux: 17. CentOS 7에서 .NET Core Web App 실행 환경 구성 [1]
11955정성태6/20/201919815Math: 60. C# - 로지스틱 회귀를 이용한 분류파일 다운로드1
11954정성태6/20/201918560오류 유형: 550. scp - sudo: no tty present and no askpass program specified
11953정성태6/20/201916782오류 유형: 549. The library 'libhostpolicy.so' required to execute the application was not found in '...'
11952정성태6/20/201917461Linux: 16. 우분투, Centos의 Netbios 호스트 이름 풀이 방법
11951정성태6/20/201920631오류 유형: 548. scp 연결 시 "Permission denied" 오류 및 "WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!" 경고
11950정성태6/18/201920843.NET Framework: 845. C# - 윈도우 작업 관리자와 리소스 모니터의 메모리 값을 구하는 방법
11949정성태6/18/201916179오류 유형: 547. CoreCLR Profiler 예제 프로젝트 빌드 시 컴파일 오류 유형
11948정성태6/17/201918603Linux: 15. 리눅스 환경의 Visual Studio Code에서 TFS 서버 연동
11947정성태6/17/201920326Linux: 14. 리눅스 환경에서 TFS 서버 연동
11946정성태6/17/201921301개발 환경 구성: 445. C# - MathNet으로 정규 분포를 따르는 데이터를 생성, PLplot으로 Histogram 표현파일 다운로드1
11945정성태6/17/201919065Linux: 13. node.js에서 syslog로 출력하는 방법
11944정성태6/16/201925419Linux: 12. Ubuntu 16.04/18.04에서 node.js 최신 버전 설치 방법
11943정성태6/15/201918665.NET Framework: 844. C# - 박싱과 언박싱 [1]
11942정성태6/13/201924872개발 환경 구성: 444. 로컬의 Visual Studio Code로 원격 리눅스 머신에 접속해 개발하는 방법 [1]
11941정성태6/13/201917556오류 유형: 546. "message NETSDK1057: You are using a preview version of .NET Core" 빌드 경고 없애는 방법
11940정성태6/13/201917830개발 환경 구성: 443. Visual Studio의 Connection Manager 기능(Remote SSH 관리)을 위한 명령행 도구파일 다운로드1
11939정성태6/13/201916579오류 유형: 545. Managed Debugging Assistant 'FatalExecutionEngineError'
11938정성태6/12/201919136Math: 59. C# - 웨이트 벡터 갱신식을 이용한 퍼셉트론 분류파일 다운로드1
11937정성태6/11/201925460개발 환경 구성: 442. .NET Core 3.0 preview 5를 이용해 Windows Forms/WPF 응용 프로그램 개발 [1]
11936정성태6/10/201918407Math: 58. C# - 최소 자승법의 1차, 2차 수렴 그래프 변화 확인 [2]파일 다운로드1
... 76  77  78  [79]  80  81  82  83  84  85  86  87  88  89  90  ...