Microsoft MVP성태의 닷넷 이야기
Windows: 42. Concurrency Runtime [링크 복사], [링크+제목 복사],
조회: 20236
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Concurrency Runtime and Windows 7
; http://blogs.msdn.com/nativeconcurrency/archive/2009/02/04/concurrency-runtime-and-windows-7.aspx

64개 이상의 프로세서를 지원하는 것과 사용자 모드 스케쥴러에 대한 개략적인 설명을 해주고 있습니다.

64개 이상의 프로세서 지원은, CPU를 그룹별로 나누어서 구현을 하는 식이어서 명시적으로 그룹을 지정하지 않게 되면 결국 하나의 그룹에 할당되어 64개 제한을 받게 된다고 합니다. 제가 생각해도 ... 명시적으로 그룹을 지정하는 것은 꽤나 번거로운 일이 될 것 같은데요. 다행히도 이런 작업을 이미 "Concurrency Runtime"에서 제공개 준다고 합니다. 즉, CR 기반으로 응용 프로그램을 작성하게 되면 Runtime 레벨에서 CPU 그룹을 지정해 주기 때문에 256개까지의 CPU를 사용할 수 있다는 이야기입니다.

UMS는 더 재미있는데요. ^^
Windows 7에서는 CR 기반으로 작성된 응용 프로그램은 스케쥴링을 사용자 모드에서도 가능하게 해주고 있습니다. UMS 레벨에서 다음 활성화될 태스크를 지정하기 때문에 더욱 빠르게 작업 간의 스위칭이 가능하게 만들었다고 합니다. 결국, 커널 스레드는 OS로부터 할당된 퀀텀만큼의 시간을 제대로 활용하게 되고, 그 커널 스레드에서 사용자 모드 스레드가 자유롭게 스위칭이 발생하는 것입니다.

음... 다중 프로세스 간에는 안 될 것 같고, 아마도 단일 프로세스에서 다중 스레드를 사용하는 응용 프로그램들의 성능이 더욱 좋아질 것으로 보입니다.

참고로, 다음의 문서도 공개되어 있습니다.

"Supporting Systems That Have More Than 64 Processors"
; http://download.microsoft.com/download/a/d/f/adf1347d-08dc-41a4-9084-623b1194d4b2/MoreThan64proc.docx








[최초 등록일: ]
[최종 수정일: 4/10/2022]

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

비밀번호

댓글 작성자
 




... 31  32  33  34  35  36  [37]  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
13016정성태3/27/202216025.NET Framework: 1183. C# 11에 추가된 ref 필드의 (우회) 구현 방법파일 다운로드1
13015정성태3/26/202217768.NET Framework: 1182. C# 11 - ref struct에 ref 필드를 허용 [1]
13014정성태3/23/202215142VC++: 155. CComPtr/CComQIPtr과 Conformance mode 옵션의 충돌 [1]
13013정성태3/22/202212918개발 환경 구성: 641. WSL 우분투 인스턴스에 파이썬 2.7 개발 환경 구성하는 방법
13012정성태3/21/202212537오류 유형: 803. C# - Local '...' or its members cannot have their address taken and be used inside an anonymous method or lambda expression
13011정성태3/21/202216005오류 유형: 802. 윈도우 운영체제에서 웹캠 카메라 인식이 안 되는 경우
13010정성태3/21/202212715오류 유형: 801. Oracle.ManagedDataAccess.Core - GetTypes 호출 시 "Could not load file or assembly 'System.DirectoryServices.Protocols...'" 오류
13009정성태3/20/202215342개발 환경 구성: 640. docker - ibmcom/db2 컨테이너 실행
13008정성태3/19/202214988VS.NET IDE: 176. 비주얼 스튜디오 - 솔루션 탐색기에서 프로젝트를 선택할 때 csproj 파일이 열리지 않도록 만드는 방법
13007정성태3/18/202213329.NET Framework: 1181. C# - Oracle.ManagedDataAccess의 Pool 및 그것의 연결 개체 수를 알아내는 방법파일 다운로드1
13006정성태3/17/202215764.NET Framework: 1180. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 remuxing.c 예제 포팅
13005정성태3/17/202214070오류 유형: 800. C# - System.InvalidOperationException: Late bound operations cannot be performed on fields with types for which Type.ContainsGenericParameters is true.
13004정성태3/16/202213581디버깅 기술: 182. windbg - 닷넷 메모리 덤프에서 AppDomain에 걸친 정적(static) 필드 값을 조사하는 방법
13003정성태3/15/202213871.NET Framework: 1179. C# - (.NET Framework를 위한) Oracle.ManagedDataAccess 패키지의 성능 카운터 설정 방법
13002정성태3/14/202215476.NET Framework: 1178. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 http_multiclient.c 예제 포팅
13001정성태3/13/202216087.NET Framework: 1177. C# - 닷넷에서 허용하는 메서드의 매개변수와 호출 인자의 최대 수
13000정성태3/12/202215048.NET Framework: 1176. C# - Oracle.ManagedDataAccess.Core의 성능 카운터 설정 방법
12999정성태3/10/202214850.NET Framework: 1175. Visual Studio - 프로젝트 또는 솔루션의 Clean 작업 시 응용 프로그램에서 생성한 파일을 함께 삭제파일 다운로드1
12998정성태3/10/202213299.NET Framework: 1174. C# - ELEMENT_TYPE_FNPTR 유형의 사용 예
12997정성태3/10/202222470오류 유형: 799. Oracle.ManagedDataAccess - "ORA-01882: timezone region not found" 오류가 발생하는 이유
12996정성태3/9/202223845VS.NET IDE: 175. Visual Studio - 인텔리센스에서 오버로드 메서드를 키보드로 선택하는 방법
12995정성태3/8/202216230.NET Framework: 1173. .NET에서 Producer/Consumer를 구현한 BlockingCollection<T>
12994정성태3/8/202215259오류 유형: 798. WinDbg - Failed to load data access module, 0x80004002
12993정성태3/4/202214986.NET Framework: 1172. .NET에서 Producer/Consumer를 구현하는 기초 인터페이스 - IProducerConsumerCollection<T>
12992정성태3/3/202217966.NET Framework: 1171. C# - BouncyCastle을 사용한 암호화/복호화 예제파일 다운로드1
12991정성태3/2/202215722.NET Framework: 1170. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 transcode_aac.c 예제 포팅
... 31  32  33  34  35  36  [37]  38  39  40  41  42  43  44  45  ...