Добро пожаловать в форум, Guest  >>   Войти | Регистрация | Поиск | Правила | В избранное | Подписаться
Все форумы / Microsoft SQL Server Новый топик    Ответить
 Как определить источник замедления SQL Server?  [new]
BusyMan
Member

Откуда: Москва
Сообщений: 4927
Я пытался гуглить и смотреть FAQ чтобы найти некий список того на что нужно смотреть в случаях когда SQL Server становится внезапно медленный и зашкаливает CPU. Все статьи нацелены на то чтобы исправить проблему и допустим 10 человек имеют сотню идей где какие запросы и как исправить, но меня интересует кое что другое. Как узнать какой конкретно запрос или приложение вызывает глобальное замедление сервера. Все статьи рассказывают о том как искать медленные запросы и т.п. но нигде почему то не пишут про то как измерить саму медленность и как определить что именно ее вызывает?
3 сен 15, 06:16    [18102091]     Ответить | Цитировать Сообщить модератору
 Re: Как определить источник замедления SQL Server?  [new]
Glory
Member

Откуда:
Сообщений: 104760
BusyMan
но нигде почему то не пишут про то как измерить саму медленность

И в чем мерять "медленность"

BusyMan
и как определить что именно ее вызывает?

Как раз про это и пишут во всех статьях - про счетчики, про планы и тп
3 сен 15, 08:18    [18102207]     Ответить | Цитировать Сообщить модератору
 Re: Как определить источник замедления SQL Server?  [new]
aleks2
Guest
Glory
Как раз про это и пишут во всех статьях - про счетчики, про планы и тп

Поциенту надо найти сам запрос. А ужо потом счетчики и планы...

BusyMan
но нигде почему то не пишут про то как измерить саму медленность и как определить что именно ее вызывает?

"Медленность" измеряется временем исполнения.
А вызывает ее
a) объективные причины: большой объем перемалываемый запросом и/или загруженность сервера.
б) субъективные причины: криво написанный запрос и криво спроектированная структура данных.

Бороться с а) почти бесполезно.

Бороться с б) можно и нужно.
3 сен 15, 08:31    [18102230]     Ответить | Цитировать Сообщить модератору
 Re: Как определить источник замедления SQL Server?  [new]
Glory
Member

Откуда:
Сообщений: 104760
aleks2
Glory
Как раз про это и пишут во всех статьях - про счетчики, про планы и тп

Поциенту надо найти сам запрос. А ужо потом счетчики и планы...

Если у него 1Гб памяти и 100Гб данных, то нафиг ему текст запроса ?
3 сен 15, 08:35    [18102238]     Ответить | Цитировать Сообщить модератору
 Re: Как определить источник замедления SQL Server?  [new]
alukardD
Member

Откуда: USSR
Сообщений: 3369
1) посмотри "sp_who2 active" - объект внимания - наличие блокировок а также то, что происходит на сервере - нет ли построения индексов и т.д.
2) посмотри какие есть ожидания...можешь сбросить статистику сначала
+
/*
--clean statistics
DBCC SQLPERF (N'sys.dm_os_wait_stats', CLEAR);
GO
*/


