当前位置: 首页 > article >正文

PG实例CPU使用率高排查思路

一、查看具体哪个会话占用高

top 查看哪个pid使用cpu高
psql 登录到数据库中查看具体的语句
SELECT pid, query FROM pg_stat_activity WHERE pid = ‘top查看到的pid’;

二、查看锁

在PostgreSQL中查看锁的状态,你可以使用pg_locks系统视图来获取当前数据库中的锁信息。以下是一些查询示例,可以帮助你查看和分析锁的情况:

  1. 查看所有当前锁

    SELECT * FROM pg_locks;
    

    这个查询将返回所有当前未解决的锁的信息。

  2. 根据锁类型查询

    • 查询所有表级锁:
      SELECT * FROM pg_locks WHERE locktype = 'relation';
      
    • 查询所有行级锁:
      SELECT * FROM pg_locks WHERE locktype = 'tuple';
      

    这些查询将分别返回表级锁和行级锁的详细信息。

  3. 查询特定数据库的锁

    SELECT * FROM pg_locks WHERE database = (SELECT oid FROM pg_database WHERE datname = 'your_database_name');
    

    'your_database_name'替换成你想要查询的数据库名称,这个查询将返回特定数据库中的锁信息。

  4. 查询持有锁的进程

    SELECT * FROM pg_locks WHERE pid = 12345;
    

    12345替换成你想要查询的进程ID,这个查询将返回特定进程持有的锁的信息。

  5. 查询等待锁的进程

    SELECT * FROM pg_locks WHERE granted = false;
    

    这个查询将返回所有正在等待锁的进程的信息。

  6. 结合pg_stat_activity视图查询锁信息

    SELECT
        pg_stat_activity.pid,
        pg_stat_activity.query,
        pg_locks.locktype,
        pg_locks.mode,
        pg_locks.relation::regclass,
        pg_locks.transactionid,
        pg_locks.virtualxid,
        pg_locks.virtualtransaction,
        pg_locks.granted
    FROM pg_stat_activity
    JOIN pg_locks ON pg_stat_activity.pid = pg_locks.pid
    WHERE pg_locks.granted = false;
    

    这个查询将结合pg_stat_activity视图和pg_locks视图,返回所有正在等待锁的会话以及持有这些锁的会话的信息。

通过这些查询,你可以有效地监控和分析PostgreSQL中的锁状态,以识别潜在的锁争用和死锁问题,并优化数据库性能。

pg_locks

从你提供的pg_locks查询结果来看,我们可以看到多个relation类型的锁,这些锁都是针对特定relation(即表)的。这里是一些关键点的解释:

  1. locktyperelation表示这些锁是针对整个表的。
  2. database:数据库的OID,这里是24975
  3. relation:表的OID,例如167953167950等。
  4. pid:持有锁的进程ID,例如589215947943179等。
  5. mode:锁的模式,这里大多数是AccessShareLock,表示共享锁,允许多个事务并发读取数据。
  6. grantedt表示锁已经被授予,f表示锁正在等待。
  7. fastpatht表示这个锁是通过快速路径授予的,f表示不是。
  8. waitstart:如果锁正在等待,这里会显示等待开始的时间。

分析锁的状态

  • 已授予的锁:大多数锁的granted列显示为t,表示这些锁已经被授予,事务可以继续执行。
  • 等待中的锁:有少数锁的granted列显示为f,表示这些锁正在等待。例如,167960167963167970的锁正在等待。

进一步的步骤

  1. 查看等待锁的详细信息
    如果你想要查看哪些事务正在等待这些锁,可以使用以下查询:

    SELECT * FROM pg_stat_activity
    WHERE pid IN (58921, 59479, 43179, 59242, 59535, 59536)
    AND state = 'idle';
    

    这个查询将返回持有或等待锁的进程的详细信息。

  2. 查看锁的等待时间
    如果锁正在等待,你可能想要知道它们已经等待了多久:

    SELECT pid, waitstart
    FROM pg_locks
    WHERE granted = false;
    
  3. 解决锁问题
    如果你发现有事务长时间持有锁或者等待锁,可能需要进一步分析这些事务的查询,考虑优化查询或者调整事务的执行顺序。

通过这些步骤,你可以更好地理解和管理PostgreSQL中的锁,以优化数据库性能和避免潜在的死锁问题。

wait_event_type

