Size: a a a

pgsql – PostgreSQL

2020 June 15

.

.tmp in pgsql – PostgreSQL
к сожелению он давно был зашарен в скайпе и больше мне недоступен(
источник

s

sexst in pgsql – PostgreSQL
Alex G
При вступлении в сообщество помимо капчи надо задавать вопрос как правильно называется БД.

А по теме: стоп-слова дело ненадежное и практически бесполезное
И ненужное. Пишете в правилах запрет,  баните нарушающих, со временем там будет так принято. Здесь же не матерятся как пример.
источник

V

Valery in pgsql – PostgreSQL
/thread
источник

VH

Vladimir Holyavik in pgsql – PostgreSQL
/thread
источник

VH

Vladimir Holyavik in pgsql – PostgreSQL
да я уж обыскался )
источник

KK

Konstantin K in pgsql – PostgreSQL
Vladimir Holyavik
пишу чат на постгре .. надо список стоп слов .. матерных .. для контроля вводимого текста .. мот есть у кого .. так же интересен список на нем инг хинди
у меня есть, скину попозже
источник

KK

Konstantin K in pgsql – PostgreSQL
щас не у компа
источник

f

fish in pgsql – PostgreSQL
/thread
источник

D

Dmitry in pgsql – PostgreSQL
Коллеги, добрый вечер

Я спрашивал тут пару недель назад, как на продакшен-базе в 1.5 терабайта включить чексуммы без особого даунтайма
База - мастер да реплика, включение чексумм занимает порядка 40 минут, судя по экспериментам

Подсказали, что можно стопнуть реплику (мастер один нагрузку легко тянет), включить там чексуммы, сделать свитчовер, включить чексуммы на другом сервере, сделать свитчовер ещё раз (нам важно чтобы в итоге мастером осталась прежняя машина, не вдавался почему, но админу верю)

Так вот нюанс в том, что у нас был когда-то неудачный опыт со свитчовером, прилично лет назад, на постгресе вроде 9.6 или около того (сейчас у нас 12.3). А именно - реплика мастером стала, а вот прежний мастер к ней подцепить репликой не удалось. С тех пор не пробовали так делать.
За давностью лет - на что оно там ругалось, не помним конечно.

Сейчас, если свитчовер также не удастся, нам придётся дважды тянуть полтора терабайта по сети, чтобы восстановить репликацию один раз, и потом второй, и это ну такое себе удовольствие.

Так вот хочется подготовиться и сделать таки эти два свитчовера, но чтобы без секса, подскажите как правильно, и где соломки подстелить.

В постгресе много способов репликации, у нас она асинхронная, wal-based (хотя я могу ошибаться или недоговаривать, давно сам не готовил постгрес)

В мастере в конфиге строчки про репликацию такие:
hot_standby = on

На реплике:
hot_standby = on
primary_conninfo = 'host=... port=... user=replication password=...'
promote_trigger_file = '/var/lib/pgsql/12/data/postgresql.trigger'


У нас есть такая дока https://edu.postgrespro.ru/dba3/dba3_05_replica_switchover.pdf

Есть такое сообщение из мейл-листа https://www.postgresql.org/message-id/CANNMO%2BKYuH3Gh7BZp%3DUGXpoos4tBR0AFgoONkqWBrokuJthEug%40mail.gmail.com, где упоминается ещё "убедиться что валы догнались" (как?) и настройка recovery.conf (которого у нас нет)

Достаточно ли доки https://edu.postgrespro.ru/dba3/dba3_05_replica_switchover.pdf для безопасного свитчовера? Или надо что-то ещё проверить / не забыть / и т.п?

Спасибо что дочитали ;)
источник

IK

Ilya Kaznacheev in pgsql – PostgreSQL
Господа, подскажите, пожалуйста, как пофиксить проблему, когда литералы даты интерпретируются не в той локали?

У меня клиент в Германии, и они у себя запускают миграции вида
SELECT *
                       FROM auftragsjournal
                       WHERE
                               "createdAt" BETWEEN '01.01.2019' AND '31.12.2019'
                               AND quelle = 'mobile'


А у меня не работает, говорит, что

ERROR: date/time field value out of range: "31.12.2019"
 Hint: Perhaps you need a different "datestyle" setting.

А вот как это сделать - не пойму
Уже и пересоздал БД с локалью de_DE (у меня локаль en_GB на компе), и при запуске миграций (запускаю через flyway) указывал LANG=de_DE - ниче не помогает
источник

IK

Ilya Kaznacheev in pgsql – PostgreSQL
Собственно, ругается на даты вида 01.01.2019
источник

IK

Ilya Kaznacheev in pgsql – PostgreSQL
Насколько я понимаю
источник

IK

Ilya Kaznacheev in pgsql – PostgreSQL
Собственно, там так и написано 😕
источник

KK

Konstantin K in pgsql – PostgreSQL
to_date('01.01.2019', 'dd.mm.yyyy')
источник

IK

Ilya Kaznacheev in pgsql – PostgreSQL
Konstantin K
to_date('01.01.2019', 'dd.mm.yyyy')
Не могу менять сами миграции, мне нужно их как-то накатить, чтобы база принала нужный формат дат
источник

IK

Ilya Kaznacheev in pgsql – PostgreSQL
Вероятно мне en_GB жизнь портит, но как пофиксить - не понимаю
источник

