Auditorias SQL
Auditorias SQL
Auditorias SQL
PASO A PASO
Fecha: 22-02-2019
Este documento técnico es solo para fines informativos. TriggerDB Consulting NO OTORGA NINGUNA GARANTÍA,
EXPRESA, IMPLÍCITA O ESTATUTARIA, CON RESPECTO A LA INFORMACIÓN CONTENIDA EN ESTE DOCUMENTO.
El cumplimiento de todas las leyes de copyright aplicables es responsabilidad del usuario. Sin limitar los derechos protegidos
por derechos de autor, ninguna parte de este documento puede reproducirse, almacenarse o introducirse en un sistema de
recuperación, ni transmitirse de ninguna forma ni por ningún medio (electrónico, mecánico, fotocopia, grabación u otro), o por
cualquier propósito, sin el permiso expreso por escrito de TriggerDB Consulting.
TriggerDB Consulting puede tener patentes, solicitudes de patentes, marcas comerciales, derechos de autor u otros
derechos de propiedad intelectual que cubran el contenido de este documento. Salvo que se indique expresamente en
cualquier acuerdo de licencia por escrito de TriggerDB Consulting, el suministro de este documento no le otorga ninguna
licencia sobre estas patentes, marcas comerciales, derechos de autor u otra propiedad intelectual.
Se especializa como arquitecto, consultor y coach en los productos de Microsoft Data Platform (SQL Server,
Big Data, Powerbi, BI, etc).
Desde el año 1997 trabaja como consultor en SQL Server donde he participado de distintos proyectos para más de 300
empresas de América y Europa, cubriendo todo lo relacionado a SQL Server y BI.
Desde el año 2005 es reconocido por Microsoft como MVP en SQL Server donde he recibido más de 12 premios.
Participa como orador de SQL Server desde el año 2003 donde ha impartido más de 200 conferencias a nivel mundial, entre
ellas (Lanzamientos de SQL, eventos para comunidades y universidades, webinars y otros tantos más)
https://twitter.com/maxiaccotto
https://www.linkedin.com/in/maxiaccotto/
En el área de seguridad informática es necesario en muchos casos poder contar con una auditorias de las operaciones que
suceden en el motor de base de datos.
En esta guía vamos a ver paso a paso como se implementan las auditorias nativas que tiene SQL Server desde su versión 2008
o superior (https://docs.microsoft.com/en-us/sql/relational-databases/security/auditing/sql-server-audit-database-engine)
Debemos mencionar que para usar todas las funcionalidades de auditoria se requiere edición Enterprise de SQL Server ya
que la Standard tiene la funcionalidad, pero de forma limitada.
3 COMPONENTES
Server Audit Es el objeto principal, aquí se definen por ejemplo los lugares de persistencia de las
auditorias (file, security Log o Application Log.
Se pueden crear más de uno a nivel instancia
Server Audit Specifications Permite auditar eventos a nivel instancia por ej. (Login Fail, créate database, etc.)
Es necesario que exista un Server Audit y se pueden crear más de uno
Database Audit Permite auditar eventos a nivel base de datos por ej. (Select, insert, alter, etc)
Specifications Es necesario que exista un Server Audit y se crean a nivel base de datos, por cada una de
las que se desea tener este tipo de auditoria
El primer paso es crear los SERVER AUDIT, en ellos se podrá definir la persistencia y otras configuraciones adicionales.
En la guía crearemos dos Server Audit (uno para los eventos de instancia y otro para los de base de datos)
• Para crear, modificar o quitar una auditoría de servidor, las entidades de seguridad deben tener el permiso ALTER
ANY SERVER AUDIT o CONTROL SERVER.
• Los usuarios con el permiso ALTER ANY SERVER AUDIT pueden crear especificaciones de auditoría de servidor y
enlazarlas a cualquier auditoría.
• Una vez creada una especificación de auditoría de servidor, las entidades de seguridad que cuenten con los permisos
CONTROL SERVER o ALTER ANY SERVER AUDIT, así como la cuenta sysadmin, o las entidades de seguridad que tengan
acceso explícito a la auditoría podrán ver dicha especificación.
Queue delay Especifica la cantidad de tiempo, en milisegundos, que puede transcurrir antes de exigir que se
procesen las acciones de auditoría. El valor 0 indica la entrega sincrónica. El valor mínimo
predeterminado es 1000 (1 segundo). El máximo es 2.147.483.647 (2.147.483,647 segundos, o 24
días, 20 horas, 31 minutos y 23,647 segundos).
On Audit Log Failure Continue: SQL Server Las operaciones de continúan. Los registros de auditoría no se conservan. La
auditoría continúa intentando el registro de eventos y se reanudará si se resuelve la condición de
error. La selección de la opción Continuar puede permitir que una actividad no se audite, con lo que se
infringirían las directivas de seguridad. Seleccione esta opción cuando la operación de continuación
del Motor de base de datos sea más importante que el mantenimiento de una auditoría completa. Esta
es la selección predeterminada
Shut Down Server: Fuerza el apagado del servidor cuando la instancia de servidor que escribe en el
destino no puede escribir datos en el destino de la auditoría. Para poder usarlo, es preciso utilizar un
inicio de sesión con el permiso SHUTDOWN . Si el inicio de sesión no tiene dicho permiso, la función
generará un error y se mostrará un mensaje de error. No se producirán eventos auditados. Seleccione
esta opción si un error de auditoría puede poner en peligro la seguridad o la integridad del sistema.
Fail Operation: En los casos en que SQL Server Audit no puede escribir en el registro de auditoría,
esta opción haría que las acciones de base de datos produjesen un error si generasen eventos
auditados. No se producirán eventos auditados. Las acciones que no producen eventos auditados
pueden continuar. La auditoría continúa intentando el registro de eventos y se reanudará si se
resuelve la condición de error. Seleccione esta opción si el mantenimiento de una auditoría completa
es más importante que el acceso total al Motor de base de datos.
Nota: para todos los casos la cuenta de servicio del engine debe tener los permisos adecuados ya sea
para escribir en las carpetas o en los eventos del SO
File path La ruta donde se guardarán los archivos, en nuestro primer ejemplo hemos seleccionado
“D:\TMP\AuditSQL\Instance” ya que ahí guardaremos los archivos para los eventos de instancia
Maximum file Size Por defecto esta opción deja tener tamaño ilimitado, en nuestra guía y en base a nuestra experiencia
configuraremos que los archivos no puedan tener más de 2GB cada uno
En este paso vamos a crear un Server Audit Specification para así poder auditar los eventos que nos interesa a nivel
instancia.
En el siguiente link se encuentran los distintos eventos que se pueden auditar a nivel instancia y asignarlos al Server Audit
Specification
https://docs.microsoft.com/es-mx/sql/relational-databases/security/auditing/sql-server-audit-action-groups-and-actions
• Para crear, modificar o quitar una auditoría de servidor, las entidades de seguridad deben tener el permiso ALTER
ANY SERVER AUDIT o CONTROL SERVER.
• Los usuarios con el permiso ALTER ANY SERVER AUDIT pueden crear especificaciones de auditoría de servidor y
enlazarlas a cualquier auditoría.
• Una vez creada una especificación de auditoría de servidor, las entidades de seguridad que cuenten con los permisos
CONTROL SERVER o ALTER ANY SERVER AUDIT, así como la cuenta sysadmin, o las entidades de seguridad que tengan
acceso explícito a la auditoría podrán ver dicha especificación.
Audit Aquí debemos seleccionar el Server Audit en el cual se persistirán los eventos (los hemos
creado en el paso anterior) , en nuestro ejemplo usaremos “Audit-TriggerDB-Instance”
Actions Aquí seleccionaremos los eventos a auditar, para este ejemplo solo hemos elegido dos
USE [master]
GO
CREATE SERVER AUDIT SPECIFICATION
[ServerAuditSpecification-triggerdb]
FOR SERVER AUDIT [Audit-TriggerDB-Instance]
ADD (FAILED_LOGIN_GROUP),
ADD (LOGIN_CHANGE_PASSWORD_GROUP)
GO
ALTER SERVER AUDIT SPECIFICATION
[ServerAuditSpecification-triggerdb]
WITH (STATE = ON);
A diferencia del Server Audit Specification, los Database Audit Specification se deben crear por cada una de las bases de
datos que se desee auditar.
Este objeto reside en la metada de la base de datos con lo cual un Backup / Restore también incluirá estas definiciones.
• Los usuarios con el permiso ALTER ANY DATABASE AUDIT pueden crear las especificaciones de auditoría de base de
datos y enlazarlas a cualquier auditoría.
• Después de crearse una especificación de auditoría de base de datos, podrá ser vista por las entidades de seguridad
que cuenten con los permisos CONTROL SERVER o ALTER ANY DATABASE AUDIT, o por la cuenta sysadmin
En la mayoría de las empresas lo que se desea auditar (sobre todo a nivel base de datos) son las operaciones realizadas por
usuarios fuera de las aplicaciones de gestión. Un ejemplo, seria poder capturar un UPDATE o un SELECT de un usuario
utilizando herramientas como Management Studio, Excel, etc.
A tal fin y en base a nuestra experiencia implementando auditorias en varias empresas es que aconsejamos aplicar un filtro
de que usuarios vamos a realmente auditar así luego nuestro log no se llena con eventos que quizás nunca veremos.
Para hacer esta operación hay dos formas posibles que luego veremos a continuación a lo largo de esta guía.
Esta operación la haremos sobre la base de datos que deseamos auditar, en nuestro ejemplo usaremos
“AdventureWorks2014”
Audit(*) Aquí debemos seleccionar el Server Audit en el cual se persistirán los eventos. En nuestro
ejemplo seleccionamos “Audit-TriggerDB-DB” ya que hemos divido los eventos de servidor
de los de base de datos en dos Server Audit distintos.
Audit Action Type (*) Aquí seleccionaremos los eventos a auditar. En el siguiente link se encuentra el listado de
todos los eventos disponibles
https://docs.microsoft.com/es-mx/sql/relational-databases/security/auditing/sql-server-
audit-action-groups-and-actions
Object Class(*) Aquí debe seleccionar el tipo de objeto a auditar donde las opciones son:
Database: Se auditarán todos los objetos de la base de datos
Object: Solo se auditará el objeto seleccionado (por ejemplo, una tabla en particular)
Schema: Se auditarán los objetos que estén dentro del schema (por ejemplo, DBO)
Object Schema Si se selecciona en object class auditar un schema, en este campo deberá indicar cuál.
Object Name Debe indicar el nombre del objeto a auditar ya sea para Database u Object. En nuestro caso
hemos seleccionado Adventureworks2014 que es el nombre de la base de datos
Principal Name(*) Aquí debe elegir un Database Role, un usuario o un Application Role.
En nuestro ejemplo hemos seleccionado al role Public , lo cual indica que auditaremos a
todos los usuarios.
Si desea no auditar a los usuarios de la aplicación y si a los externos, una alternativa seria
crear un role en cada base de datos (por ejemplo, llamado Auditoria) y seleccionar ese role
en principal name (en lugar del public)
Si además desea auditar a los Sysadmin de su servidor (estos por lo general no son ni
usuarios de sus bases de datos) debería agregar a los mismos eventos el role dbo (como se
muestra en la figura siguiente)
*Campos obligatorios
Como hemos comentado anteriormente en este documento, en la auditoria quizás no tenga sentido que se registren los
eventos provenientes de las aplicaciones de gestión y si de las externas.
Al crear el Database Audit Specification hemos visto que podríamos resolver esto creando un role en la base de datos y luego
asignando a los usuarios que debemos auditar en dicho role , seria técnicamente como poderlos agrupar de alguna forma.
En esta sección veremos una segunda técnica que directamente aplica al Server Audit y es la posibilidad de filtrar ahí mismo
sin importar de donde se haga el evento.
Este método si tenemos muchas bases de datos quizás es mejor que el anterior ya que nos permite mejorar la
administración.
Tenga cuidado si por ejemplo desea auditar eventos en el Server Audit Specification como SUCCESFUL_LOGIN_GROUP y otros
eventos más en la misma especificación, si filtra los de la aplicación estará perdiendo de datos. Imagine que desea auditar
login sucess y cambios de clave y no le interesa ver en su auditoria los de login sucess que sean del login de la aplicación (le
llenera el log seguramente y esa información es probable que no sea relevante para un departamento de seguridad
informática).
Para resolver este ultima caso lo que usted debería hacer es crear dos Server Audit distintos (uno con filtro y el otro no) y
dos Server Audit Specification distintos (por ejemplo, los eventos de Successful_login_group en uno y en el otro el resto)
Para aplicar los filtros sobre un Server Audit ya existente se deben seguir los siguientes pasos
Nota: en este ejemplo hemos seleccionado el Server Audit que hemos creado para persistir los eventos de base de datos y le
hemos agregado el filtro para que excluya a los login SQL1 y SQL2
Para poder ver los distintos eventos con su correspondiente detalle existen dos alternativas que veremos a continuación.
Desde el propio SSMS se pueden ver los registros del log, para eso lo que se debe hacer es lo siguiente sobre el Server Audit
que deseamos observar
Si hacemos el mismo procedimiento sobre el server Audit que alojamos los eventos de base de datos veremos los mismos
atributos, pero obviamente con otros datos
Para poder usar esta opción SQL Server dispone de una función llamada sys.fn_get_audit_file
(https://docs.microsoft.com/en-us/sql/relational-databases/system-functions/sys-fn-get-audit-file-transact-sql)
Con la cual podemos leer los archivos de auditoria y que el resultado sea una tabla para luego verlo o integrarlo con otras
soluciones.
Con esta función y las vistas de SQL Server correspondientes a Audit se puede buscar toda la información necesaria
sys.server_audits Contiene una fila para cada auditoría de SQL Server de una instancia de
servidor
https://docs.microsoft.com/en-us/sql/relational-databases/system-catalog-views/sys-server-
audits-transact-sql
sys.dm_server_audit_status Devuelve una fila para cada auditoría de servidor que indica el estado actual
de la misma
https://docs.microsoft.com/es-es/sql/relational-databases/system-dynamic-management-views/sys-
dm-server-audit-status-transact-sql
sys.dm_audit_actions Devuelve una fila por cada acción de auditoría sobre la que se puede guardar
información en el registro de auditoría y por cada grupo de acciones de
auditoría que se puede configurar como parte de SQL Server Audit
https://docs.microsoft.com/es-es/sql/relational-databases/system-dynamic-management-views/sys-
dm-audit-actions-transact-sql
sys.dm_audit_class_type_map Devuelve una tabla que asigna el campo class_type del registro de auditoría al
campo class_desc en sys.dm_audit_actions
https://docs.microsoft.com/es-es/sql/relational-databases/system-dynamic-management-views/sys-
dm-audit-class-type-map-transact-sql
SELECT A.NAME,
A.class_desc,
A.parent_class_desc,
A.covering_parent_action_name,
F.*
FROM sys.fn_get_audit_file
(@PATH,default,default) as F
left join sys.dm_audit_actions A
on F.action_id = A.action_id
ORDER BY EVENT_TIME DESC;
GO
La utilización de eventos y asincronismo hacen que las implementaciones de las auditorias nativas no tengan impacto en la
performance de nuestro motor como si suele suceder con otras técnicas como por ejemplo el uso de trigger.
Las auditorias están disponibles desde SQL Server 2008 lo cual la hacen una funcionalidad madura.
Si bien se pueden usar otros métodos de auditoria (extend Events y profiler entre otros) las auditorias nativas son robustas y
contienen todo lo necesario para una implementación adecuada.