Гость
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / Помогите разобраться с блокировками. / 9 сообщений из 9, страница 1 из 1
28.02.2018, 17:59
    #39608655
Личинка DBA
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите разобраться с блокировками.
Так пусто:
Код: sql
1.
select * from pg_stat_activity WHERE waiting=true






так примерно 300 строк
Код: sql
1.
2.
SELECT * FROM pg_locks
WHERE mode not in ('AccessShareLock')




Как так?
...
Рейтинг: 0 / 0
28.02.2018, 17:59
    #39608656
Личинка DBA
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите разобраться с блокировками.
Правильно ли я понимаю что когда одна сессия блокирует другую, waiting в pg_stat_activity должно стать true ?
...
Рейтинг: 0 / 0
28.02.2018, 18:02
    #39608661
Личинка DBA
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите разобраться с блокировками.
вот у меня есть сессия, например, в которой 10 часов выполняется SELECT-ы в уровне transaction_isolation = 'repeatable read'


может ли она блоккировать другие сессии не выполняющие ddl с таблицами?
...
Рейтинг: 0 / 0
28.02.2018, 18:25
    #39608677
Личинка DBA
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите разобраться с блокировками.
Еще,

в


base/pgsql_tmp/

сотни фалов вида:
pgsql_tmp8496.109
pgsql_tmp8496.110
pgsql_tmp8496.111

и т.д.


В проводнике у них нулевой размер показывает.
...
Рейтинг: 0 / 0
28.02.2018, 20:59
    #39608727
Alexius
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите разобраться с блокировками.
Личинка DBAПравильно ли я понимаю что когда одна сессия блокирует другую, waiting в pg_stat_activity должно стать true ?

правильно.

Личинка DBAвот у меня есть сессия, например, в которой 10 часов выполняется SELECT-ы в уровне transaction_isolation = 'repeatable read'


может ли она блоккировать другие сессии не выполняющие ddl с таблицами?

если там только чтение идет, то напрямую нет, может блокировать ddl операции, которые будут пытаться взять accessexclusive lock и уже в свою очередь заблокируют другие транзакции.

посмотрите внимательно вывод запроса:
Код: sql
1.
2.
3.
4.
5.
6.
SELECT (clock_timestamp() - pg_stat_activity.xact_start) AS ts_age, pg_stat_activity.state, (clock_timestamp() - pg_stat_activity.query_start) as query_age, (clock_timestamp() - state_change) as change_age, pg_stat_activity.datname, pg_stat_activity.pid, pg_stat_activity.usename, pg_stat_activity.waiting, pg_stat_activity.client_addr, pg_stat_activity.client_port, pg_stat_activity.query
FROM pg_stat_activity
WHERE
((clock_timestamp() - pg_stat_activity.xact_start > '00:00:00.1'::interval) OR (clock_timestamp() - pg_stat_activity.query_start > '00:00:00.1'::interval and state = 'idle in transaction (aborted)'))
and pg_stat_activity.pid<>pg_backend_pid()
ORDER BY coalesce(pg_stat_activity.xact_start, pg_stat_activity.query_start);



в частности ts_age (длительность транзакции), state, waiting. я подозреваю, что у вас блокировок нет, а все сессии в idle in transaction съели пул коннектов.

от 10-часовых транзакций надо избавляться, они автовакууму не дадут нормально работать.
...
Рейтинг: 0 / 0
28.02.2018, 23:03
    #39608752
Melkij
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите разобраться с блокировками.
Личинка DBAТак пусто:
так примерно 300 строк
Как так?
Так вы не просили not granted - вот вам и дали список из всех локов, включая успешно выданные.
...
Рейтинг: 0 / 0
01.03.2018, 08:27
    #39608819
qwwq
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите разобраться с блокировками.
Личинка DBAвот у меня есть сессия, например, в которой 10 часов выполняется SELECT-ы в уровне transaction_isolation = 'repeatable read'


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

вы бы снепшоты этой сессии раздали -- и параллельно селектики ваши селектили.
...
Рейтинг: 0 / 0
01.03.2018, 10:41
    #39608880
Личинка DBA
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите разобраться с блокировками.
MelkijЛичинка DBAТак пусто:
так примерно 300 строк
Как так?
Так вы не просили not granted - вот вам и дали список из всех локов, включая успешно выданные.



А как нонгратед блокировки посмотреть?
...
Рейтинг: 0 / 0
01.03.2018, 11:14
    #39608902
Alexius
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите разобраться с блокировками.
Личинка DBA,

кэп подсказывает, что надо дописать where not granted.
...
Рейтинг: 0 / 0
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / Помогите разобраться с блокировками. / 9 сообщений из 9, страница 1 из 1
Целевая тема:
Создать новую тему:
Автор:
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]