NotifyServiceStatusChangeA 함수(winsvc.h)

지정된 서비스를 만들거나 삭제하거나 상태 변경될 때 애플리케이션이 알림을 받을 수 있도록 합니다.

구문

DWORD NotifyServiceStatusChangeA(
  [in] SC_HANDLE        hService,
  [in] DWORD            dwNotifyMask,
  [in] PSERVICE_NOTIFYA pNotifyBuffer
);

매개 변수

[in] hService

서비스 또는 서비스 제어 관리자에 대한 핸들입니다. 서비스에 대한 핸들은 OpenService 또는 CreateService 함수에서 반환되며 SERVICE_QUERY_STATUS 액세스 권한이 있어야 합니다. 서비스 제어 관리자에 대한 핸들은 OpenSCManager 함수에서 반환되며 SC_MANAGER_ENUMERATE_SERVICE 액세스 권한이 있어야 합니다. 자세한 내용은 서비스 보안 및 액세스 권한을 참조하세요.

서비스당 하나의 미해결 알림 요청만 있을 수 있습니다.

[in] dwNotifyMask

보고해야 하는 상태 변경 내용의 유형입니다. 이 매개 변수는 다음 값 중 하나 이상일 수 있습니다.

의미
SERVICE_NOTIFY_CREATED
0x00000080
서비스가 만들어진 시기를 보고합니다.

hService 매개 변수는 SCM에 대한 핸들이어야 합니다.

SERVICE_NOTIFY_CONTINUE_PENDING
0x00000010
서비스를 계속 진행하려고 할 때 보고합니다.

hService 매개 변수는 서비스에 대한 핸들이어야 합니다.

SERVICE_NOTIFY_DELETE_PENDING
0x00000200
애플리케이션이 DeleteService 함수에 대한 호출에서 서비스를 지정한 경우를 보고합니다. 애플리케이션은 삭제할 수 있도록 서비스에 대한 핸들을 닫아야 합니다.

hService 매개 변수는 서비스에 대한 핸들이어야 합니다.

SERVICE_NOTIFY_DELETED
0x00000100
서비스가 삭제된 시기를 보고합니다. 애플리케이션이 서비스에 대한 열린 핸들이 있는 경우 이 알림을 받을 수 없습니다.

hService 매개 변수는 SCM에 대한 핸들이어야 합니다.

SERVICE_NOTIFY_PAUSE_PENDING
0x00000020
서비스가 일시 중지되는 경우 보고합니다.

hService 매개 변수는 서비스에 대한 핸들이어야 합니다.

SERVICE_NOTIFY_PAUSED
0x00000040
서비스가 일시 중지된 경우 보고합니다.

hService 매개 변수는 서비스에 대한 핸들이어야 합니다.

SERVICE_NOTIFY_RUNNING
0x00000008
서비스가 실행 중일 때 보고합니다.

hService 매개 변수는 서비스에 대한 핸들이어야 합니다.

SERVICE_NOTIFY_START_PENDING
0x00000002
서비스가 시작될 때 보고합니다.

hService 매개 변수는 서비스에 대한 핸들이어야 합니다.

SERVICE_NOTIFY_STOP_PENDING
0x00000004
서비스가 중지되는 시기를 보고합니다.

hService 매개 변수는 서비스에 대한 핸들이어야 합니다.

SERVICE_NOTIFY_STOPPED
0x00000001
서비스가 중지된 경우를 보고합니다.

hService 매개 변수는 서비스에 대한 핸들이어야 합니다.

[in] pNotifyBuffer

콜백 함수에 대한 포인터와 같은 알림 정보를 포함하는 SERVICE_NOTIFY 구조체에 대한 포인터입니다. 이 구조는 콜백 함수가 호출되거나 호출 스레드가 알림 요청을 취소할 때까지 유효한 상태를 유지해야 합니다.

첫 번째 호출의 콜백 함수가 버퍼로 완료되거나 첫 번째 알림 요청이 취소될 때까지 동일한 버퍼 매개 변수를 사용하여 NotifyServiceStatusChange 를 여러 차례 호출하지 마세요. 그렇지 않으면 콜백 함수가 수신할 버퍼 버전이 보장되지 않습니다.

Windows Vista: 콜백 함수의 주소는 로드된 모듈의 주소 범위 내에 있어야 합니다. 따라서 콜백 함수는 런타임에 생성되는 코드(예: JIT 컴파일러에서 생성된 관리 코드) 또는 런타임에 압축을 해제하는 네이티브 코드일 수 없습니다. 이 제한은 Windows Server 2008 및 Windows Vista SP1에서 제거되었습니다.

