Cómo crear RSExecRole
Reporting Services utiliza una función de la base de datos predefinida denominada RSExecRole para conceder permisos de servidor de informes a la base de datos del servidor de informes. La función RSExecRole se crea automáticamente con la base de datos del servidor de informes. Por lo general, nunca se debe modificar la función ni asignar otros usuarios a la misma. Sin embargo, cuando se mueve una base de datos del servidor de informes a un Motor de base de datos de SQL Server nuevo o diferente, se debe volver a crear la función en las bases de datos del sistema MSDB y maestra.
Usando estas instrucciones realizará los siguientes pasos:
Crear y proporcionar la función RSExecRole en la base de datos del sistema maestra.
Crear y proporcionar la función RSExecRole en la base de datos del sistema MSDB.
Nota
Las instrucciones de este tema están destinadas a los usuarios que no desean ejecutar un script o escribir código WMI para proporcionar la base de datos del servidor de informes. Si administra una implementación grande y va a mover las bases de datos habitualmente, debe escribir un script para automatizar estos pasos. Para obtener más información, vea Proveedor WMI de Reporting Services.
Antes de empezar
Realice una copia de seguridad de las claves de cifrado para poder restaurarlas después de mover la base de datos. Este paso no afecta directamente a la capacidad personal para crear y proporcionar la función RSExecRole, pero se debe disponer de una copia de seguridad de las claves para comprobar el trabajo. Para obtener más información, vea Realizar copias de seguridad y restaurar claves de cifrado.
Compruebe que ha iniciado sesión con una cuenta de usuario que tenga permisos sysadmin en la instancia de SQL Server.
Compruebe que el servicio Agente SQL Server está instalado y se está ejecutando en la instancia de Motor de base de datos que piensa utilizar.
Asocie las bases de datos reportservertempdb y reportserver. No es necesario que asocie las bases de datos para crear la función real, pero deben estar asociadas para poder probar el trabajo.
Las instrucciones para crear manualmente la función RSExecRole están destinadas a utilizarse en el contexto de migración de una instalación del servidor de informes. Las tareas importantes como realizar una copia de seguridad y mover la base de datos del servidor de informes no se tratan en este tema, pero se incluyen en la documentación del motor de base de datos. Para obtener más información sobre todas las tareas de un proceso de migración, vea Migración (Reporting Services).
Crear RSExecRole en la base de datos maestra
Reporting Services utiliza procedimientos almacenados extendidos para que el servicio Agente SQL Server admita las operaciones programadas. En los pasos siguientes se explica cómo conceder permisos de ejecución para los procedimientos a la función RSExecRole.
Para crear la función RSExecRole en la base de datos del sistema maestra mediante Management Studio
Inicie SQL Server Management Studio y conéctese a una instancia de Motor de base de datos que hospede la base de datos del servidor de informes.
Abra Bases de datos.
Abra Bases de datos del sistema.
Abra Maestra.
Abra Seguridad.
Abra Funciones.
Haga clic con el botón secundario en Funciones de base de datos y seleccione Nueva función de la base de datos. Aparece la página General.
En Nombre de función, escriba RSExecRole.
En Propietario, escriba DBO.
Haga clic en Elementos que pueden protegerse.
Haga clic en Buscar. Aparece el cuadro de diálogo Agregar objetos. La opción Especificar objetos está seleccionada de forma predeterminada.
Haga clic en Aceptar. Aparece el cuadro de diálogo Seleccionar objetos.
Haga clic en Tipos de objeto.
Haga clic en Procedimientos almacenados extendidos.
Haga clic en Aceptar.
Haga clic en Examinar.
Desplácese hacia abajo en la lista de procedimientos almacenados extendidos y seleccione los siguientes:
xp_sqlagent_enum_jobs
xp_sqlagent_is_starting
xp_sqlagent_notify
Haga clic en Aceptar y, a continuación, vuelva a hacer clic en Aceptar.
En la fila Ejecutar, en la columna Conceder, haga clic en la casilla y, a continuación, haga clic en Aceptar.
Repita estos pasos con cada uno de los procedimientos almacenados restantes. Se deben conceder a la función RSExecRole permisos de ejecución para los tres procedimientos almacenados.
Crear la función RSExecRole en la base de datos MSDB
Reporting Services utiliza procedimientos almacenados para el servicio Agente SQL Server y recupera información de los trabajos en las tablas del sistema para admitir las operaciones programadas. En los pasos siguientes se explica cómo conceder a la función RSExecRole permisos de ejecución para los procedimientos y permisos de selección en las tablas.
Para crear la función RSExecRole en la base de datos del sistema MSDB
Repita los pasos similares para conceder permisos a procedimientos almacenados y tablas en MSDB. Para simplificar los pasos, proporcionará los procedimientos almacenados y las tablas de forma independiente.
Abra MSDB.
Abra Seguridad.
Abra Funciones.
Haga clic con el botón secundario en Funciones de base de datos y seleccione Nueva función de la base de datos. Aparece la página General.
En Nombre de función, escriba RSExecRole.
En Propietario, escriba DBO.
Haga clic en Elementos que pueden protegerse.
Haga clic en Agregar. Aparece el cuadro de diálogo Agregar objetos. La opción Especificar objetos está seleccionada de forma predeterminada.
Haga clic en Aceptar.
Haga clic en Tipos de objeto.
Haga clic en Procedimientos almacenados.
Haga clic en Aceptar.
Haga clic en Examinar.
Desplácese hacia abajo en la lista de elementos y seleccione los siguientes:
sp_add_category
sp_add_job
sp_add_jobschedule
sp_add_jobserver
sp_add_jobstep
sp_delete_job
sp_help_category
sp_help_job
sp_help_jobschedule
sp_verify_job_identifiers
Haga clic en Aceptar y, a continuación, vuelva a hacer clic en Aceptar.
Seleccione el primer procedimiento almacenado: sp_add_category.
En la fila Ejecutar, en la columna Conceder, haga clic en la casilla y, a continuación, haga clic en Aceptar.
Repita este paso con cada uno de los procedimientos almacenados restantes. Se deben conceder a la función RSExecRole permisos de ejecución para los diez procedimientos almacenados.
En la ficha Elementos que pueden protegerse, haga clic en Agregar de nuevo. Aparece el cuadro de diálogo Agregar objetos. La opción Especificar objetos está seleccionada de forma predeterminada.
Haga clic en Aceptar.
Haga clic en Tipos de objeto.
Haga clic en Tablas.
Haga clic en Aceptar.
Haga clic en Examinar.
Desplácese hacia abajo en la lista de elementos y seleccione los siguientes:
syscategories
sysjobs
Haga clic en Aceptar y, a continuación, vuelva a hacer clic en Aceptar.
Seleccione la primera tabla: syscategories.
En la fila Seleccionar, en la columna Conceder, haga clic en la casilla y, a continuación, haga clic en Aceptar.
Repita este procedimiento con la tabla sysjobs. Se deben conceder a la función RSExecRole permisos de selección para ambas tablas.
Mover la base de datos del servidor de informes
Después de crear las funciones, puede mover la base de datos del servidor de informes a una instancia nueva de SQL Server. Para obtener más información, vea Mover las bases de datos del servidor de informes a otro equipo.
Si va a actualizar Motor de base de datos a SQL Server 2008, puede hacerlo antes o después de mover la base de datos.
La base de datos del servidor de informes se actualizará a SQL Server 2008 automáticamente cuando el servidor de informes se conecte a ella. No hay ningún paso concreto requerido para actualizar la base de datos.
Restaurar las claves de cifrado y comprobar el trabajo
Si ha asociado las bases de datos del servidor de informes, ahora debe poder completar los pasos siguientes para comprobar el trabajo.
Para comprobar la capacidad de operación del servidor de informes después de mover una base de datos
Inicie la herramienta Configuración de Reporting Services y conéctese al servidor de informes.
Haga clic en Base de datos.
Haga clic en Cambiar base de datos.
Haga clic en Elegir una base de datos del servidor de informes existente.
Escriba el nombre del servidor del motor de base de datos. Si ha asociado las bases de datos del servidor de informes a una instancia con nombre, debe escribir el nombre de la instancia con este formato: < nombreDeServidor>\<nombreDeInstancia>.
Haga clic en Probar conexión.
Haga clic en Siguiente.
En Base de datos, seleccione la base de datos del servidor de informes.
Haga clic en Siguiente y complete el asistente.
Haga clic en Claves de cifrado.
Haga clic en Restaurar.
Seleccione el archivo seguro (.snk) que tiene la copia de seguridad de la clave simétrica utilizada para descifrar las credenciales almacenadas y la información de conexión en la base de datos del servidor de informes.
Escriba la contraseña y haga clic en Aceptar.
Haga clic en Dirección URL del Administrador de informes.
Haga clic en el vínculo para abrir el Administrador de informes. Debe ver los elementos del servidor de informes de la base de datos del servidor de informes.
Vea también