Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
vacuum и размер базы: интересный эффект
|
|||
|---|---|---|---|
|
#18+
жму по очереди команды, в это время никто и ничто с базой не работает, вот что получается: select pg_database_size('db'); ---------------- 848164568 vacuum full analyze; select pg_database_size('db'); ---------------- 848105476 vacuum full analyze; select pg_database_size('db'); ---------------- 848097284 так до какой степени вакуумить? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 30.07.2007, 21:11 |
|
||
|
vacuum и размер базы: интересный эффект
|
|||
|---|---|---|---|
|
#18+
Одной таблетки достаточно. Если хочется ещё уменьшить размер базы, то надо сделать REINDEX Код: plaintext 1. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 31.07.2007, 10:26 |
|
||
|
vacuum и размер базы: интересный эффект
|
|||
|---|---|---|---|
|
#18+
Dan BlackОдной таблетки достаточно. Если хочется ещё уменьшить размер базы, то надо сделать REINDEX Код: plaintext 1. какие команды можно применять во время работы юзеров: 1. vacuum; 2. vacuum full analyze; 3. reindex ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 31.07.2007, 11:03 |
|
||
|
vacuum и размер базы: интересный эффект
|
|||
|---|---|---|---|
|
#18+
Winnipuh какие команды можно применять во время работы юзеров: 1. vacuum; 2. vacuum full analyze; 3. reindex 1. не имеет смысла, если запущен autovacuum (а так сколько угодно) 2. я бы очень не рекоммендовал увлекаться FULL'ом, ибо он эксклюзивно лочит таблицу и в это время ни чтение, ни запись другим пользователям будет не доступно. 3. Полезно. Только учтите, что SELECT'ы, где используется этот индекс будут ждать пока ваш реиндекс не пройдет. Поэтому в некоторых случаях эффективнее сделать DROP/CREATE индексу. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 31.07.2007, 11:53 |
|
||
|
vacuum и размер базы: интересный эффект
|
|||
|---|---|---|---|
|
#18+
Thamerlan Winnipuh 3. reindex 3. Полезно. Только учтите, что SELECT'ы, где используется этот индекс будут ждать пока ваш реиндекс не пройдет. Поэтому в некоторых случаях эффективнее сделать DROP/CREATE индексу. REINDEX is similar to a drop and recreate of the index in that the index contents are rebuilt from scratch. However, the locking considerations are rather different. REINDEX locks out writes but not reads of the index's parent table. It also takes an exclusive lock on the specific index being processed, which will block reads that attempt to use that index. In contrast, DROP INDEX momentarily takes exclusive lock on the parent table, blocking both writes and reads. The subsequent CREATE INDEX locks out writes but not reads; since the index is not there, no read will attempt to use it, meaning that there will be no blocking but reads may be forced into expensive sequential scans. Another important point is that the drop/create approach invalidates any cached query plans that use the index, while REINDEX does not. т.е. совет сомнителен. А вот хп-ки могут начать ругаться на отсутствие рилейшена оид такой-то (до переконнекта). ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 31.07.2007, 14:46 |
|
||
|
vacuum и размер базы: интересный эффект
|
|||
|---|---|---|---|
|
#18+
4321 REINDEX is similar to a drop and recreate of the index in that the index contents are rebuilt from scratch. However, the locking considerations are rather different. REINDEX locks out writes but not reads of the index's parent table. It also takes an exclusive lock on the specific index being processed, which will block reads that attempt to use that index. In contrast, DROP INDEX momentarily takes exclusive lock on the parent table, blocking both writes and reads. The subsequent CREATE INDEX locks out writes but not reads; since the index is not there, no read will attempt to use it, meaning that there will be no blocking but reads may be forced into expensive sequential scans. Another important point is that the drop/create approach invalidates any cached query plans that use the index, while REINDEX does not. т.е. совет сомнителен. А вот хп-ки могут начать ругаться на отсутствие рилейшена оид такой-то (до переконнекта). Вы выделили красным не то место. Вот так лучше: It also takes an exclusive lock on the specific index being processed, which will block reads that attempt to use that index. А в чем совет сомнителен? Вы не советуете делать REINDEX? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 31.07.2007, 15:45 |
|
||
|
vacuum и размер базы: интересный эффект
|
|||
|---|---|---|---|
|
#18+
Thamerlan Вы выделили красным не то место. Вот так лучше: It also takes an exclusive lock on the specific index being processed, which will block reads that attempt to use that index. А в чем совет сомнителен? Вы не советуете делать REINDEX?гм. я, кстати сказать, выделил самое то. Таблица не лочица, но не используется индекс. Чем это отличается от дропа? Конечно, если вы знаете способ заюзать индекс после дропа, но до завершения криейта - другое дело. а сомнителен - т.к. при работающих клиентах желательно избегать пользовать DROP/RESTORE - в силу авторAnother important point is that the drop/create approach invalidates any cached query plans that use the index, while REINDEX does not. , что приводит к проблемам у работающих юзеров (надо перегружать хп-ки). С другой стороны разницы промеж локами на таблицу промеж REINDEX и DROP/RESTORE в хелпе сильной не наблюдается. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 31.07.2007, 16:04 |
|
||
|
vacuum и размер базы: интересный эффект
|
|||
|---|---|---|---|
|
#18+
4321гм. я, кстати сказать, выделил самое то. Таблица не лочица, но не используется индекс. Чем это отличается от дропа? Конечно, если вы знаете способ заюзать индекс после дропа, но до завершения криейта - другое дело. Ну во первых, я нигде не агитировал использовать DROP/CREATE вместо REINDEX. Я сказал, что бывают случаи когда DROP/CREATE может заменить REINDEX. А во вторых, отличие в том, что когда происходит REINDEX вашего 10 гигабайтного индекса, то все операции, которым оптимайзер "прописал" этот индекс будут ждать окончания REINDEX'а (включая SELECT'ы). 4321 а сомнителен - т.к. при работающих клиентах желательно избегать пользовать DROP/RESTORE - в силу авторAnother important point is that the drop/create approach invalidates any cached query plans that use the index, while REINDEX does not. , что приводит к проблемам у работающих юзеров (надо перегружать хп-ки). С другой стороны разницы промеж локами на таблицу промеж REINDEX и DROP/RESTORE в хелпе сильной не наблюдается. Ну произойдет новый hard parse и создастся новый план выполнения. Конечно это не очень хорошо для производительности... но такой вариант имеет место быть. P.s. Сам стараюсь обходиться REINDEX'ами... :) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 31.07.2007, 16:32 |
|
||
|
|

start [/forum/topic.php?fid=53&fpage=291&tid=2005211]: |
0ms |
get settings: |
8ms |
get forum list: |
16ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
38ms |
get topic data: |
9ms |
get forum data: |
2ms |
get page messages: |
39ms |
get tp. blocked users: |
1ms |
| others: | 245ms |
| total: | 366ms |

| 0 / 0 |
