Аватар для Dima_ABD
0 / 0 / 0
Регистрация: 11.08.2022
Сообщений: 217

Auto-shrink в MS SQL SERVER 2008R2

21.11.2022, 15:37. Показов 2750. Ответов 21
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Почему и чем "опасен" шринк" ("автошринк")???
По умолчанию сервера автосжатие - True, то есть включено по "заводским" настройкам самого майкрософт я так понимаю.... Но при этом всём в "методичках" и "статьях" (я так понимаю, что они официальные, т.к. размещены на оф. сайте) оно типа как бы не рекомендовано, т.к. частое сжатие (частый шринк) приводит к фрагментации данных в файловой системе. (а фрагментация я так понимаю, когда физический порядок страницы не совпадает с логическим, т.е. в новой базе данных этот порядок соблюдается, логический = физическому, но после удаления таблицы он сразу же нарушается???я правильно понимаю?? но не в этом вопрос).
Так вот, после удаления таблиц, место внутри базы освобождается, но на диске база все также осталась ( сиквел сервер не отдает место файловой системе обратно), я применяю шринк (вручную), место освобождается на диске (сиквел сервер отдает это место файловой системе?). И если я все правильно понимаю здесь две стороны:
1. при распухании базы, следует делать шринк (допустим даже вручную), чтобы после удаления данных, вернуть место файловой системе. Это дает плюс "огромный" , ну типа отдает место свободное и база меньше весит, т.е. база не занимает свободное место (место без данных) на диске. Но после шринка появляется фрагментация
2.при определённых действиях база распухает, например при удалении данных, данные внутри базы меньше, но в файловой системе занимает также. Шринк не производится, база распухает, данные весят к примеру 60 гб, а на диске 80гб, 20 гб это свободное место на диске в файловой системе. И данные не займут больше места, пока не займут всё свободное место, т.е. 20 гб.
Я написал много чего как я понимаю и вопросы, на которые хочется получить ответ. Я начинающий АБД. Время чтобы тестить есть, начальство брало меня чтобы выучить как специалиста, который будет все это в будущем контролировать с но правда с постоянным самообучением. Я про себя сказал к слову о том, что много моментов не пойму в силу не понятия слэнга...

Я задался этим вопросом, т.к. у меня база данных: размер 85303,23 МБ и свободно 17759,58 МБ (20,8%). Стоит автошринк, но в вышенаписанном мною я пояснил что не рекомендовано. Вопрос стоит о оптимизации базы , а именно ее размере, попытки ее уменьшить без вреда данным. Может быть сделать перестройку индексов и в дальнейшем отключить автошринк?? Прошу помочь в очередной раз, я не прошу сразу "все карты на стол" и "как все и сразу" сделать, а советов из своего личного опыта и с опытом в применении всех возможных рекомендаций майкрософта в решении такой проблемы или проблем к ним близким.

Добавлено через 1 минуту
Я хоть и без опыта но баз чтобы протестить все варианты хватит.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.11.2022, 15:37
Ответы с готовыми решениями:

Ошибки при установке SQL Server 2008R2
День добрый! Спасите утопающего! Вот уже второй день выношу себе мозг, попытками установить SQL Server 2008R2. Запускаю...

Sql server 2008r2. Ole db подключение выдает ошибку ssl
В реестре выставлял сертификат равный нулю. Tsl 1.2 включен. Драйвер ole db обновлял. В менеджер студио входит под учеткой ,в файле udl...

Не могу установить образец базы данных AdventureWorks на SQL Server 2008R2
Здравствуйте, я новичок в сфере SQL Server. На данный момент я работаю под этой...

21
1306 / 360 / 98
Регистрация: 14.10.2022
Сообщений: 1,103
25.11.2022, 15:21
Студворк — интернет-сервис помощи студентам
Тут только в степень этого надо нужно понимать.
На мой взгляд, делать rebuild надо:
1. В случае, если вы используете кучу, например - для предварительной вставки и модификации данных. Тогда alter table rebuild нужен периодически, т.к. страницы в куче, помеченные на удаление, потом в распределение свободного места не попадают. И это как раз тот момент, когда файл данных бесполезно пухнет.
2. Когда фрагментация на главных таблицах, притом имеющих объем свыше 10-15 Гб выросла свыше 20-25%
3. Когда какой-нибудь дебил сделал кластерный индекс по newid(), и таблица интенсивно используется на вставку/обновления (как в простигосподи exchange) (это, наверное, единственный случай, когда можно настраивать задание на автоматический ребилд, так часто, как только это возможно организационно. И даже не проверять фрагментацию предварительно).
4. Когда был Alter table, особенно с удалением какого либо поля, или с добавлением поле фиксированного размера. Тут нужен alter table rebuild обязательно.