WITH [Waits] AS
(SELECT
[wait_type],
[wait_time_ms] / 1000.0 AS [WaitS],
([wait_time_ms] - [signal_wait_time_ms]) / 1000.0 AS [ResourceS],
[signal_wait_time_ms] / 1000.0 AS [SignalS],
[waiting_tasks_count] AS [WaitCount],
100.0 * [wait_time_ms] / SUM ([wait_time_ms]) OVER() AS [Percentage],
ROW_NUMBER() OVER(ORDER BY [wait_time_ms] DESC) AS [RowNum]
FROM sys.dm_os_wait_stats
WHERE [wait_type] NOT IN (
N'CLR_SEMAPHORE', N'LAZYWRITER_SLEEP',
N'RESOURCE_QUEUE', N'SQLTRACE_BUFFER_FLUSH',
N'SLEEP_TASK', N'SLEEP_SYSTEMTASK',
N'WAITFOR', N'HADR_FILESTREAM_IOMGR_IOCOMPLETION',
N'CHECKPOINT_QUEUE', N'REQUEST_FOR_DEADLOCK_SEARCH',
N'XE_TIMER_EVENT', N'XE_DISPATCHER_JOIN',
N'LOGMGR_QUEUE', N'FT_IFTS_SCHEDULER_IDLE_WAIT',
N'BROKER_TASK_STOP', N'CLR_MANUAL_EVENT',
N'CLR_AUTO_EVENT', N'DISPATCHER_QUEUE_SEMAPHORE',
N'TRACEWRITE', N'XE_DISPATCHER_WAIT',
N'BROKER_TO_FLUSH', N'BROKER_EVENTHANDLER',
N'FT_IFTSHC_MUTEX', N'SQLTRACE_INCREMENTAL_FLUSH_SLEEP',
N'DIRTY_PAGE_POLL', N'SP_SERVER_DIAGNOSTICS_SLEEP')
)
SELECT
[W1].[wait_type] AS [WaitType],
CAST ([W1].[WaitS] AS DECIMAL(14, 2)) AS [Wait_S],
CAST ([W1].[ResourceS] AS DECIMAL(14, 2)) AS [Resource_S],
CAST ([W1].[SignalS] AS DECIMAL(14, 2)) AS [Signal_S],
[W1].[WaitCount] AS [WaitCount],
CAST ([W1].[Percentage] AS DECIMAL(4, 2)) AS [Percentage],
CAST (([W1].[WaitS] / [W1].[WaitCount]) AS DECIMAL (14, 4)) AS [AvgWait_S],
CAST (([W1].[ResourceS] / [W1].[WaitCount]) AS DECIMAL (14, 4)) AS [AvgRes_S],
CAST (([W1].[SignalS] / [W1].[WaitCount]) AS DECIMAL (14, 4)) AS [AvgSig_S]
FROM [Waits] AS [W1]
INNER JOIN [Waits] AS [W2]
ON [W2].[RowNum] <= [W1].[RowNum]
GROUP BY [W1].[RowNum], [W1].[wait_type], [W1].[WaitS],
[W1].[ResourceS], [W1].[SignalS], [W1].[WaitCount], [W1].[Percentage]
HAVING SUM ([W2].[Percentage]) - [W1].[Percentage] < 95; -- percentage threshold
GO
3 сен 15, 09:08    [18102342]     Ответить | Цитировать Сообщить модератору
 Re: Как определить источник замедления SQL Server?  [new]
alukardD
Member

Откуда: USSR
Сообщений: 3369
Посмотри какие запросы больше всего грузят...посмотри план выполнения топовых запросов...может там не хватает индексов.
+
--dbcc freeproccache
SELECT TOP 50
SUBSTRING(eqt.TEXT,(
eqs.statement_start_offset/2) +1
,((CASE eqs.statement_end_offset
WHEN -1 THEN DATALENGTH(eqt.TEXT)
ELSE eqs.statement_end_offset
END - eqs.statement_start_offset)/2)+1)
,eqs.execution_count
,eqs.last_elapsed_time/1000000 AS Last_elapsed_time_Secs
,eqs.total_elapsed_time/1000000 AS Total_elapsed_time_Secs
,eqs.total_logical_reads
,eqs.last_logical_reads
,eqs.total_logical_writes
,eqs.last_logical_writes
,eqs.total_worker_time
,eqs.last_worker_time
,eqs.last_execution_time
,eqp.query_plan
FROM sys.dm_exec_query_stats eqs
CROSS APPLY sys.dm_exec_sql_text(eqs.sql_handle) eqt
CROSS APPLY sys.dm_exec_query_plan(eqs.plan_handle) eqp
ORDER BY eqs.total_worker_time DESC
3 сен 15, 09:10    [18102350]     Ответить | Цитировать Сообщить модератору
 Re: Как определить источник замедления SQL Server?  [new]
Mike_za
Member

Откуда: Москва
Сообщений: 1176
Оно же доступно в стандартных отчетах сервера. Правая кнопка мышки ...
3 сен 15, 10:28    [18102736]     Ответить | Цитировать Сообщить модератору
 Re: Как определить источник замедления SQL Server?  [new]
Mind
Member

Откуда: Лучший город на Земле
Сообщений: 2322
BusyMan
Все статьи нацелены на то чтобы исправить проблему
А вам просто нравится смотреть на зависание? Исправлять не нужно?

BusyMan
Как узнать какой конкретно запрос или приложение вызывает глобальное замедление сервера.
Если у вас 10 разных запросов запущенных из разных приложений и каждый потребляет 10% CPU, то кто из них вызывает глобальное замедление сервера?

BusyMan
Все статьи рассказывают о том как искать медленные запросы и т.п.
Так вам же это и было нужно? Узнать какой запрос вызывает глобальное замедление сервера? Медленный запрос является хорошим кандидатом, на то чтобы потреблять много ресурсов, которые в свою очередь нужны другим запросам чтобы быстро выполняться.

BusyMan
как измерить саму медленность и как определить что именно ее вызывает?
К "медленности" приводит нехватка ресурсов.

И как уже тут советовали - смотрите ожидания и блокировки.
3 сен 15, 21:24    [18105656]     Ответить | Цитировать Сообщить модератору
Все форумы / Microsoft SQL Server Ответить