> 백엔드 개발 > Golang > Go 스케줄러는 언제 새로운 M과 P를 생성합니까?

Go 스케줄러는 언제 새로운 M과 P를 생성합니까?

王林
풀어 주다: 2024-02-06 09:00:09
앞으로
897명이 탐색했습니다.

Go 스케줄러는 언제 새로운 M과 P를 생성합니까?

질문 내용

golang GMP 모델을 배웠으니 이제 고루틴, 운영체제 스레드, golang 컨텍스트/프로세서가 어떻게 서로 협력하는지 이해했습니다. 그런데 M과 P가 언제 생성될지 아직도 이해가 안 가시나요?

예를 들어 데이터베이스에서 일부 작업을 실행하는 테스트 코드가 있고 두 가지 테스트 사례(두 개의 고루틴 배치)가 있습니다.

으아아아

제가 이해한 바에 따르면 M은 필요할 때 생성됩니다. 첫 번째 고루틴 배치에서는 8개(내 컴퓨터의 가상 코어 수) 운영 체제 스레드가 생성되고, 두 번째 배치에서는 새 스레드를 생성하지 않고 이 8개의 운영 체제 스레드만 재사용합니다. 이 올바른지?

이 주제에 대한 더 많은 자료나 블로그를 제공해 주시면 감사하겠습니다.


정답


M은 프로세스가 차단되지 않거나 시스템 호출이 없는 경우에만 재사용할 수 있습니다. 귀하의 경우 go func()에 차단 작업이 있습니다. 따라서 M의 수는 8(내 컴퓨터의 가상 코어 수)로 제한되지 않습니다. 첫 번째 배치는 P에서 차단 및 제거되며 P와 관련된 새 M이 생성되는 동안 차단 프로세스가 완료될 때까지 기다립니다.

자세한 내용은 아래를 참고해주세요

위 내용은 Go 스케줄러는 언제 새로운 M과 P를 생성합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:stackoverflow.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