
Леонид
29.01.2018
17:48:26
первый
второй

Google

Arthur
29.01.2018
17:52:50
Есть удобный сервис для планов :)
https://explain.depesz.com/

Andrey
29.01.2018
17:52:54
Ну тут у вас 2500мс против 2100. И видимо как раз из-за буфуров (см. buffers read в первом плане и его отсутствие во втором).
В ситуации когда запрос выполняется десятки секунд у вас скорее всего все читается с диска (не будет buffers shared hit).

Леонид
29.01.2018
17:54:58
кажется вижу, где разница
а как это пофиксить можно?

Alex
29.01.2018
18:55:15

Yaroslav
29.01.2018
18:57:10
а как это пофиксить можно?
Что именно? Это просто эффект кэширования данных.
Тут либо кэшировать больше (добавить RAM) / читать быстрее (улучшить дисковую подсистему), либо читать меньше (оптимизировать запрос / создать подходящие индексы).

Леонид
29.01.2018
18:59:57
Понял, спасибо. Но если вот такой кейс. Юзер утром приходит запускает приложение и ждет инфу, которая нужна ему 1 раз в день. И первый запрос длится 70 сек, а второй уже 2-3. Мне тут уже советовали, поставить шедуллер, который рано утром будет для юзеров прогревать базу ?
делая запросы, на получение инфы.

Google

Леонид
29.01.2018
19:01:37
Может как-то можно узнать, сколько времени будет длиться такой кеш? Когда, например, он сбрасывается и нужно снова читать с диска.

Alex
29.01.2018
19:02:13
а как это пофиксить можно?
Можно- переписать запрос или больше памяти в сервак добавть для shared buffer . Могу сразу сказать что в пг shared buffer работает мин в 2 раза быстрее чем кэш ос. Поэтому советы про маленький shared buffer считаю вредными
Это для ос
Check point completion target для pg
Больше ничего не придумали

Yaroslav
29.01.2018
19:05:13

Alex
29.01.2018
19:05:47

Леонид
29.01.2018
19:06:11

Yaroslav
29.01.2018
19:06:27

Леонид
29.01.2018
19:07:39

Yaroslav
29.01.2018
19:09:17

Леонид
29.01.2018
19:09:26
10

Yaroslav
29.01.2018
19:10:07
10
Значит, upgrade Вам не поможет. ;)

Леонид
29.01.2018
19:11:02
тогда так.
1. попробую оптимизировать запрос.
2. добавлю RAM
и на крайний буду прогревать, на большее денег и времени не дадут)

Петр
29.01.2018
19:11:10

Леонид
29.01.2018
19:11:31

Петр
29.01.2018
19:12:21
Да там понимать то нечего особо

Google

Alex
29.01.2018
19:12:51
И вытеснится при первой возможности

Yaroslav
29.01.2018
19:13:26

Alex
29.01.2018
19:13:50
Самое оптимально для пг это оптимальные запросы
Остальное это мертвому припарки и отсрачивание агонии

Леонид
29.01.2018
19:14:36
понял, спасиб

Alex
29.01.2018
19:14:53

Yaroslav
29.01.2018
19:14:54

Alex
29.01.2018
19:16:07
При второй. Это рояля не меняет. Или база влезает в кеш или нет, другого не дано. Если база есть определенного размера значит она нужна вся

Yaroslav
29.01.2018
19:16:07

Alex
29.01.2018
19:16:24

Yaroslav
29.01.2018
19:17:16
До поры до времени
И до этой поры может быть бесконечно далеко... разве что время DBA стоит копейки. ;)

Alex
29.01.2018
19:17:51
Если запрос кривой то можно хоть септильон мегабайт выделить
Ибо нет инструментов для быстрого разрешения инцидентов кроме как мозг дба
Все остальное от лукавого
Ктобы что не говорил

Yaroslav
29.01.2018
19:20:17

Alex
29.01.2018
19:20:53
Намного стоят лицухи и намного же стоят простои

Google

Evgeniy
29.01.2018
19:21:16
кажется на эстейт проперти надо сделать более селективный индекс

Alex
29.01.2018
19:21:32

Леонид
29.01.2018
19:23:22

Yaroslav
29.01.2018
19:23:27

Evgeniy
29.01.2018
19:25:18
это как?
у тебя по точкам нашлось 290к записей, потом пошел джойн к проперти с кучкой фильтров и наджойнилось всего 7к записей
возможно тебе поможет индекс на условие которое много отбрасывает результатов

Yaroslav
29.01.2018
19:25:22
это как?
Подождите. Если Вы хотите (и можете) именно оптимизировать запрос, занимайтесь этим.
А если Вы хотите, чтобы Вам в этом помогли, занимайтесь правильно, т.е. выкладывайте \d всех таблиц, сам запрос и EXPLAIN (ANALYZE, BUFFERS). ;)

Evgeniy
29.01.2018
19:27:30

Леонид
29.01.2018
19:27:30

Alex
29.01.2018
19:28:09

Evgeniy
29.01.2018
19:28:40

Petr
29.01.2018
19:29:02
ребята, есть что-то получше pg_basebackup, когда нужно забэкапить базу вплоть до индексов?

Alex
29.01.2018
19:29:13

Evgeniy
29.01.2018
19:29:25

Alex
29.01.2018
19:29:30

Petr
29.01.2018
19:30:02
спасибо, посмотрю)

Alex
29.01.2018
19:30:14
Лучше только cp если в один поток
Приходите на конфу, мы там расскажем
Что почем

Yaroslav
29.01.2018
19:31:02

Petr
29.01.2018
19:31:33
а если сравнивать скорость между pg_probackup и pg_basebackup — есть ли великая разница?

Google

Alex
29.01.2018
19:31:57
Basebackep это почти cp
Без проверок

Petr
29.01.2018
19:33:50
ок, спасибо)

Alex
29.01.2018
19:36:06

Evgeniy
29.01.2018
19:38:22
в чью сторону-то

Петр
29.01.2018
19:40:35

Evgeniy
29.01.2018
19:46:57

Леонид
29.01.2018
19:47:45
ну чо?
не могу понять как и где
там юзается поиск в радиусе 100км например
и сортируется по растоянию
самые ближайшие

Evgeniy
29.01.2018
19:48:39
create index concurrently on estate_properties(building_area,latest_sale_recording_date);

Леонид
29.01.2018
19:49:08
Оо, спс. Сейчас попробую

Yaroslav
29.01.2018
19:50:00
Вы бы вставляли в виде текста (всё, о чём Вас просили) на какой-нибудь paste site, а сюда ссылку.