Iniciar SQL Server en modo de usuario único

En determinadas circunstancias, puede ser necesario iniciar una instancia de SQL Server en modo de usuario único mediante startup option -m. Por ejemplo, es posible que desee cambiar las opciones de configuración del servidor o recuperar una base de datos master dañada u otra base de datos del sistema. Ambas acciones requieren que se inicie una instancia de SQL Server en modo de usuario único.

Al iniciar SQL Server en modo de usuario único, cualquier miembro del grupo local de administradores del equipo puede conectarse a la instancia de SQL Server como miembro del rol fijo de servidor sysadmin. Para obtener más información, vea Conectarse a SQL Server cuando los administradores del sistema no tienen acceso.

Tenga en cuenta los siguientes aspectos cuando inicie una instancia de SQL Server en modo de usuario único:

  • Solo se podrá conectar al servidor un único usuario.

  • No se ejecuta el proceso CHECKPOINT. De manera predeterminada, se ejecuta automáticamente en el inicio.

[!NOTA]

Detenga el servicio del Agente SQL Server antes de conectarse a una instancia de SQL Server en modo de usuario único; de lo contrario, el servicio del Agente SQL Server utilizará la conexión y, por tanto, la bloqueará.

Al iniciar una instancia de SQL Server en modo de usuario único, SQL Server Management Studio puede conectarse a SQL Server. Se podría producir un error en el Explorador de objetos de Management Studio porque requiere más de una conexión para algunas operaciones. Para administrar SQL Server en modo de usuario único, ejecute las instrucciones de Transact-SQL conectándose solo a través del Editor de consultas de Management Studio o use la utilidad sqlcmd.

Cuando se usa la opción -m con sqlcmd o Management Studio, se pueden limitar las conexiones a una aplicación cliente especificada. Por ejemplo, -m"sqlcmd" limita las conexiones a una conexión única y esa conexión se debe identificar como el programa cliente sqlcmd. Use esta opción cuando esté iniciando SQL Server en modo de usuario único y una aplicación cliente desconocida esté usando la única conexión disponible. Para conectar a través del editor de consultas de Management Studio, use -m"Microsoft SQL Server Management Studio - Query".

Nota de seguridadNota de seguridad

No use esta opción como una característica de seguridad. La aplicación cliente proporciona el nombre de la misma y puede proporcionar un nombre falso como parte de la cadena de conexión.

Nota para instalaciones en clúster

Para la instalación de SQL Server en un entorno en clúster, cuando SQL Server se inicia en modo de usuario único, la DLL de recursos de clúster utiliza la conexión disponible, con lo que impide cualquier otra conexión con el servidor. Cuando SQL Server está en este estado, si se intenta poner en línea el recurso del Agente SQL Server, puede producir la conmutación por error del recurso de SQL a otro nodo si el recurso está configurado para afectar al grupo.

Para solucionar el problema, utilice el procedimiento siguiente:

  1. Quite el parámetro de inicio –m de las propiedades avanzadas de SQL Server.

  2. Ponga sin conexión el recurso de SQL Server.

  3. Desde el nodo de propietario actual de este grupo, ejecute el comando siguiente en el símbolo del sistema: net start MSSQLSERVER /m.

  4. Compruebe en el administrador de clústeres o en la consola de administración de clústeres de conmutación por error que el recurso de SQL Server sigue estando sin conexión.

  5. Conéctese a SQL Server utilizando ahora el comando siguiente y realice la operación necesaria: SQLCMD -E -S<nombreDeServidor>.

  6. Una vez completada la operación, cierre el símbolo del sistema y vuelva a poner en línea SQL y otros recursos mediante el administrador de clústeres.

Vea también

Referencia

sqlcmd (utilidad)

CHECKPOINT (Transact-SQL)

sp_configure (Transact-SQL)

Conceptos

Iniciar, detener o pausar el servicio del Agente SQL Server

Conexión de diagnóstico para administradores de bases de datos

Opciones de inicio del servicio de motor de base de datos