Re: strem replication standby lag check

Поиск
Список
Период
Сортировка
От Sergey Konoplev
Тема Re: strem replication standby lag check
Дата
Msg-id CAL_0b1vy1MezdWNvJaNTBKR0ZOxeULwgTtnA9KejKdvm9eAuJQ@mail.gmail.com
обсуждение исходный текст
Ответ на Re: strem replication standby lag check  (desmodemone <desmodemone@gmail.com>)
Список pgsql-admin
> 2014/1/17 yhe <yinghe0101@yahoo.com>
>> any way I can do that without a dblink?
>>

On Mon, Jan 20, 2014 at 4:33 AM, desmodemone <desmodemone@gmail.com> wrote:
> I think it's better to use the pg_stat_replication

+1

And this is how to make all the calculation of the lag (in bytes):

CREATE OR REPLACE FUNCTION hex_to_int(i_hex text, OUT o_dec integer)
RETURNS integer LANGUAGE 'plpgsql' IMMUTABLE STRICT AS $$
BEGIN
    EXECUTE 'SELECT x''' || i_hex || '''::integer' INTO o_dec;
    RETURN;
END $$;

SELECT
    client_addr,
    sent_offset - (
        replay_offset - (sent_xlog - replay_xlog) * 255 * 16 ^ 6 ) AS byte_lag
FROM (
    SELECT
        client_addr,
        hex_to_int(split_part(sent_location, '/', 1)) AS sent_xlog,
        hex_to_int(split_part(replay_location, '/', 1)) AS replay_xlog,
        hex_to_int(split_part(sent_location, '/', 2)) AS sent_offset,
        hex_to_int(split_part(replay_location, '/', 2)) AS replay_offset
    FROM pg_stat_replication
) AS s;

--
Kind regards,
Sergey Konoplev
PostgreSQL Consultant and DBA

http://www.linkedin.com/in/grayhemp
+1 (415) 867-9984, +7 (901) 903-0499, +7 (988) 888-1979
gray.ru@gmail.com


В списке pgsql-admin по дате отправления:

Предыдущее
От: desmodemone
Дата:
Сообщение: Re: strem replication standby lag check
Следующее
От: 杨涛涛
Дата:
Сообщение: 回复: pg_ctl promote