Greenplum中怎么查看锁信息并处理
发表于:2025-01-28 作者:千家信息网编辑
千家信息网最后更新 2025年01月28日,Greenplum中怎么查看锁信息并处理,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Greenplum提供了一个视图(gp_toolk
千家信息网最后更新 2025年01月28日Greenplum中怎么查看锁信息并处理
Greenplum中怎么查看锁信息并处理,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
Greenplum提供了一个视图(gp_toolkit.gp_locks_on_relation)用来查看当前的锁信息情况,执行查询如下:
postgres=# select * from gp_toolkit.gp_locks_on_relation ; lorlocktype | lordatabase | lorrelname | lorrelation | lortransaction | lorpid | lormode | lorgranted | lorcurrentquery-------------+-------------+-----------------------------+-------------+----------------+--------+------------------+------------+------------------------------------------------- relation | 12094 | gp_locks_on_relation | 12016 | | 11989 | AccessShareLock | t | select * from gp_toolkit.gp_locks_on_relation ; relation | 0 | pg_authid | 1260 | | 11989 | AccessShareLock | t | select * from gp_toolkit.gp_locks_on_relation ; relation | 0 | pg_authid_oid_index | 2677 | | 11989 | AccessShareLock | t | select * from gp_toolkit.gp_locks_on_relation ; relation | 0 | pg_authid_rolname_index | 2676 | | 11989 | AccessShareLock | t | select * from gp_toolkit.gp_locks_on_relation ; relation | 0 | pg_authid_rolresgroup_index | 6440 | | 11989 | AccessShareLock | t | select * from gp_toolkit.gp_locks_on_relation ; relation | 0 | pg_authid_rolresqueue_index | 6029 | | 11989 | AccessShareLock | t | select * from gp_toolkit.gp_locks_on_relation ; relation | 12094 | pg_class | 1259 | | 11989 | AccessShareLock | t | select * from gp_toolkit.gp_locks_on_relation ; relation | 12094 | pg_class_oid_index | 2662 | | 11989 | AccessShareLock | t | select * from gp_toolkit.gp_locks_on_relation ; relation | 12094 | pg_class_relname_nsp_index | 2663 | | 11989 | AccessShareLock | t | select * from gp_toolkit.gp_locks_on_relation ; relation | 0 | pg_database | 1262 | | 11989 | AccessShareLock | t | select * from gp_toolkit.gp_locks_on_relation ; relation | 0 | pg_database_datname_index | 2671 | | 11989 | AccessShareLock | t | select * from gp_toolkit.gp_locks_on_relation ; relation | 0 | pg_database_oid_index | 2672 | | 11989 | AccessShareLock | t | select * from gp_toolkit.gp_locks_on_relation ; relation | 12094 | pg_locks | 11343 | | 11989 | AccessShareLock | t | select * from gp_toolkit.gp_locks_on_relation ; relation | 12094 | pg_stat_activity | 11417 | | 11989 | AccessShareLock | t | select * from gp_toolkit.gp_locks_on_relation ; relation | 12094 | t1 | 16384 | | 12650 | RowExclusiveLock | t |in transaction(15 rows)
查到锁信息后,我们一般情况会根据当前的问题及业务逻辑定位出,是哪个进程卡住了。这里假设上面我们构造的针对t1表的事务插入引起了行级排他锁,那么我们此时为了恢复业务,需要将其处理掉。
首先我们通过活动查询视图来看一下该查询目前的状态:
postgres=# select * from pg_stat_activity; datid | datname | procpid | sess_id | usesysid | usename | current_query | waiting | query_start | backend_start | client_addr | client_port | application_name | xact_start | waiting_reason | rsgid | rsgname | rsgqueueduration-------+----------+---------+---------+----------+---------+---------------------------------+---------+-------------------------------+-------------------------------+-------------+-------------+------------------+-------------------------------+----------------+-------+---------+------------------ 12094 | postgres | 11989 | 51 | 10 | gposs5 | select * from pg_stat_activity; | f | 2020-09-09 21:16:17.514665+08 | 2020-09-09 21:12:06.797525+08 | | -1 | psql | 2020-09-09 21:16:17.514665+08 | | 0 | unknown | 12094 | postgres | 12650 | 52 | 10 | gposs5 |in transaction | f | 2020-09-09 21:15:56.159363+08 | 2020-09-09 21:15:36.889396+08 | | -1 | psql | 2020-09-09 21:15:48.16486+08 | | 0 | unknown |(2 rows)
可以看出,procpid为12650的查询,与上面锁的lorpid是对应的,我们可以将这个进程停掉。采用如下两个函数即可:
postgres=# select pg_cancel_backend(12650); pg_cancel_backend------------------- t(1 row)postgres=# select pg_cancel_backend(12650); pg_cancel_backend------------------- t(1 row)postgres=# select pg_terminate_backend(12650); pg_terminate_backend---------------------- t(1 row)postgres=# select pg_terminate_backend(12650);WARNING: PID 12650 is not a PostgreSQL server process pg_terminate_backend---------------------- f(1 row)
看完上述内容,你们掌握Greenplum中怎么查看锁信息并处理的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注行业资讯频道,感谢各位的阅读!
信息
查询
处理
问题
业务
内容
情况
方法
更多
视图
进程
束手无策
为此
两个
事务
函数
原因
对此
技能
状态
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全面临的问题
服务器租赁这个项目可以做吗
是浙江明讯网络技术有限公司
git 服务器文件
什么样服务器
三门峡支付软件开发
隔离广播和提高网络安全
神力科莎争锋怎么进多人服务器
rpr技术 三级网络技术
数据库修改数据语句的关键字是
数据库连接游标
安全企业网络安全报告
云店互联网科技有限公司
海康视频流媒体服务器
群众网络安全活动
数据库并发控制原理简述
远程服务器ip
发明数据库的是谁
五一网络安全保障工作
计算机本地服务器地址
定兴天气预报软件开发
git服务器与客户端
灵武市软件开发技术费用
云电脑 云服务器
怎么通过窗口读取数据库的数据
焦作搜房网络技术有限公司
数据库服务器升级方案
奉化手机软件开发平台
1700亿网络安全生态
更改或在当前数据库