Hace un par de meses estuvimos trabajando en un proyecto de escalabilidad de bases de datos, y entre otras cosas, uno de los datos que necesitábamos conocer era la memoria utilizada por cada base de datos en una instancia de SQL Server.

El escenario era el siguiente: una instancia de SQL Server daba servicio a un número de bases de datos que estaban distribuidas de la siguiente forma:

  • Una base de datos “general” que era compartida por todas las aplicaciones que usaban el servidor de base de datos.
  • Una base de datos por empresa que hacía uso del servicio.

Necesitábamos conocer cuanta memoria usaba cada base de datos “de empresa”, porque parte del trabajo consistía en conocer a cuantas bases de datos podría dar servicio la instalación. El objetivo era grosso modo, conocer cuantas páginas de datos utilizaba cada base de datos de la instalación.

Para ello usamos la siguiente consulta (extraído de BOL) que devuelve las páginas de datos asignadas a cada BD:

SELECT

count(*) AS cached_pages_count

, count(*) * 8. / 1024 AS MB

,CASE database_id

WHEN 32767 THEN ‘ResourceDb’

ELSE db_name(database_id)

END AS Database_name

FROM sys.dm_os_buffer_descriptors

GROUP BY db_name(database_id) ,database_id

ORDER BY cached_pages_count DESC

 

A este dato obtenido hay que añadirle el resto de componentes de SQL Server; por ejemplo, memoria asignada para bloqueos, caché de procesos, servidores vinculados, etc. pero si nos da una aproximación muy real del porcentaje de memoria total que utiliza cada base de datos. Al fin y al cabo, es cuestión de contar habas J

En otro post, veremos caché de procesos, y otros componentes…

0 Shares:
Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

You May Also Like
Leer más

Backups y restores “al vuelo” sin almacenamiento intermedio

Seguramente los más “senior” recordarán la posibilidad que existía en versiones SQL Server antiguas de realizar backups utilizando named pipes. Cuando hablo de versiones antiguas, me refiero a “antiguas de verdad”, ya que esta funcionalidad fue marcada como obsoleta en SQL Server 7, se mantuvo en SQL 2000 pero ya se eliminó de SQL Server 2005 y posteriores.