从你提供的pg_stat_activity视图中的wait_event_typewait_event列的信息来看,我们可以分析出以下内容:

  1. pid:进程ID,标识了当前正在等待的数据库进程。

  2. wait_event_type:等待事件的类型,它描述了进程正在等待的资源类型。可能的值包括LWLock(轻量级锁)、IO(输入/输出操作)等。

  3. wait_event:具体的等待事件,它提供了更详细的信息,说明进程正在等待什么。例如,WALWrite表示进程正在等待WAL(Write-Ahead Logging)写入操作完成,WALSync表示进程正在等待WAL同步操作完成。

分析结果

  • 进程79424、102543、102632、102633、77589:这些进程没有列出具体的等待事件,这意味着它们可能没有等待任何事件,或者正在执行一些不需要等待特定资源的操作。

  • 进程60269和61544:这两个进程都在等待WALWrite事件。这表明它们可能正在执行写入操作,并且正在等待WAL缓冲区中的数据被写入磁盘。这是数据库操作中的一个常见步骤,尤其是在处理大量写入时。

  • 进程61683:这个进程正在等待WALSync事件。这意味着它正在等待WAL缓冲区中的数据被同步到磁盘。这是确保数据持久性的重要步骤,特别是在事务日志中。

可能的影响和解决方案

  • WAL写入等待:如果多个进程长时间等待WALWriteWALSync,这可能表明WAL写入速度较慢,可能是由于磁盘I/O性能瓶颈或WAL缓冲区设置不当。可以考虑以下解决方案:

    • 检查磁盘性能和I/O子系统。
    • 增加WAL缓冲区的大小。
    • 优化WAL相关的配置参数,如wal_levelwal_buffers等。
  • 监控和优化:持续监控这些等待事件,特别是在高负载情况下,可以帮助识别性能瓶颈。使用pg_stat_activity视图可以帮助你实时监控数据库的运行状态,并及时调整配置以优化性能。

通过这些分析,你可以更好地理解数据库进程的等待行为,并采取相应的措施来优化数据库的性能和稳定性。

三、查看会话

SELECT datname, usename, COUNT(*) FROM pg_stat_activity WHERE datname != 'postgres' AND usename != 'postgres' GROUP BY datname, usename;
select pid,wait_event_type,wait_event from pg_stat_activity WHERE datname != 'postgres' AND usename != 'postgres' AND state != 'idle' ; 
select pid,wait_event_type,wait_event from pg_stat_activity WHERE state != 'idle' ; 

http://www.kler.cn/a/395144.html

相关文章:

  • 研究生如何远控实验室电脑?远程办公功能使用教程
  • IC 脚本之python
  • Rocky、Almalinux、CentOS、Ubuntu和Debian系统初始化脚本v9版
  • JavaScript 观察者设计模式
  • RabbitMQ高效的消息队列中间件原理及实践
  • 速盾:高防 CDN 和 CDN 的缓存机制都一样吗?
  • pyflink datastream数据流ds经过一系列转换后转为table,t_env.from_data_stream(ds)
  • 【C++学习(35)】在Linux中基于ucontext实现C++实现协程(Coroutine),基于C++20的co_await 协程的关键字实现协程
  • 机器学习在网络安全中的应用
  • 问:SQL优化,七条实践总结?
  • Rust枚举之卧龙凤雏(Rust Option枚举、Rust Result枚举)(Rust Enum、Some(T)、Ok(T)、Err(E))链式操作
  • TKinter实现与Dash应用的同步启停控制
  • kubernetes简单入门实战
  • 【大语言模型】ACL2024论文-10 CSCD-IME: 纠正拼音输入法产生的拼写错误
  • MathGPT的原理介绍,在中小学数学教学的应用场景,以及代码样例实现
  • Leetcode:3258. 统计满足 K 约束的子字符串数量 I
  • 什么是CRM系统?
  • 华为eNSP:RSTP
  • 【前端】vue 如何完全销毁一个组件
  • JavaScript 面试题
  • 助力网络安全发展,安全态势攻防赛事可视化
  • PostgreSQL 计算两个时间之间的日期差
  • Cyberchef配合Wireshark提取并解析TCP/FTP流量数据包中的文件
  • NeRF在农业领域的应用-------------(1)
  • 深入理解ElasticSearch分词器:详解各种分词器的原理与应用
  • 鸿蒙学习生态应用开发能力全景图-开发者支持平台(5)