26.01.2024, 16:50 | #1 |
Участник
|
Фрагментация индексов
D365
Обновлена база в PrePROD копией базы из PROD Два индекса на таблице DirPartyRelationship
Как я понимаю, MS поддерживает здоровье индексов в D365, поэтому не очень ясно, почему такая высокая фрагментация? PS: Такая же история,например, с DirPartyTable. На стороне SQL в ней 34 индекса. Среди них 8 имеют фрагментацию больше 90% В CustTable три основных индекса RecID, AccountIdx InvoiceAccountIdx имеют 98% Последний раз редактировалось Lankey; 26.01.2024 в 18:40. |
|
29.01.2024, 10:46 | #2 |
Участник
|
А у вас как? Тоже такая сильная фрагментация на этих индексах?
|
|
29.01.2024, 14:46 | #3 |
Moderator
|
Посмотрел. У меня фрагментация кластерных индексов по recId порядка 50%, фрагментация обычных индексов - порядка 70% (для этих двух таблиц конечно)
Вообще логику отбора индексов для перестроения/реорганизации можно в хранимой процедуре SYS.DM_DB_INDEX_USAGE_STATS Если я там правильно код понял, то индексы с более 500 записей и менее 100 страниц переиндексируются только если за некий период к ним было более 100000 обращений, а индекс с более 100 страниц переиндексируются только если к ним было более 10000 обращений. Как период определяется - я не знаю. Как я подозреваю, можно статистику доступа к индексам какой-то командой сбросить, но какой именно командой и насколько часто она этими скриптами автоиндексации выполняется - я не знаю. Еще у меня было ощущение, что во времена SSD переиндексация не так актуальна, как во времена настоящих жестких дисков, поскольку время последовательного и произвольного чтения/записи для SSD достаточно близки. Последний раз редактировалось fed; 29.01.2024 в 15:24. |
|
|
За это сообщение автора поблагодарили: Lankey (1). |
29.01.2024, 16:49 | #4 |
Участник
|
Цитата:
Цитата: Цитата:
Миф: у нас SSD, поэтому дефрагментация нам не нужна. Еще как нужна! Часто в высоко нагруженных системах не делают дефрагментацию, потому что это сложно. В итоге процент фрагментации выходит на уровень почти 100%, и таблицы занимают в два раза больше страниц, чем нужно. В два раза больше места - это в два раза хуже Buffer Cache Hits Ratio. Это в два раза больше размер full backups. Это в два раза дольше full table scans. Это выше CPU (потому что страницы перемещаются с помощью процессора, а не сами по себе)
|
|
29.01.2024, 22:14 | #5 |
Участник
|
Спасибо большое, что посмотрели! Очень признательна . Есть хоть какие-то теперь ориентиры , чтобы понимать, нормально ли то, что у нас происходит.
Последний раз редактировалось Lankey; 29.01.2024 в 22:16. |
|
25.01.2025, 14:37 | #6 |
Участник
|
Скажите заодно, пожалуйста, на cloud tier 2-3-4-5 кем должна выполняться дефрагментация?
На UAT пользователи жалуются на локи на таблице из ISV модели: когда один процесс update делает , а пользователь (др процесс) открывает форму с данными на просмотр, то его страница виснет. На стороне SQL лок эскалируется на всю таблицу, хоть апдейт по идее полько subset записей обновляет по полю из одного из индексов. Я вижу, что на таблице дефрагментация индексов от 50 до 99 процентов (кластерный 94). Подозреваю, что с такой фрагментацией SQL проще всю таблицу залочить, отсюда проблема.(тут я буду благодарна за другие гипотзы ) В любом случае, с фрагментацией надо, наверное, что-то делать: Нашла https://www.inetdynamics.com.sg/3-ti...s-performance/ , но хотела бы уточнить, вы этим пользуетесь или как-то иначе дефрагментируете? Спасибо |
|