IK

Ilya Kaznacheev in pgsql – PostgreSQL
Пробовал LANG=de_DE LC_CTYPE=de_DE.UTF-8 flyway migrate - не помогает
источник

IK

Ilya Kaznacheev in pgsql – PostgreSQL
Пробовал базу пересоздать с указанием локали - не помогает
источник

YS

Yaroslav Schekin in pgsql – PostgreSQL
Dmitry
Коллеги, добрый вечер

Я спрашивал тут пару недель назад, как на продакшен-базе в 1.5 терабайта включить чексуммы без особого даунтайма
База - мастер да реплика, включение чексумм занимает порядка 40 минут, судя по экспериментам

Подсказали, что можно стопнуть реплику (мастер один нагрузку легко тянет), включить там чексуммы, сделать свитчовер, включить чексуммы на другом сервере, сделать свитчовер ещё раз (нам важно чтобы в итоге мастером осталась прежняя машина, не вдавался почему, но админу верю)

Так вот нюанс в том, что у нас был когда-то неудачный опыт со свитчовером, прилично лет назад, на постгресе вроде 9.6 или около того (сейчас у нас 12.3). А именно - реплика мастером стала, а вот прежний мастер к ней подцепить репликой не удалось. С тех пор не пробовали так делать.
За давностью лет - на что оно там ругалось, не помним конечно.

Сейчас, если свитчовер также не удастся, нам придётся дважды тянуть полтора терабайта по сети, чтобы восстановить репликацию один раз, и потом второй, и это ну такое себе удовольствие.

Так вот хочется подготовиться и сделать таки эти два свитчовера, но чтобы без секса, подскажите как правильно, и где соломки подстелить.

В постгресе много способов репликации, у нас она асинхронная, wal-based (хотя я могу ошибаться или недоговаривать, давно сам не готовил постгрес)

В мастере в конфиге строчки про репликацию такие:
hot_standby = on

На реплике:
hot_standby = on
primary_conninfo = 'host=... port=... user=replication password=...'
promote_trigger_file = '/var/lib/pgsql/12/data/postgresql.trigger'


У нас есть такая дока https://edu.postgrespro.ru/dba3/dba3_05_replica_switchover.pdf

Есть такое сообщение из мейл-листа https://www.postgresql.org/message-id/CANNMO%2BKYuH3Gh7BZp%3DUGXpoos4tBR0AFgoONkqWBrokuJthEug%40mail.gmail.com, где упоминается ещё "убедиться что валы догнались" (как?) и настройка recovery.conf (которого у нас нет)

Достаточно ли доки https://edu.postgrespro.ru/dba3/dba3_05_replica_switchover.pdf для безопасного свитчовера? Или надо что-то ещё проверить / не забыть / и т.п?

Спасибо что дочитали ;)
> Подсказали, что можно стопнуть реплику (мастер один нагрузку легко тянет), включить там чексуммы

Кто подсказал-то (такое я тоже слышал, и с виду оно может и работать, но не делал)? ;)
Я к чему — может, у них спросить, как прошло / были ли проблемы?

Далее:
1.  Стопнуть реплику (мастер один нагрузку легко тянет), включить там чексуммы
2.  Сделать свитчовер
Вот где-то перед этим шагом реплика, по идее, должна быть "докачена" WAL-ами с primary, нет?

3.  включить чексуммы на другом сервере,

4. сделать свитчовер ещё раз

И перед этим — тоже, см. выше.

> реплика мастером стала, а вот прежний мастер к ней подцепить репликой не удалось

timelines разошлись, наверное. Тогда же pg_rewind ещё не было, вроде?

> Сейчас, если свитчовер также не удастся, нам придётся дважды тянуть полтора терабайта по сети

Не обязательно. Как раз тут можно подумать, как правильно применить pg_rewind, по идее.

>  где соломки подстелить.

А Вы на "урезанных" тестовых кластерах (к примеру, с теми же схемами и почти без данных; или вообще на тестовых базах) потренируйтесь. :)

> где упоминается ещё "убедиться что валы догнались" (как?)

См. https://www.postgresql.org/docs/current/app-pgcontroldata.html , по идее.

> и настройка recovery.conf (которого у нас нет)

Это потому, что у Вас v12.

> Или надо что-то ещё проверить / не забыть / и т.п?

Почитали бы Вы официальную документацию, для начала. ;)
источник

YS

Yaroslav Schekin in pgsql – PostgreSQL
Ilya Kaznacheev
Господа, подскажите, пожалуйста, как пофиксить проблему, когда литералы даты интерпретируются не в той локали?

У меня клиент в Германии, и они у себя запускают миграции вида
SELECT *
                       FROM auftragsjournal
                       WHERE
                               "createdAt" BETWEEN '01.01.2019' AND '31.12.2019'
                               AND quelle = 'mobile'


А у меня не работает, говорит, что

ERROR: date/time field value out of range: "31.12.2019"
 Hint: Perhaps you need a different "datestyle" setting.

А вот как это сделать - не пойму
Уже и пересоздал БД с локалью de_DE (у меня локаль en_GB на компе), и при запуске миграций (запускаю через flyway) указывал LANG=de_DE - ниче не помогает
Hint: Perhaps you need a different "datestyle" setting? ;)
источник