我的编程空间,编程开发者的网络收藏夹
学习永远不晚

PostgreSQL疑难问题分析步骤

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

PostgreSQL疑难问题分析步骤

PostgreSQL疑难问题分析步骤

运维管理postgresql 时难免不会遇到一些疑难问题,遇到这里问题时怎么处理呢。

一、分析是整库异常还是个别进程异常

二、首先收集信息

确认好异常类别后,可以进行收集相应的信息了

整库异常

    检查server状态
执行pg_ctl status [-D datadir],并将结果保存
2.    保存pg_top输出结果
将pg_top所有输出结果保存
按c键输出完整sql文本:
 
3.    保存pg_stat_activity所有记录
psql –c "select * from pg_stat_activity;">$PGNAME_session_activity.csv
4.    保存等待事件信息
查询等待时间,并保存结果
 with t_wait as  
(select a.locktype,a.database,a.relation,a.page,a.tuple,a.classid,a.objid,a.objsubid,a.pid,a.virtualtransaction,a.virtualxid,a,transactionid,b.query,b.xact_start,b.query_start,b.usename,b.datname from pg_locks a,pg_stat_activity b where a.pid=b.pid and not a.granted), 
t_run as  
(select a.mode,a.locktype,a.database,a.relation,a.page,a.tuple,a.classid,a.objid,a.objsubid,a.pid,a.virtualtransaction,a.virtualxid,a,transactionid,b.query,  b.xact_start,b.query_start,b.usename,b.datname from pg_locks a,pg_stat_activity b where a.pid=b.pid and a.granted)  
select r.locktype,r.mode,r.usename r_user,r.datname r_db,r.relation::regclass,r.pid r_pid,r.xact_start r_xact_start,r.query_start r_query_start,r.query r_query, 
w.usename w_user,w.datname w_db,w.pid w_pid,w.xact_start w_xact_start,w.query_start w_query_start,w.query w_query   
from t_wait w,t_run r where 
  r.locktype is not distinct from w.locktype and 
        r.database is not distinct from w.database and 
        r.relation is not distinct from w.relation and 
        r.page is not distinct from w.page and 
        r.tuple is not distinct from w.tuple and 
        r.classid is not distinct from w.classid and 
        r.objid is not distinct from w.objid and 
  r.objsubid is not distinct from w.objsubid 
       order by r.xact_start;
5.    查询锁信息
select a.locktype,a.pid,a.relation,a.mode,a.granted,b.relname from pg_locks a,pg_class b where a.relation=b.oid;

   单个进程异常需要收集相关信息


1.    数据库中查询进程相关sql信息
select * from pg_stat_activity where pid=$pid;
select a.locktype,a.pid,a.relation,a.mode,a.granted,b.relname from pg_locks a,pg_class b where a.relation=b.oid and a.pid=$pid;
2.    收集strace等信息
strace -rTfo strace.$PID -p $PID
3.    收集pstack信息
pstack $PID >> pstack.$PID
lsof -p $PID >> lsof.$PID
4.    收集perf等信息
perf stat -p $PID >> perf_stat.$PID
perf record -e cpu-clock -g -p $PID
 

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

PostgreSQL疑难问题分析步骤

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

PostgreSQL疑难问题分析步骤

运维管理postgresql 时难免不会遇到一些疑难问题,遇到这里问题时怎么处理呢。 一、分析是整库异常还是个别进程异常 二、首先收集信息 确认好异常类别后,可以进行收集相应的信息了 整库异常 1.    检查server状态 执行pg_ctl status
PostgreSQL疑难问题分析步骤
2021-10-26

如何解析学习C++时的疑难问题

本篇文章为大家展示了如何解析学习C++时的疑难问题,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。许多编程人员学习C++总结经验为,有的觉得C++语言是一门独立的语言,并不是在C语言的基础上,可以直接
2023-06-17

Node.js Async/Await常见问题解答:解决异步编程中的疑难杂症

Node.js的Async/Await是一种处理异步代码的优雅方式,它可以使异步代码看起来像同步代码一样,从而简化了异步编程。然而,在使用Async/Await时,也可能会遇到一些常见的问题,本文将对这些问题进行解答,帮助您解决异步编程中的疑难杂症。
Node.js Async/Await常见问题解答:解决异步编程中的疑难杂症
2024-02-27

Ubuntu中postgresql安装问题的示例分析

小编给大家分享一下Ubuntu中postgresql安装问题的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Ubuntu postgresql 的安装 本
2023-06-17

Java线程同步问题分析

本篇内容主要讲解“Java线程同步问题分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java线程同步问题分析”吧!Java线程同步的基本实现思路还是比较容易理解的。我们可以给共享资源加一把锁
2023-06-17

Java线程同步问题实例分析

这篇文章主要讲解了“Java线程同步问题实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java线程同步问题实例分析”吧!1.场景有五位沉默的哲学家围坐在一张圆桌旁,他们一生都在吃东西
2023-06-29

React中setState同步或异步问题的示例分析

这篇文章主要为大家展示了“React中setState同步或异步问题的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“React中setState同步或异步问题的示例分析”这篇文章吧。1.
2023-06-25

Android异步回调中的UI同步性问题分析

Android程序编码过程中,回调无处不在。从最常见的Activity生命周期回调开始,到BroadcastReceiver、Service以及Sqlite等。Activity、BroadcastReceiver和Service这些基本组件
2022-06-06

SpringBoot在项目中访问静态资源步骤分析

今天在玩SpringBoot的demo的时候,放了张图片在resources目录下,启动区访问的时候,突然好奇是识别哪些文件夹来展示静态资源的,为什么有时候放的文件夹不能显示,有的却可以
2023-01-28

Java多线程同步问题的示例分析

这篇文章主要介绍Java多线程同步问题的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!简单了解下在操作系统中进程和线程的区别:  进程:每个进程都有独立的代码和数据空间(进程上下文),进程间的切换会有较大的开
2023-05-30

Android中ListView异步加载图片错位、重复、闪烁问题分析及解决方案

Android ListView异步加载图片错位、重复、闪烁分析以及解决方案,具体问题分析以及解决方案请看下文。 我们在使用ListView异步加载图片的时候,在快速滑动或者网络不好的情况下,会出现图片错位、重复、闪烁等问题,其实这些问题总
2022-06-06

编程热搜

目录