Desafio: Resource Monitor e Paginação de Memória


Esse é um desafio bastante difícil e não ficaria surpreso se aparecesse algo assim na certificação do Microsoft Certified Master. Esse problema envolve o diagnóstico da quantidade de memória disponível no servidor, mas sob uma perspectiva mais abrangente. Torna-se necessário compreender o cenário como um todo ao invés de analisar os erros pontualmente.

Estava lendo o artigo de suporte KB 918483 relacionado com alta utilização de memória que tem um trecho do ERRORLOG:

How to reduce paging of buffer pool memory in the 64-bit version of SQL Server
http://support.microsoft.com/kb/918483/en-us

2009-05-05 15:43:56.01 Server Resource Monitor (0x13c43) Worker 0x0412C1E8 appears to be non-yielding on Node 0. Memory freed: 34152 KB. Approx CPU Used: kernel 171 ms, user 140 ms, Interval: 125093.
2009-05-05 12:54:52.18 Server * *******************************************************************************
2009-05-05 12:54:52.18 Server * BEGIN STACK DUMP:
2009-05-05 12:54:52.18 Server * 05/05/08 12:54:52 spid 0
2009-05-05 12:54:52.18 Server * Non-yielding Resource Monitor
2009-05-05 12:54:52.18 Server * *******************************************************************************
2009-06-10 09:13:53.44 Server * *******************************************************************************
2009-06-10 09:13:53.44 Server * BEGIN STACK DUMP:
2009-06-10 09:13:53.44 Server * 06/10/09 09:13:53 spid 0
2009-06-10 09:13:53.44 Server * Non-yielding IOCP Listener
2009-06-10 09:13:53.44 Server * *******************************************************************************
2009-06-10 09:13:55.85 spid2s LazyWriter: warning, no free buffers found.
2009-07-15 13:27:45.35 spid4s AppDomain xx (SQLCLR.dbo[runtime].xx) is marked for unload due to memory pressure.
2009-07-15 13:27:45.35 spid4s AppDomain xx (SQLCLR.dbo[runtime].xx) unloaded.
2009-07-15 13:37:51.42 Logon Error: 17189, Severity: 16, State: 1.
2009-07-15 13:37:51.42 Logon SQL Server failed with error code 0xc0000000 to spawn a thread to process a new login or connection. Check the SQL Server error log and the Windows event logs for information about possible related problems. [CLIENT: xx.xxx.xx.xx]

 

A pergunta é como interpretar todas essas mensagens de erro e por qual motivo que elas aparecem no ERRORLOG.

  1. Qual o motivo do Stack Dump?
  2. Qual a relação entre o Lazy Writer e as mensagens de erro do SQLCLR?
  3. Qual o impacto do erro de Logon?

Por fim, qual problema (provavelmente) ocorreu no servidor que levou a todos esses erros?

Postem os seus comentários e opiniões!

Skip to main content