zoukankan      html  css  js  c++  java
  • postgresql数据库大量锁表的问题解决

    一、postgresql数据库出现锁表问题排查

     1 //查询锁表的情况
     2 SELECT 
    3
      A.locktype, 4   A.DATABASE, 5   A.pid, 6   A.relation, 7   b.relname 8 FROM 9   pg_locks 10 A JOIN pg_class b ON A.relation = b.oid;
    11
    12 //杀死进程 13 select pg_terminate_backend(pid); //pid为进程id号

    //用于查询系统进程状态的表

    select * from pg_stat_activity;

    主要关注waiting 是否等待中,stat 进程状态, query 具体语句

    当waiting 为t 的进行需要特别注意,query可以查看到具体语句,然后进行查杀

    最终的原因排查为,mq拥堵导致一些流程走不了,代码流程又涉及到更新等操作,产生数据库锁 一直占用着连接的资源 。

    二、锁类型 8种:(pgsql源码的src/include/storage/lock.h文件)

    /* NoLock is not a lock mode, but a flag value meaning "don't get a lock" */
    #define NoLock                          0
    #define AccessShareLock                 1 /* SELECT */
    #define RowShareLock                    2 /* SELECT FOR UPDATE/FOR SHARE */
    #define RowExclusiveLock                3 /* INSERT, UPDATE, DELETE */
    #define ShareUpdateExclusiveLock        4 /* VACUUM (non-FULL),ANALYZE, CREATE
                                               * INDEX CONCURRENTLY */
    #define ShareLock                       5 /* CREATE INDEX (WITHOUT CONCURRENTLY) */
    #define ShareRowExclusiveLock           6 /* like EXCLUSIVE MODE, but allows ROW
                                               * SHARE */
    #define ExclusiveLock                   7 /* blocks ROW SHARE/SELECT...FOR
                                               * UPDATE */
    #define AccessExclusiveLock             8 /* ALTER TABLE, DROP TABLE, VACUUM
                                               * FULL, and unqualified LOCK TABLE */

    三、锁冲突(可以看出哪些锁会发生冲突)

    四、可加锁对象的定义(pgsql源码src/include/storage/lock.h文件)

     1 typedef enum LockTagType
     2 {
     3   LOCKTAG_RELATION, /* whole relation */
     4   /* ID info for a relation is DB OID + REL OID; DB OID = 0 if shared */
     5   LOCKTAG_RELATION_EXTEND, /* the right to extend a relation */
     6   /* same ID info as RELATION */
     7   LOCKTAG_PAGE, /* one page of a relation */
     8   /* ID info for a page is RELATION info + BlockNumber */
     9   LOCKTAG_TUPLE, /* one physical tuple */
    10   /* ID info for a tuple is PAGE info + OffsetNumber */
    11   LOCKTAG_TRANSACTION, /* transaction (for waiting for xact done) */
    12   /* ID info for a transaction is its TransactionId */
    13   LOCKTAG_VIRTUALTRANSACTION, /* virtual transaction (ditto) */
    14   /* ID info for a virtual transaction is its VirtualTransactionId */
    15   LOCKTAG_OBJECT, /* non-relation database object */
    16   /* ID info for an object is DB OID + CLASS OID + OBJECT OID + SUBID */
    17 
    18 /*
    19 * Note: object ID has same representation as in pg_depend and
    20 * pg_description, but notice that we are constraining SUBID to 16 bits.
    21 * Also, we use DB OID = 0 for shared objects such as tablespaces.
    22 */
    23   LOCKTAG_USERLOCK, /* reserved for old contrib/userlock code */
    24   LOCKTAG_ADVISORY /* advisory user locks */
    25 } LockTagType;

  • 相关阅读:
    教你怎么叠T恤
    最动人的情歌《The Power of Love》by Celine.Dion
    使代码简洁的 5 条忠告
    Timeout MessageBox
    内联函数
    局部对象
    const用法(转)
    心情
    内联函数
    局部对象
  • 原文地址:https://www.cnblogs.com/zluckiy/p/12486838.html
Copyright © 2011-2022 走看看