172 похожих чатов

В чем sex идеи? Сжимать на диске место, занятое файлом

данных?

13 ответов

7 просмотров

Удалять что то это очень больно и очень медленно поэтому пг не удаляет а оставляет как есть, когда дисковое место кончилось приходит админ и запускает vacuum, не так?

central hardware
Удалять что то это очень больно и очень медленно п...

ага в 3 часа ночи. бд встает раком и будится админ почистить место

central hardware
Удалять что то это очень больно и очень медленно п...

Не вакуум, а вакуум фулл. Который не запускается, потому что нет места на диске.

central hardware
Мониторинг наше все

мониторинг сработал пораньше в 2 часа ночи, БД не упала, все равно херня какая-то :)

Читайте документацию и курсы АБД от ПостгресПро. Там всё есть в удобоваримом и понятном виде.

central hardware
Удалять что то это очень больно и очень медленно п...

Вообще не так. Вакуум чистит версии данных которые никакая транзакция уже не увидит. Освободившееся место переиспользуется

Igor-IT Автор вопроса
Михаил Шурутов
Читайте документацию и курсы АБД от ПостгресПро. Т...

Я посмотрел все три DBA. Знаю что есть. Не знаю, кто и зачем придумал.

Igor IT
Я посмотрел все три DBA. Знаю что есть. Не знаю, к...

Я вот не знаю, что непонятно в этих двух абзацах из документации (https://postgrespro.ru/docs/postgresql/14/routine-vacuuming) , для понять, ЗАЧЕМ: В PostgreSQL команды UPDATE или DELETE не вызывают немедленного удаления старой версии изменяемых строк. Этот подход необходим для реализации эффективного многоверсионного управления конкурентным доступом (MVCC, см. Главу 13): версия строки не должна удаляться до тех пор, пока она остаётся потенциально видимой для других транзакций. Однако в конце концов устаревшая или удалённая версия строки оказывается не нужна ни одной из транзакций. После этого занимаемое ей место должно быть освобождено и может быть отдано новым строкам, во избежание неограниченного роста потребности в дисковом пространстве. Это происходит при выполнении команды VACUUM. Обычная форма VACUUM удаляет неиспользуемые версии строк в таблицах и индексах и помечает пространство свободным для дальнейшего использования. Однако это дисковое пространство не возвращается операционной системе, кроме особого случая, когда полностью освобождаются одна или несколько страниц в конце таблицы и можно легко получить исключительную блокировку таблицы. Команда VACUUM FULL, напротив, кардинально сжимает таблицы, записывая абсолютно новую версию файла таблицы без неиспользуемого пространства. Это минимизирует размер таблицы, однако может занять много времени. Кроме того, для этого требуется больше места на диске для записи новой копии таблицы до завершения операции. Написано по-русски. Понятно.

Igor-IT Автор вопроса
Михаил Шурутов
Я вот не знаю, что непонятно в этих двух абзацах и...

Странно, почему в Oracle Database американцы это не сделали?

Igor IT
Странно, почему в Oracle Database американцы это н...

Потому что oracle - это oracle, а постгрес, это постгрес. ВНЕЗАПНО!

Igor IT
Странно, почему в Oracle Database американцы это н...

Я когда-то разбирал отличия: https://postgrespro.ru/blog/pgsql/17758

Igor IT
Я посмотрел все три DBA. Знаю что есть. Не знаю, к...

MVCC придумал наш бывший соотечественник Вадим Михеев из Красноярска, он был одним из первых core-разработчиков http://www.sai.msu.su/~megera/postgres/mvcc.html

Похожие вопросы

Обсуждают сегодня

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
TCodePointer = record cp: CodePointer; name: string; cnt: Integer; next: TCodePointerArray; // этот тип ещё неизвестен end; TCodePointerArray = array of ...
notme
9
Привет ) есть такой кусок кода, он считывает ini файл. my $conf = Config::IniFiles->new( -file => $ini_file ); if (!$conf) { $self->my_die('cannot_read_cfg', ...
Kolya lastname
7
Добрый день. Хочу сделать отрисовку по команде на панели. Почему-то рисуется только при втором вызове. С чем может быть связано, не подскажете? procedure TForm1.FormDblClick(...
Kirill Filippenok
20
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Блин, интересно, кто-нибудь когда-нибудь переписывал какую-нибудь игру с x86 на arm? Вообще, такое возможно?
Alan 🔝 Бэброу
13
Эх кто-то пришел и весь праздник испортил :( You need complex FBX scene importing setup to change things on import? good luck with that. You need navigation and pathfinding? g...
Serg Gini
5
Всем привет! Нужен совет от опытных. Переношу свой проект с Делфи 10.2 Токио на Лазарус 3.2 установленный через инсталлятор fpcupdeluxe-x86_64-win64. При импортировании проект...
Дмитрий Завгородний
7
здравствуйте, братья, кто-нибудь знает, как работать с Swift.com или Swift.net?
Ozzy
6
Всем доброго дня! Подскажите может кто использовал связку Pagebuilder + Clientsetting. Сами параметры с типом pagebuilder в модуле Clientsetting работают нормально, можно такж...
Александр Добриков
12
Карта сайта