반환 값

함수가 성공하면 반환 값이 ERROR_SUCCESS. 서비스가 삭제되도록 표시된 경우 반환 값이 ERROR_SERVICE_MARKED_FOR_DELETE 서비스에 대한 핸들을 닫아야 합니다. 서비스 알림이 시스템 상태보다 너무 뒤처지면 함수는 ERROR_SERVICE_NOTIFY_CLIENT_LAGGING 반환합니다. 이 경우 클라이언트는 SCM에 대한 핸들을 닫고, 새 핸들을 열고, 이 함수를 다시 호출해야 합니다.

함수가 실패하면 반환 값은 시스템 오류 코드 중 하나입니다.

설명

NotifyServiceStatusChange 함수를 사용하여 서비스 애플리케이션에 대한 알림을 받을 수 있습니다. 드라이버 서비스에 대한 알림을 받는 데 사용할 수 없습니다.

서비스가 상태 변경되면 시스템은 지정된 콜백 함수를 호출 스레드에 큐에 대기 중인 APC(비동기 프로시저 호출)로 호출합니다. 호출 스레드는 알림을 받으려면 경고 대기(예: SleepEx 함수 호출)를 입력해야 합니다. 자세한 내용은 비동기 프로시저 호출을 참조하세요.

NotifyServiceStatusChange를 호출할 때 서비스가 이미 요청된 상태인 경우 콜백 함수는 즉시 큐에 대기됩니다. 다음에 동일한 서비스 및 상태로 함수를 호출할 때 서비스 상태가 변경되지 않은 경우 콜백 함수는 즉시 큐에 대기되지 않습니다. 콜백 함수는 다음에 서비스가 요청된 상태로 들어갈 때 큐에 대기합니다.

NotifyServiceStatusChange 함수는 THREAD_SET_CONTEXT 액세스 권한이 있는 호출 스레드에서 OpenThread 함수를 호출합니다. 호출 스레드에 이 액세스 권한이 없으면 NotifyServiceStatusChange 가 실패합니다. 호출 스레드가 다른 사용자를 가장하는 경우 컨텍스트를 설정할 수 있는 충분한 권한이 없을 수 있습니다.

추가 스레드를 만드는 것보다 대기를 수행하는 스레드에서 NotifyServiceStatusChange 를 호출하는 것이 더 효율적입니다.

콜백 함수가 호출된 후 호출자는 NotifyServiceStatusChange 를 호출하여 추가 알림을 받아야 합니다. NotifyServiceStatusChange 및 기타 SCM 함수를 비롯한 Windows API의 특정 함수는 RPC(원격 프로시저 호출)를 사용합니다. 이러한 함수는 경고 가능한 대기 작업을 수행할 수 있으므로 콜백 함수 내에서 호출하는 것이 안전하지 않습니다. 대신 콜백 함수는 알림 매개 변수를 저장하고 콜백 외부에서 추가 작업을 수행해야 합니다.

미해결 알림을 취소하려면 CloseServiceHandle 함수를 사용하여 서비스 핸들을 닫습니다. CloseServiceHandle이 성공하면 더 이상 알림 APC가 큐에 대기되지 않습니다. 호출 스레드가 서비스 핸들을 닫지 않고 종료되거나 APC가 생성될 때까지 기다리지 않으면 메모리 누수가 발생할 수 있습니다.

중요 스레드가 알림을 받거나 CloseServiceHandle을 호출하기 전에 호출 스레드가 DLL에 있고 DLL이 언로드된 경우 알림으로 인해 예측할 수 없는 결과가 발생하고 프로세스가 응답하지 않을 수 있습니다.
 

참고

winsvc.h 헤더는 NOTIFYServiceStatusChange를 유니코드 전처리기 상수의 정의에 따라 이 함수의 ANSI 또는 유니코드 버전을 자동으로 선택하는 별칭으로 정의합니다. 인코딩 중립 별칭을 인코딩 중립이 아닌 코드와 혼합하면 컴파일 또는 런타임 오류가 발생하는 불일치가 발생할 수 있습니다. 자세한 내용은 함수 프로토타입에 대한 규칙을 참조하세요.

요구 사항

요구 사항
지원되는 최소 클라이언트 Windows Vista [데스크톱 앱만 해당]
지원되는 최소 서버 Windows Server 2008 [데스크톱 앱만 해당]
대상 플랫폼 Windows
헤더 winsvc.h(Windows.h 포함)
라이브러리 Advapi32.lib
DLL Advapi32.dll

추가 정보

SERVICE_NOTIFY

SubscribeServiceChangeNotifications

서비스 함수