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

Подскажите, юзаем libpq (через psycopg) в python для подключения, задаем

два хоста:
psql "postgresql://localhost:5433,localhost:5434/postgres" -tc 'SHOW port'
Первая в списке БД на порту 5433 недоступна (curl выдает get connection refused), но libpq вместо того, чтобы проверить второй хост, который рабочий, и подключиться к нему, просто падает уже после первого хоста:
psql: error: connection to server at "localhost" (::1), port 5433 failed: FATAL: could not open file "global/pg_filenode.map": No such file or directory
Это как-то фиксится или by design? Были треды у Postgresql на эту тему?

Причем JDBC работает при таком кейсе, но заюзать его мы не можем :/

9 ответов

11 просмотров

При таких условиях curl не должэн выдавать connection refused. Возможно, вы запускаете его откуда-то неоттуда.

Terrifin- Автор вопроса
Ilya Anfimov
При таких условиях curl не должэн выдавать connect...

Это один из примеров, дефакто там не localhost, и ошибка у libpq: connection failed: server closed the connection unexpectedly This probably means the server terminated abnormally before or while processing the request. Но смысл тот же, psycopg юзая libpq не идет дальше первого нерабочего хоста. С курлом все ок, он правильно отдает ошибку от "сломанного" хоста

Terrifin
Это один из примеров, дефакто там не localhost, и ...

Нет, curl не должэн отдавать connection refused, если там никак не refused. И да, libpq идёт дальшэ только если refused (ну, можэт ещё если timeout). Если соединение прошло, а что-то упало на аутэнтификацыи -- то дальшэ не идёт. Я не думаю, что есть простые способы изменить это поведение.

Terrifin
Это один из примеров, дефакто там не localhost, и ...

Хм так он смог достучатся судя по ошибке (

Terrifin- Автор вопроса
Konstantin Zaitsev
Хм так он смог достучатся судя по ошибке (

Там в целом какая-та "муть" произошла на сервере, основной посыл в том, что при любой "мути", libpq вместо перехода к следующему серверу, зачем-то падает, перемудрили в общем они что-то, зачем было при аутентификации падать (мб и с ней какой косяк там на низком уровне на серваке произошел), а при других кейсах брать следующий сервер и т.д.

Terrifin
Там в целом какая-та "муть" произошла на сервере, ...

Спорить про все случаи не буду, но про аутентификацию базовый принцип ИБ

Terrifin- Автор вопроса
Konstantin Zaitsev
Спорить про все случаи не буду, но про аутентифика...

Не брутфорсили чтобы типа 3 раза, если 3 разных хоста?

Konstantin Zaitsev
Спорить про все случаи не буду, но про аутентифика...

Ну, это клиент вроде как, ему-то не надо так выслужываться.

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта