kettle导数据造成Postgresql锁表

场景:kettle数据抽取节点A、B,Postgresql集群数据管理节点C。A和B上同时跑着数据抽取任务,有两个任务运行过程中卡住。于是打算重启抽取任务,先truncate这两个表(一个任务对应一个表),问题出现了,有一个表truncate执行卡住,delete卡住,drop table也不行,但是可以insert和select。一定是表锁住了!

解决办法:

1.查询表中存在的锁

select a.locktype,a.database,a.pid,a.mode,a.relation,b.relname

from pg_locks a

join pg_class b on a.relation = b.oid

where upper(b.relname) = 'TABLE_NAME';

查到后发现确实存在锁,如下:

 locktype | database |  pid  |      mode       | relation | relname

----------+----------+-------+-----------------+----------+---------

 relation |   439791 | 26752 | AccessShareLock |  2851428 |table_name

 relation |   439791 | 26752 | ExclusiveLock   |  2851428 |table_name

2.再根据上面查出来的pid去表pg_stat_activity查询一下该锁对应的SQL语句:

select usename,current_query ,query_start,procpid,client_addr from pg_stat_activity where procpid=17509;

如下:

  usename  |  current_query                      |          query_start          | procpid |  client_addr  

-----------+---------------------------------------------------------------------------------------------------------------+-------------------------------+---------+----------------

 gpcluster | DELETE FROM TABLE_NAME WHERE A = 1  | 2011-05-14 09:35:47.721173+08 |   17509 | 192.168.165.18

(1 row)

3.杀掉方法:在Postgresql数据库管理服务器中,查询这个进程PID然后Kill掉。

注意在A和B节点上是查不到该进程的,因为A和B组织的copy语句是要在数据库里执行的,一个copy语句对应一个进程。

 > ps -ef|grep 17509

postgres 17509  4868  1 Nov18 ?        00:11:19 postgres: postgres mydb 192.168.165.18(56059) SELECT             

postgres 30838 30800  0 15:19 pts/3    00:00:00 grep 17509

> kill -9 17509

猜你喜欢

转载自zsg86.iteye.com/blog/2394928
今日推荐