백그라운드 프로세스와 데몬 프로세스의 차이점
가장 큰 차이점은 다음과 같습니다.
- (a) 데몬 프로세스는 터미널 콘솔에서 완전히 분리되었지만 백그라운드 프로그램은 터미널에서 완전히 분리되지 않았습니다(터미널이 닫히기 전에 결과는 여전히 터미널에 출력됩니다).
- (b) 터미널 콘솔을 닫을 때 데몬 프로세스는 영향을 받지 않지만 사용자가 종료할 때 백그라운드 프로그램은 중지됩니다. 영향을 피하기 위해 nohup 명령 및 형식으로 실행해야 합니다.
- (c) 데몬 프로세스의 세션 그룹, 현재 디렉터리 및 파일 설명자는 독립적입니다. 백그라운드에서 실행하는 것은 프로그램이 백그라운드에서 실행될 수 있도록 하는 터미널의 포크일 뿐입니다.
데몬의 기능
데몬은 백그라운드에서 실행되는 특수 프로세스로, 터미널과 분리되어 있어 어떤 터미널에서 생성되는 신호로 인해 프로세스가 중단되는 것을 방지하고 프로세스 실행 중에 생성된 정보가 어떤 터미널에도 표시되지 않습니다. . 데몬 프로세스는 주기적으로 특정 작업을 수행하거나 발생하는 특정 이벤트의 처리를 기다립니다.
데몬 프로그래밍의 핵심 포인트
-
- 제어 터미널 작동과 관련된 일부 신호를 보호하는 것은 데몬 프로세스가 정상적으로 시작되기 전에 제어 터미널이 방해를 받아 종료되거나 정지되는 것을 방지하기 위한 것입니다. 코드는 아래와 같이 표시됩니다.
으아악
- 백그라운드에서 실행됩니다.
으아악
- 터미널과 프로세스 그룹의 통제에서 벗어나세요:
- (1) 프로세스는 프로세스 그룹에 속하며 프로세스 그룹 번호(PGID)는 프로세스 리더의 프로세스 번호(PID)입니다
- (2) 동일한 프로세스 그룹의 프로세스는 제어 터미널을 공유합니다. 기본적으로 이 제어 터미널은 프로세스가 생성된 터미널입니다
- (3) 프로세스와 연결된 제어 터미널 및 프로세스 그룹은 일반적으로 상위 프로세스에서 상속됩니다. 따라서 터미널에서 생성된 신호가 모든 프로세스로 전송되기 때문에 하위 프로세스는 여전히 상위 프로세스의 터미널에 의해 영향을 받습니다. 포그라운드 프로세스 그룹의 프로세스.
위의 이유에 따라 하위 프로세스에 대한 터미널의 영향을 완전히 제거해야 합니다. 하위 프로세스를 새 세션 리더로 만들기 위해 코드는 다음과 같습니다.
으아악
setsid() 호출이 성공하면 이 함수를 호출하는 프로세스가 새 세션 리더와 새 프로세스 리더가 되며 원래 프로세스 그룹에서 분리됩니다. 제어 단말에 대한 세션 프로세스의 독점성으로 인해 해당 프로세스는 동시에 제어 단말에서 분리됩니다.
프로세스가 제어 터미널을 다시 여는 것을 방지하기 위해 사용되는 방법은 하위 프로세스를 다시 생성하고 상위 프로세스가 종료되도록 하는 것입니다. 따라서 목표를 달성합니다. 코드는 아래와 같이 표시됩니다.
으아악
-
열린 파일 설명자를 닫습니다. 프로세스는 자신을 생성한 상위 프로세스로부터 열린 파일 설명자를 상속하므로 일반적으로 더 이상 필요하지 않습니다. 닫히지 않으면 시스템 리소스가 낭비됩니다. 코드는 아래와 같이 표시됩니다.
으아악
-
현재 작업 디렉토리를 변경하세요. 프로세스가 활성화되어 있는 동안에는 해당 작업 디렉터리를 포함하는 파일 시스템을 마운트 해제할 수 없습니다. 따라서 데몬의 작업 디렉터리를 적절한 디렉터리로 변경해야 합니다. 코드는 아래와 같이 표시됩니다.
으아악
-
파일 생성 마스크를 재설정합니다. 프로세스는 파일 생성 마스크를 생성한 상위 프로세스로부터 상속받습니다. 데몬이 생성한 파일의 액세스 권한을 수정할 수 있습니다. 코드는 아래와 같이 표시됩니다.
으아악
-
SIGCHLD 신호(하위 프로세스 종료 신호)를 처리합니다. 자식 프로세스가 끝날 때까지 기다리지 않으면 자식 프로세스는 좀비 프로세스가 되어 시스템 커널 리소스를 차지하게 됩니다.
으아악
- 전체 코드는 다음과 같습니다.
으아악
setsid() 함수 함수 추가:
호출 프로세스가 이미 프로세스 그룹의 리더인 경우 이 함수는 오류를 반환합니다. 이러한 상황을 방지하기 위해 일반적으로 fork()를 호출하여 자식 프로세스를 생성한 후 부모 프로세스를 종료하고 자식 프로세스는 계속 진행되며 자식 프로세스에서 이 함수를 호출합니다.
이 함수를 호출한 프로세스가 프로세스 그룹 리더가 아닌 경우 이 함수는 새 세션을 생성하며, setid() 함수를 호출한 프로세스는 새 세션의 리더 프로세스가 되어 세션 그룹과 프로세스에서 분리됩니다. 상위 프로세스의 그룹입니다. 세션은 제어 터미널에서만 독점적이기 때문에 프로세스는 제어 터미널에서 동시에 분리됩니다.
위 내용은 Linux의 수호성인 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!