Все. Во всех остальных случаях - это либо бесполезное, либо вредное занятие.
А реорганайз - вообще бесполезная команда, от слова совсем.

А вот статистику пересчитывать, наоборот - нужно так часто, как это возможно по организационным соображениям.

Любимое занятие всех 1С-ников делать каждый вечер ребилд/реорганайз индексов (есть куча навороченных скриптов по этому поводу) - влияет на производительность, в основном, из-за того, что после rebuild индекса идет обновление статистики по нему, бонусом, и соответственно, все кэшированные планы тоже становятся неактуальны (а у 1С прямо болезнь кэшировать планы с идиотскими параметрами, и потом страдать на ровном месте - вчера летало, сегодня восползает).
А вот после реорганайза - не идет. Поэтому рождаются перлы, типа "если индекс фрагментирован менее, чем на 10% - то реорганайз, иначе ребилд".
Но в первом случае - это плацебо, а во втором - "красный стрептоцид", у которого другое действующее начало и оно вообще бесцветное :-)

Все имхо.
Сегодня на работе куча дурной работы, хочется отвлечься :-) Пишу всякую фигню.
0
139 / 105 / 36
Регистрация: 27.07.2022
Сообщений: 359
25.11.2022, 15:53
Цитата Сообщение от uaggster Посмотреть сообщение
Тут только в степень этого надо нужно понимать.
Чтоб понимать степень - нужно как-то все эти нюансы отдельно мониторить и препарировать. Когда десятки инстансов и сотни баз это уже немного утомительно. Проще везде типовые джобы настроить, чем искать, где именно там guid-ы кластерным ключом висят, например
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.11.2022, 15:53
Помогаю со студенческими работами здесь

Настройка Database mail SQL Server 2008R2 на серверах с интернетом и без
Доброго всем дня! Такой вопрос, есть несколько серверов, на некоторых настройка database mail прошла без проблем (по статье...

Остановить синхронизацию в репликации или обновить статус sql server 2008R2?
Проблема следующая: синхронизация зависла и находится в статусе "Runing" и сообщение: "Retrieving subscription information" ...

Некорректная работа DNS server на Windows server 2008r2 ad ds
Доброго времени суток, прошу помощи в анализе проблемы, за ранее извиняюсь за ненадлежащего вида содержания. Имеется небольшой server...

Linked server между MSSQL SERVER 2008R2 и 2000
Здравствуйте,уважаемые форумчане! Такая проблема: Имеется два сервака - MS SQL Server 2008 R2 и MS SQL Server 2000. Необходимо делать...

[Microsoft][ODBC SQL Server Driver][SQL Server]Login failed- User: Reason: Not defined as a valid user of a trusted SQL Server connection
Login failed- User: Reason: Not defined as a valid user of a trusted SQL Server connection Вот такую ошибку выдает. В DSN...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
22
Ответ Создать тему
Опции темы

Новые блоги и статьи
Нейросеть на алгоритме "эстафета хвоста" как перспектива.
Hrethgir 06.05.2026
На десерт, когда запущу сервер. Статья тут https:/ / habr. com/ ru/ articles/ 1030914/ . Автор я сам, нейросеть только помогает в вопросах которые мне не известны - не знаю людей которые знали-бы. . .
Асинхронный приём данных из COM-порта
Argus19 01.05.2026
Асинхронный приём данных из COM-порта Купил на aliexpress термопринтер QR701. Он оказался странным. Поключил к Arduino Nano. Был очень удивлён. Наотрез отказывается печатать русские буквы. Чтобы. . .
попытка написать игровой сервер на C++
pyirrlicht 29.04.2026
попытка написать игровой сервер на плюсах с открытым бесконечным миром. возможно получится прикрутить интерпретатор питон для кастомизации игровой логики. что есть на текущий момент:. . .
Контроль уникальности выбранного документа-основания при изменении реквизита
Maks 28.04.2026
Алгоритм из решения ниже разработан на примере нетипового документа "ЗаявкаНаРемонтСпецтехники", разработанного в КА2. Задача: уведомлять пользователя, если указанная заявка (документ-основание). . .
Благородство как наказание
Maks 24.04.2026
У хорошего человека отношения с женщинами всегда складываются трудно. А я человек хороший. Заявляю без тени смущения, потому что гордиться тут нечем. От хорошего человека ждут соответствующего. . .
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru