regulador de recursos

Se aplica a:SQL ServerAzure SQL Managed Instance

SQL Server Resource Governor es una característica que puede usar para administrar SQL Server carga de trabajo y consumo de recursos del sistema. Resource Governor permite especificar la cantidad máxima de CPU, E/S física y memoria que las solicitudes de aplicación entrantes pueden usar.

Nota

Aunque Azure SQL Database aprovecha Resource Governor (entre otras técnicas) para administrar recursos, no se admite la configuración de usuarios de grupos de recursos personalizados y grupos de cargas de trabajo en Azure SQL Database. Azure Synapse Analytics tiene una implementación diferente de un comportamiento similar de Resource Governor a través de la característica de clasificación de carga de trabajo.

Ventajas del regulador de recursos

Resource Governor permite administrar las cargas de trabajo y los recursos de SQL Server mediante la especificación de límites sobre el consumo de recursos para las solicitudes entrantes. En el contexto del Regulador de recursos, la carga de trabajo es un conjunto de consultas o solicitudes de dimensiones similares que pueden (y deberían) tratarse como una entidad única. No se trata de un requisito, pero cuanto más uniforme es el modelo del uso de recursos de una carga de trabajo, mayores son las ventajas que pueden obtenerse del Regulador de recursos. Los límites sobre los recursos pueden reconfigurarse en tiempo real con un impacto mínimo sobre las cargas de trabajo que se están ejecutando.

En un entorno donde varias cargas de trabajo distintas están presentes en el mismo servidor, el Regulador de recursos permite diferenciar estas cargas de trabajo y asignar los recursos compartidos a medida que se soliciten, en función de los límites que se especifiquen. Estos recursos son CPU, E/S física y memoria.

El uso del regulador de recursos permite:

  • Proporcionar aislamiento de recursos y multiempresa cuando una sola instancia de SQL Server suministra servicios a cargas de trabajo de varios clientes. Es decir, puede repartir los recursos disponibles en un servidor entre las cargas de trabajo y minimizar los problemas que pueden aparecer cuando las cargas de trabajo compiten por los recursos.

  • Proporcionar un rendimiento predecible y cumplir los contratos de nivel de servicio para los distintos inquilinos de carga de trabajo en un entorno multiusuario y con varias cargas de trabajo.

  • Aislar y limitar las consultas descontroladas o regular los recursos de E/S en operaciones como DBCC CHECKDB que pueden saturar el subsistema de E/S y afectar negativamente a otras cargas de trabajo.

  • Agregar un seguimiento detallado de recursos para los reembolsos por uso de recursos y proporcionar una facturación predecible a los clientes de los recursos de servidor.

Restricciones del Regulador de recursos

Esta versión del Regulador de recursos tiene las restricciones siguientes:

  • La administración de recursos se limita al motor de base de datos de SQL Server. Resource Governor no se puede usar para Analysis Services, Integration Services y Reporting Services.

  • No hay ninguna supervisión o administración de las cargas de trabajo entre las instancias de SQL Server.

  • El Regulador de recursos puede administrar las cargas de trabajo de OLTP pero estos tipos de consultas, que son normalmente muy cortas en duración, no siempre ocupan la CPU el tiempo suficiente como para aplicar los controles de ancho de banda. Este hecho puede sesgar las estadísticas obtenidas para el porcentaje de uso de la CPU.

  • La capacidad de regular la E/S física solo se aplica a las operaciones de usuario y no a las tareas del sistema. Las tareas del sistema incluyen operaciones de escritura en el registro de transacciones y operaciones diferidas de E/S de escritura. Resource Governor se aplica principalmente a las operaciones de lectura de usuario, porque la mayoría de las operaciones de escritura suelen ser realizadas por tareas del sistema.

  • No puede establecer umbrales de E/S en el grupo de recursos de servidor interno.

Conceptos de recursos

Los tres conceptos siguientes son fundamentales para comprender y usar el regulador de recursos:

  • Grupo de recursos de servidor. Un grupo de recursos de servidor representa los recursos físicos del servidor. Puede pensar en un grupo como en una instancia virtual de SQL Server dentro de una instancia de SQL Server . Se crean dos grupos de recursos (internos y predeterminados) cuando se instala SQL Server. El regulador de recursos también admite grupos de recursos de servidor definidos por el usuario. Para más información, consulte Resource Governor Resource Pool.

  • Grupos de carga de trabajo. Un grupo de cargas de trabajo actúa como un contenedor de las solicitudes de sesión que tienen criterios de clasificación similares. Una carga de trabajo permite la supervisión agregada de las sesiones y define directivas para estas. Cada grupo de cargas de trabajo pertenece a un grupo de recursos de servidor. Se crean dos grupos de cargas de trabajo (internos y predeterminados) y se asignan a sus grupos de recursos correspondientes cuando se instala SQL Server. El regulador de recursos también admite grupos de cargas de trabajo definidos por el usuario. Para obtener más información, consulte Resource Governor Workload Group.

  • Clasificación. El proceso de clasificación asigna las sesiones de entrada a cada grupo de cargas de trabajo según las características de la sesión. Puede adaptar la lógica de clasificación escribiendo una función definida por el usuario, denominada función clasificadora. El regulador de recursos también admite una función clasificadora definida por el usuario para implementar las reglas de la clasificación. Para más información, consulte Resource Governor Classifier Function.

Nota

El regulador de recursos no impone ningún control sobre las conexiones de administrador dedicadas (DAC). No hay ninguna necesidad de clasificar las consultas de DAC, las cuales se ejecutan en el grupo de cargas de trabajo y en el grupo de recursos de servidor internos.

En el contexto del regulador de recursos, puede tratar los conceptos anteriores como componentes. La ilustración siguiente muestra estos componentes y su relación entre sí, tal y como existen en el entorno del motor de base de datos. Desde el punto de vista del procesamiento, el flujo simplificado es como sigue:

  • Existe una conexión entrante para una sesión (sesión 1 de n).

  • La sesión está clasificada (Clasificación).

  • La carga de trabajo de la sesión se enruta a un grupo de cargas de trabajo, por ejemplo, al Grupo 4.

  • El grupo de cargas de trabajo utiliza el grupo de recursos de servidor al que está asociado, por ejemplo, el Grupo 2.

  • El grupo de recursos de servidor proporciona y limita los recursos requeridos por la aplicación, por ejemplo, la Aplicación 3.

componentes funcionales de Resource Governor

Tareas del regulador de recursos

Descripción de la tarea Tema
Describe cómo habilitar el regulador de recursos. Habilitar el regulador de recursos
Describe cómo deshabilitar el regulador de recursos. Deshabilitar el regulador de recursos
Describe cómo crear, modificar y quitar un grupo de recursos de servidor. Grupo de recursos de servidor del regulador de recursos
Describe cómo crear, modificar, mover y quitar un grupo de carga de trabajo. Grupos de cargas de trabajo del regulador de recursos
Describe cómo crear y probar una función clasificadora definida por el usuario. Función clasificadora del regulador de recursos
Describe cómo configurar el regulador de recursos mediante una plantilla. Configurar el regulador de recursos mediante una plantilla
Describe cómo ver las propiedades del regulador de recursos. Ver las propiedades del regulador de recursos

Consulte también

Instancias del motor de base de datos (SQL Server)