Compartir a través de


sys.dm_external_script_requests

Se aplica a: SQL Server 2016 (13.x) y versiones posteriores Azure SQL Managed Instance

Devuelve una fila para cada cuenta de trabajo activa que ejecuta un script externo.

Nota:

Esta vista de administración dinámica (DMV) solo está disponible si ha instalado y habilitado la característica que admite la ejecución de scripts externos. Para más información, consulte Machine Learning Services (R, Python) en SQL Server 2017 y versiones posteriores, R Services en SQL Server 2016 y Machine Learning Services en Azure SQL Instancia administrada.

Nombre de la columna Tipo de datos Descripción
external_script_request_id identificador único Identificador del proceso que envió la solicitud de script externo. Esto corresponde al identificador de proceso tal como se recibió la instancia de SQL.
language nvarchar Palabra clave que representa un lenguaje de script compatible.
degree_of_parallelism int Número que indica el número de procesos paralelos que se crearon. Este valor podría ser diferente del número de procesos paralelos que se solicitaron.
external_user_name nvarchar La cuenta de trabajo de Windows bajo la que se ejecutó el script.

Permisos

Requiere VIEW SERVER STATE permiso en el servidor.

Nota:

Los usuarios que ejecutan scripts externos deben tener el permiso EXECUTE ANY EXTERNAL SCRIPTadicional , pero los administradores pueden usar esta DMV sin este permiso.

Permisos para SQL Server 2022 y versiones posteriores

Requiere el permiso VER ESTADO DE RENDIMIENTO DEL SERVIDOR en el servidor.

Comentarios

Esta vista se puede filtrar usando el identificador del lenguaje de script.

La vista también devuelve la cuenta de trabajo en la que se ejecuta el script. Para obtener información sobre las cuentas de trabajo usadas por los scripts externos, vea la sección Identidades usadas en el procesamiento (SQLRUserGroup) en Información general de seguridad para el marco de extensibilidad en SQL Server Machine Learning Services.

El GUID que se devuelve en el campo external_script_request_id también representa el nombre de archivo del directorio seguro donde se almacenan los archivos temporales. Cada cuenta de trabajo, como MSSQLSERVER01, representa un único inicio de sesión de SQL o un usuario de Windows y puede usarse para ejecutar varias solicitudes de script. De forma predeterminada, estos archivos temporales se limpian tras la finalización del script.

Esta DMV supervisa solo los procesos activos y no puede informar sobre scripts que ya han completado. Si necesita realizar un seguimiento de la duración de scripts, es recomendable agregar información de tiempo en el script y capturar eso como parte de la ejecución del script.

Ejemplos

Visualización de los scripts activos actualmente para un proceso determinado

En el ejemplo siguiente se muestra el número de ejecuciones de scripts externos que tienen lugar en la instancia actual.

SELECT external_script_request_id
  , [language]
  , degree_of_parallelism
  , external_user_name
FROM sys.dm_external_script_requests;

Resultados

external_script_request_id language degree_of_parallelism external_user_name
183EE6FC-7399-4318-AA2E-7A6C68E435A8 R 1 MSSQLSERVER01

Consulte también