다가오는 리눅스 6.13 릴리스는 작업 스케줄링에서 우선 순위 상속을 향상시키기 위한 방법인 프록시 실행을 구현하기 위한 준비 패치를 포함할 예정입니다. 프록시 실행은 작업의 스케줄러 컨텍스트(스케줄링 클래스와 우선 순위를 포함)와 실행 컨텍스트(실제 실행 매개변수, 예: CPU 친화성)를 구분합니다. 이 기능을 통해 뮤텍스에 의해 차단된 작업은 실행 대기열에 남아 있을 수 있으며, 잠금 소유자는 차단된 작업의 스케줄러 컨텍스트를 상속받으면서 그를 대신해 실행할 수 있습니다. 그러나 실행 컨텍스트는 여전히 구분되므로, 잠금 소유자의 CPU 친화성이 실행 위치를 결정합니다.
프록시 실행의 구현은 뮤텍스 소유자가 차단되거나 다른 상태에 있을 때와 같은 더 복잡한 시나리오를 초래할 수 있으며, 이는 스케줄링 결정에 영향을 미칠 수 있습니다. 현재 패치 시리즈는 검토 단계에 있으며, 더 복잡한 프록시 실행의 측면을 다루기 전에 더 간단한 패치를 통해 진행하는 것을 목표로 하고 있습니다. 이 개발은 리눅스 커널의 작업 스케줄링 효율성을 개선하기 위한 지속적인 노력의 일환으로, 멀티스레드 환경에서 성능에 매우 중요합니다.
* 이 글은
phoronix.com의 기사를 요약한 것입니다. 전체 기사의 내용은
이곳에서 확인하실 수 있습니다.