Catatan
Akses ke halaman ini memerlukan otorisasi. Anda dapat mencoba masuk atau mengubah direktori.
Akses ke halaman ini memerlukan otorisasi. Anda dapat mencoba mengubah direktori.
Mewakili metode yang akan menangani GlobalHealthCheck peristiwa, yang terjadi ketika operasi terkait kesehatan dijalankan.
Sintaks
virtual GLOBAL_NOTIFICATION_STATUS OnGlobalHealthCheck(
VOID
);
Parameter
Metode ini tidak memerlukan parameter.
Tampilkan Nilai
Nilai GLOBAL_NOTIFICATION_STATUS .
Keterangan
Ketika modul global telah mendaftar untuk pemberitahuan peristiwa GL_HEALTH_CHECK , IIS akan memanggil metode modul OnGlobalHealthCheck ketika operasi terkait kesehatan terjadi. Misalnya, jika modul lain memanggil metode IHttpServer::ReportUnhealthy, IIS akan memanggil OnGlobalHealthCheck modul apa pun yang telah mendaftar untuk pemberitahuan.GL_HEALTH_CHECK
Catatan
Modul global dapat mendaftar untuk GlobalHealthCheck pemberitahuan peristiwa dengan mendaftar GL_HEALTH_CHECK dalam fungsi RegisterModule modul.
Contoh
Contoh kode berikut menunjukkan cara membuat modul HTTP tingkat global yang mendaftar untuk GL_HEALTH_CHECK pemberitahuan peristiwa. Jika operasi terkait kesehatan terjadi, IIS akan memanggil metode modul OnGlobalHealthCheck contoh. Metode ini akan menulis entri di log aplikasi Windows Event Viewer lalu keluar.
#define _WINSOCKAPI_
#include <windows.h>
#include <sal.h>
#include <httpserv.h>
// Create the module's global class.
class MyGlobalModule : public CGlobalModule
{
public:
// Process a GL_HEALTH_CHECK notification.
GLOBAL_NOTIFICATION_STATUS
OnGlobalHealthCheck(
VOID
)
{
WriteEventViewerLog("OnGlobalHealthCheck");
return GL_NOTIFICATION_CONTINUE;
}
VOID Terminate()
{
// Remove the class from memory.
delete this;
}
MyGlobalModule()
{
// Open a handle to the Event Viewer.
m_hEventLog = RegisterEventSource( NULL,"IISADMIN" );
}
~MyGlobalModule()
{
// Test whether the handle for the Event Viewer is open.
if (NULL != m_hEventLog)
{
// Close the handle to the Event Viewer.
DeregisterEventSource( m_hEventLog );
m_hEventLog = NULL;
}
}
private:
// Create a handle for the event viewer.
HANDLE m_hEventLog;
// Define a method that writes to the Event Viewer.
BOOL WriteEventViewerLog(LPCSTR szNotification)
{
// Test whether the handle for the Event Viewer is open.
if (NULL != m_hEventLog)
{
// Write any strings to the Event Viewer and return.
return ReportEvent(
m_hEventLog,
EVENTLOG_INFORMATION_TYPE, 0, 0,
NULL, 1, 0, &szNotification, NULL );
}
return FALSE;
}
};
// Create the module's exported registration function.
HRESULT
__stdcall
RegisterModule(
DWORD dwServerVersion,
IHttpModuleRegistrationInfo * pModuleInfo,
IHttpServer * pGlobalInfo
)
{
UNREFERENCED_PARAMETER( dwServerVersion );
UNREFERENCED_PARAMETER( pGlobalInfo );
// Create an instance of the global module class.
MyGlobalModule * pGlobalModule = new MyGlobalModule;
// Test for an error.
if (NULL == pGlobalModule)
{
return HRESULT_FROM_WIN32(ERROR_NOT_ENOUGH_MEMORY);
}
// Set the global notifications and exit.
return pModuleInfo->SetGlobalNotifications(
pGlobalModule, GL_HEALTH_CHECK );
}
Modul Anda harus mengekspor fungsi RegisterModule . Anda dapat mengekspor fungsi ini dengan membuat file definisi modul (.def) untuk proyek Anda, atau Anda dapat mengkompilasi modul dengan menggunakan sakelar /EXPORT:RegisterModule . Untuk informasi selengkapnya, lihat Panduan: Membuat Modul HTTP Global-Level Dengan Menggunakan Kode Asli.
Anda dapat secara opsional mengkompilasi kode dengan menggunakan __stdcall (/Gz) konvensi panggilan alih-alih secara eksplisit mendeklarasikan konvensi panggilan untuk setiap fungsi.
Persyaratan
| Jenis | Deskripsi |
|---|---|
| Klien | - IIS 7.0 di Windows Vista - IIS 7.5 di Windows 7 - IIS 8.0 di Windows 8 - IIS 10.0 pada Windows 10 |
| Server | - IIS 7.0 di Windows Server 2008 - IIS 7.5 di Windows Server 2008 R2 - IIS 8.0 di Windows Server 2012 - IIS 8.5 di Windows Server 2012 R2 - IIS 10.0 di Windows Server 2016 |
| Produk | - IIS 7.0, IIS 7.5, IIS 8.0, IIS 8.5, IIS 10.0 - IIS Express 7.5, IIS Express 8.0, IIS Express 10.0 |
| Header | Httpserv.h |