리눅스 커널 구조와 원리 책중에서 궁금한게 있어서 질문 합니다.
글쓴이: teaeune / 작성시간: 월, 2008/10/27 - 8:17오후
workqueue에 대해서 궁금 한것이 있는데요.
책에서 설명 하길 프로세스 컨텍스트처리를 지연 시키기 위해서 이용 한다고 되어 있는데요.
정말 궁금 한것이
질문 1. 컨테스트의 지연이 필요한 경우가 무엇이 있나요?
질문 2. workqueue를 사용하는 윈도우에서 메시지를 큐에 담은거와 같은 이유인가요?
큐를 사용한다고 속도 면에서 좋아 지지는 않지않나요? 단지 안정적으로 순차적으로 처리가 가능
하다는 것이 장점이 될수 있나요?
Forums:
workqueue 는 2.4커널
workqueue 는 2.4커널 시절에 taskqueue 로 불리던 놈입니다.
이름뿐만 아니라 내부적인 구현도 변하고 좀 더 편리하게 바뀌었습니다. API 도 여러 개 추가됐고요.
전담 커널 쓰레드에서 순차적으로 호출되기 때문에 스케쥴링에 관계된 부분의 접근이 자유롭습니다.
책에서 말한 컨텍스트 지연이라는 말은 스케쥴 변경 정도로 이해하세요.
구체적인 예라면... mutex lock 이나 semaphore lock, event poll 등이 대표적인 예가 되겠네요.
'순차적으로 호출'은 목적이 아니라 결과일 뿐입니다. 메시지큐와는 비슷하지도 않은 물건입니다.
'순차적으로 호출' 이라는 것에 개발자로써의 주의점이 있다면,
어떤 work 의 handler 에 발생하는 지연은 다른 work 에게도 영향을 준다는 것.
예를 들어 어떤 놈의 handler 에서 deadlock 상황이 발생해 멍때리게 된다면,
결론적으로 담당 쓰레드가 멍때리게 되므로 그 workqueue 에 등록된 모든 work 들이 실행되지 않게 됩니다.
OTL
댓글 달기