pgSql 事务篇

查询长时间运行的事务

SELECT

pid,

usename,

application_name,

client_addr,

client_port,

state,

-- 计算事务已运行时长

now() - xact_start AS transaction_duration,

-- 计算当前查询已运行时长

now() - query_start AS query_duration,

query

FROM pg_stat_activity

WHERE xact_start IS NOT NULL -- 只显示开启了事务的连接

AND state != 'idle' -- 排除完全空闲的连接(可选)

AND pid != pg_backend_pid() -- 排除当前查询本身

ORDER BY transaction_duration DESC;

中止活跃事务

-- 终止所有运行超过5分钟的活跃事务

SELECT pg_terminate_backend(pid)

FROM pg_stat_activity

WHERE xact_start < now() - interval '5 minutes'

AND state = 'active'

AND pid != pg_backend_pid();

查询pid的链路

SELECT

blocked_locks.pid AS blocked_pid, -- 被阻塞的进程

blocked_activity.query AS blocked_query, -- 被阻塞的查询

blocking_locks.pid AS blocking_pid, -- 阻塞源进程 (元凶)

blocking_activity.query AS blocking_query, -- 阻塞源正在执行的SQL

-- 计算阻塞时长 (被阻塞进程已经等待了多久)

now() - blocked_activity.query_start AS blocked_duration

FROM pg_catalog.pg_locks blocked_locks

JOIN pg_catalog.pg_stat_activity blocked_activity

ON blocked_activity.pid = blocked_locks.pid

JOIN pg_catalog.pg_locks blocking_locks

ON blocking_locks.locktype = blocked_locks.locktype

AND blocking_locks.database IS NOT DISTINCT FROM blocked_locks.database

AND blocking_locks.relation IS NOT DISTINCT FROM blocked_locks.relation

AND blocking_locks.pid != blocked_locks.pid

JOIN pg_catalog.pg_stat_activity blocking_activity

ON blocking_activity.pid = blocking_locks.pid

WHERE NOT blocked_locks.granted order by blocked_duration desc; -- 只查看正在等待锁的进程

数据库连接数

SELECT

client_addr,

COUNT(*) AS connection_count,

COUNT(*) FILTER (WHERE state = 'active') AS active_count

FROM pg_stat_activity

WHERE client_addr IS NOT NULL

GROUP BY client_addr

ORDER BY connection_count DESC;

设置锁超时

-- 设置锁等待超时(10秒)

ALTER SYSTEM SET lock_timeout = '10s';

-- 设置语句执行超时(30秒)

ALTER SYSTEM SET statement_timeout = '30s';

-- 设置空闲事务超时(30秒)

ALTER SYSTEM SET idle_in_transaction_session_timeout = '30s';

-- 重新加载配置(使设置立即对新建会话生效)

SELECT pg_reload_conf();

查询超时参数

-- 查看所有超时参数

SELECT name, setting, unit, context

FROM pg_settings

WHERE name IN (

'lock_timeout',

'statement_timeout',

'idle_in_transaction_session_timeout',

'deadlock_timeout'

);

相关推荐
像我这样帅的人丶你还2 小时前
Java 后端详解(五):Redis 缓存
java·后端·全栈
plainGeekDev4 小时前
GreenDAO → Room
android·java·kotlin
jiayou644 小时前
KingbaseES 表级与列级加密完全指南
数据库·后端
亦暖筑序9 小时前
Java 8老系统AI Workflow实战:把一次性AI对话升级成可恢复工作流
java·后端
敲代码的彭于晏9 小时前
Bean 生命周期完全图解:前端同学也能看懂的 Spring 核心机制
java·前端·后端
plainGeekDev11 小时前
ButterKnife → ViewBinding
android·java·kotlin
GBASE1 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
像我这样帅的人丶你还1 天前
Java 后端详解(四):分页与搜索
java·javascript·后端
她的男孩1 天前
数据权限为什么不能只靠注解?Forge 的 Mapper 层 SQL 改写源码拆解
java·后端·架构
tntxia1 天前
Mybatis的日志输入
java