IHttpServer::D ecrementThreadCount (Método)
Disminuye el número de subprocesos del grupo de subprocesos.
Sintaxis
virtual VOID DecrementThreadCount(
VOID
) = 0;
Parámetros
Este método no toma parámetros.
Valor devuelto
VOID
.
Comentarios
El DecrementThreadCount
método reduce el recuento de subprocesos disponibles para el grupo de subprocesos por un único subproceso.
Nota
DecrementThreadCount
no disminuye realmente el número de subprocesos en uso; solo se ve afectado el número de subprocesos.
Al desarrollar un módulo HTTP que realiza operaciones que requieren mucho tiempo para procesarse, el módulo HTTP podría llamar a IHttpServer::IncrementThreadCount para aumentar los subprocesos disponibles para el grupo de subprocesos mientras el módulo ejecuta las operaciones de larga duración. Cuando finalice el módulo, llamaría DecrementThreadCount
a para restaurar el número de subprocesos.
Ejemplo
En el ejemplo de código siguiente se muestra cómo crear un módulo HTTP que llama IncrementThreadCount
a para aumentar el número de subprocesos del grupo de subprocesos y, a continuación, se suspende durante 30 segundos. A continuación, el módulo llama DecrementThreadCount
a para restaurar el número de subprocesos y se cierra.
#define _WINSOCKAPI_
#include <windows.h>
#include <sal.h>
#include <httpserv.h>
// Create a pointer for the global server interface.
IHttpServer * g_pHttpServer = NULL;
// Create the module class.
class MyHttpModule : public CHttpModule
{
public:
REQUEST_NOTIFICATION_STATUS
OnBeginRequest(
IN IHttpContext * pHttpContext,
IN IHttpEventProvider * pProvider
)
{
UNREFERENCED_PARAMETER( pHttpContext );
UNREFERENCED_PARAMETER( pProvider );
// Increment the thread count.
g_pHttpServer->IncrementThreadCount();
// Sleep for 30 seconds.
Sleep(30 * 1000);
// Decrement the thread count.
g_pHttpServer->DecrementThreadCount();
// Return processing to the pipeline.
return RQ_NOTIFICATION_CONTINUE;
}
};
// Create the module's class factory.
class MyHttpModuleFactory : public IHttpModuleFactory
{
public:
HRESULT
GetHttpModule(
OUT CHttpModule ** ppModule,
IN IModuleAllocator * pAllocator
)
{
UNREFERENCED_PARAMETER( pAllocator );
// Create a new instance.
MyHttpModule * pModule = new MyHttpModule;
// Test for an error.
if (!pModule)
{
// Return an error if the factory cannot create the instance.
return HRESULT_FROM_WIN32( ERROR_NOT_ENOUGH_MEMORY );
}
else
{
// Return a pointer to the module.
*ppModule = pModule;
pModule = NULL;
// Return a success status.
return S_OK;
}
}
void Terminate()
{
// Remove the class from memory.
delete this;
}
};
// Create the module's exported registration function.
HRESULT
__stdcall
RegisterModule(
DWORD dwServerVersion,
IHttpModuleRegistrationInfo * pModuleInfo,
IHttpServer * pGlobalInfo
)
{
UNREFERENCED_PARAMETER( dwServerVersion );
// Store the pointer for the global server interface.
g_pHttpServer = pGlobalInfo;
// Set the request notifications and exit.
return pModuleInfo->SetRequestNotifications(
new MyHttpModuleFactory,
RQ_BEGIN_REQUEST,
0
);
}
El módulo debe exportar la función RegisterModule . Puede exportar esta función mediante la creación de un archivo de definición de módulo (.def) para el proyecto, o bien puede compilar el módulo mediante el /EXPORT:RegisterModule
modificador . Para obtener más información, vea Tutorial: Creación de un módulo HTTP de Request-Level mediante código nativo.
Opcionalmente, puede compilar el código mediante la __stdcall (/Gz)
convención de llamada en lugar de declarar explícitamente la convención de llamada para cada función.
Requisitos
Tipo | Descripción |
---|---|
Remoto | - IIS 7.0 en Windows Vista - IIS 7.5 en Windows 7 - IIS 8.0 en Windows 8 - IIS 10.0 en Windows 10 |
Servidor | - IIS 7.0 en Windows Server 2008 - IIS 7.5 en Windows Server 2008 R2 - IIS 8.0 en Windows Server 2012 - IIS 8.5 en Windows Server 2012 R2 - IIS 10.0 en Windows Server 2016 |
Producto | - 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 |
Encabezado | Httpserv.h |
Consulte también
IHttpServer (interfaz)
IHttpServer::IncrementThreadCount (Método)