DeadLock 발생 조건 4가지 및 해결 방법

HYEONG HWAN, MUN/ 5월 26, 2015/ 미분류/ 3 comments

https://blog.lael.be/post/1304

DeadLock 발생 조건 4가지 및 해결 방법.

 

이것은 학부 3학년 교과목인 Operating System(운영체제)의 Process Scheduling 파트에서 다뤄지는 핵심적인 내용이다.

이 이론은 하나 이상의 시스템이 협력을 할 때 반드시 고려되야 하는 내용을 포함하고 있다.

 

교착 상태의 조건

1971년에 E. G. 코프만 교수는 교착상태가 일어나려면 다음과 같은 네 가지 필요 조건을 충족시켜야 함을 보였다.

  1. 상호배제(Mutual exclusion) : 프로세스들이 필요로 하는 자원에 대해 배타적인 통제권을 요구한다.
  2. 점유대기(Hold and wait) : 프로세스가 할당된 자원을 가진 상태에서 다른 자원을 기다린다.
  3. 비선점(No preemption) : 프로세스가 어떤 자원의 사용을 끝낼 때까지 그 자원을 뺏을 수 없다.
  4. 순환대기(Circular wait) : 각 프로세스는 순환적으로 다음 프로세스가 요구하는 자원을 가지고 있다.

이 조건 중에서 한 가지라도 만족하지 않으면 교착 상태는 발생하지 않는다. 이 중 순환대기 조건은 점유대기 조건과 비선점 조건을 만족해야 성립하는 조건이므로, 위 4가지 조건은 서로 완전히 독립적인 것은 아니다.

 

교착 상태 해결방법

 

교착 상태의 관리

현재의 대부분의 운영 체제들은 교착 상태를 막는 것은 불가능하다.
교착 상태가 발생하면 여러 운영 체제들은 제각기 다른 비표준 방식들로 이러한 교착 상태에 대응한다.
대부분의 접근들은 4가지 코프만 조건들 가운데 하나(특히 4번째 것)를 막음으로써 동작한다. 주요 접근 방식은 다음과 같다.

 

교착 상태의 예방
  • 상호배제 조건의 제거
교착 상태는 두 개 이상의 프로세스가 공유 불가능한 자원을 사용하니 발생하는 것이므로 공유 불가능한, 즉사 상호 배제 조건을 제거하면 교착 상태를 해결할 수 있다.
  • 점유와 대기 조건의 제거
한 프로세스에 수행되기 전에 모든 자원을 할당시키고 나서 점유하지 않을 때에는 다른 프로세스가 자원을 요구하도록 하는 방법이다. 자원 과다 사용으로 인한 효율성, 프로세스가 요구하는 자원을 파악하는 데에 대한 비용, 자원에 대한 내용을 저장 및 복원하기 위한 비용, 기아상태, 무한 대기 등의 문제점이 있다.
  • 비선점 조건의 제거
비선점 프로세스에 대해 선점 가능한 프로토콜을 만들어 준다.
  • 순환 대기 조건의 제거
자원 유형에 따라 순서를 매긴다.

이 교착 상태의 해결 방법들은 자원 사용의 효율성이 떨어지고 비용이 많이 드는 문제점이 있다.

 

교착 상태의 회피

자원이 어떻게 요청될지에 대한 추가정보를 제공하도록 요구하는 것으로 시스템에 circular wait가 발생하지 않도록 자원 할당 상태를 검사한다.

교착 상태 회피하기 위한 알고리즘으로 크게 두가지가 있다.

1) 자원 할당 그래프 알고리즘 (Resource Allocation Graph Algorithm)
2) 은행원 알고리즘 (Banker’s algorithm)

 

교착 상태의 무시

 

교착 상태의 발견

3 Comments

  1. 글 잘보고 갑니다 감사합니다.

  2. 정리 감사합니다.

student에 답글 남기기 응답 취소

작성하신 댓글은 관리자의 수동 승인 후 게시됩니다.

You may use these HTML tags and attributes: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <s> <strike> <strong>
*
*