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

Может быть проблема связана с тем, что постгря в докере?

36 ответов

5 просмотров

СУБД называется постгрес. А постгря в докере - оно обязано доставлять боль и страдания тому, кто занимается подобным непотребством.

Setplus-Mac Автор вопроса
Михаил Шурутов
СУБД называется постгрес. А постгря в докере - оно...

Например, какие? Может постргес в докере показывать такие высокие IO?

Setplus Mac
Например, какие? Может постргес в докере показыват...

недостаточно информации для ответа на ваш вопрос. 10 инсёртов в пустую таблицу - это одно, 10 инсёртов вместе с триггерами - это другое, 10 инсёртов в таблицу в 100Гб - это третье. проверьте через pg_test_fsync скорость выполнения fsync в вашем контейнере. Ну и можете pg_bench запустить для последующего сравнения с другими вариантами установки СУБД

Сергей Голод
недостаточно информации для ответа на ваш вопрос. ...

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

Михаил Шурутов
СУБД называется постгрес. А постгря в докере - оно...

> А постгря в докере - оно обязано доставлять боль и страдания тому, кто занимается подобным непотребством. Тут все зависит от потребностей. Я например без докера просто не могу. Мои типовые сценарии: - локально держу 6 версий постгреса с 9.5 по 13 для локальной разработки и тестов (они обычно у меня выключены, запускаю при необходимости) - если ктото заводит мне багу, я в докере быстро поднимаю нужное окружение чтобы воспроизвести багу - в докере запускаю тестовое окружение нужной версии постгреса, чтобы быстро проверить какую-то функциональность и потом удалить это окружение, не засоряя основную систему. Держать и обслуживать виртуалки для этого, или может держать это все в виде локальных служб это просто долго, дорого и нерационально, и вот это бы и было как вы и говорите непостребством, с болью и страданиями. И при разумном подходе, docker+postgres можно и в проде держать.

Alexey Lesovsky
> А постгря в докере - оно обязано доставлять боль...

Ключевое словосочетание: при разумном подходе.

Михаил Шурутов
Ключевое словосочетание: при разумном подходе.

При неразумном боль и унижение причиняет абсолютно всё.

Что такого нужно сделать, чтобы постгрес именно в докере доставлял боль?

Михаил Шурутов
Попробуйте обновить мажорную версию.

Хм, видимо я везучий, пока обновлял без проблем.

Михаил Шурутов
Попробуйте обновить мажорную версию.

В чём отличия от обновления без докера?

Sergey Bezrukov
В чём отличия от обновления без докера?

В отсутствии докера. Распишите, пожалуйста, пошагово процедуру обновления ПГ в докере в конфигурации мастер-реплика.

Михаил Шурутов
В отсутствии докера. Распишите, пожалуйста, пошаго...

Откуда взялась мастер-реплика? Докер - это для разработки большей частью.

Sergey Bezrukov
Откуда взялась мастер-реплика? Докер - это для ра...

Я не занимаюсь поддержкой разработки. Только и исключительно пром, который обслуживает внешних клиентов. Как показывает практика, то, что используется при разработке, так называемые "архитекторы" от словосочетания "идиоты безмозглые" пытаются протащить и в пром. Ну у меня же на ноутбуке, деве всё работает!

Михаил Шурутов
Я не занимаюсь поддержкой разработки. Только и иск...

без нагрузки и реальных объемов данных, ага, все работает ))

Михаил Шурутов
Я не занимаюсь поддержкой разработки. Только и иск...

Тогда понятно. В высоконагруженную систему лучше лишних уровней не запихивать, тут согласен, конечно.

Сергей Кравчук
без нагрузки и реальных объемов данных, ага, все р...

Вот именно! На прошлой работе один такой архитектор ваял скрипты для миграций. 50+ тыс записей вставлял отдельными INSERT-ами. У него на деве всё быстро проходило, меньше минуты.

Евгений Смирнов
На деве SSD, а на боевом - HDD, так?

Не так. 50 тыс записей и нагруженный проект и по записи, и по чтению.

Sergey Bezrukov
Тогда понятно. В высоконагруженную систему лучше л...

Самое интересное в этой фразе - лишние уровни. Ибо при любой, даже паравиртуализации, этот лишний уровень появляется. А если ещё и используются тома системы виртуализации, а не проброс физических устройств в витруалку, то чудеса с вводом/выводом гарантированы.

Setplus-Mac Автор вопроса
Сергей Голод
недостаточно информации для ответа на ваш вопрос. ...

И вот конфиг max_connections = 200 shared_buffers = 4GB effective_cache_size = 12GB maintenance_work_mem = 1GB checkpoint_completion_target = 0.7 wal_buffers = 16MB default_statistics_target = 100 random_page_cost = 4 effective_io_concurrency = 2 work_mem = 5242kB min_wal_size = 1GB max_wal_size = 4GB max_worker_processes = 8 max_parallel_workers_per_gather = 4 max_parallel_workers = 8 max_parallel_maintenance_workers = 4

Setplus-Mac Автор вопроса
Setplus Mac
И вот

это не совсем то что нужно, это конечно показывает что диски медленные, но не говорит о причинах почему они медленные... надо искать причины. начать следует с оценики работы системы через утилиты top, iostat и изучения окружения (конфигурация железа и настройки системы) где проявляются проблемы

Setplus Mac
И вот

Этого недостаточно. Напишите, какое там "железо", полностью — так проще будет.

Setplus Mac
Сейчас кину

вы не написали про диски, что там у вас ssd или hdd?

Setplus Mac
screenshot Выхлоп pg_test_fsync

да уж, не блещет докер производительностью.... А что используется в качестве хранилища для докера?

Setplus-Mac Автор вопроса
Setplus Mac
да дефолтный

если что, overlay2

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

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

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Эх кто-то пришел и весь праздник испортил :( 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
Какого хера? /Sources/App/Modules/User/Models/UserLinkApple.swift:21:20: warning: stored property '_id' of 'Sendable'-conforming class 'UserLinkApple' is mutable @ID(...
Alexander Sherbakov
14
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Почему стало ломаться на D11? "739002.86400000' is not a valid timestamp" function IncDateTime(aStamp:TTimeStamp;aKind:TTriggerKind;aInterval:Integer):TDateTime; //aStamp = 2...
Катерина Свиридова
8
У тебя в конфиге нигде нет deny all; или вообще любого deny?
Alexander Sherbakov
10
Портфолио: Зовут меня Александр, мне 36 лет. Город Пушкино. Общий рабочий стаж: ~14 лет Уровень квалификации: Senior Full-stack developer Где прочесть мой код? https://github....
Magic
10
Есть Pipeline для GitLab Runner (executor = "shell") В нём есть: default: before_script: - set -eo pipefail - source "$(~/bin/trdl use werf 2 stable)" - source...
Aleksandr Karabanov
1
Ребят, чет я уже не догоняю... Крч в коде на асм там происходит нечто вроде a+число (a+1, a+2 и т.д.). Но почему строка lea ecx, [edx+1] работает как a+1?? В edx берется адрес...
Alan 🔝 Бэброу
4
Карта сайта