达梦数据库性能分析

news2024/10/5 15:32:09

目录

数据库常用性能分析方法... 3

一、服务器监控... 3

1、cpu监控... 3

2、内存... 3

3、swap内存... 3

4、磁盘... 4

5、网络监测... 4

二、数据库实例监控... 6

1、v$sessions. 6

2、慢sql、阻塞、锁... 7

3、内存监控... 10

4、monitor监控工具使用及开启sql日志跟踪... 10

5、AWR报告生成及使用... 13

数据库常用性能分析方法

一、服务器监控

1、cpu监控

top

2、内存

top

free -m

3、swap内存

生产系统尽量调低或者不使用swap内存,尽量使用系统内存提高性能

cat /proc/sys/vm/swappiness

vim /etc/sysctl.conf

vm.swappiness=10

sysctl -p

物理内存使用到90%左右开始使用swap内存

4、磁盘

df -h

iostat -xm

iostat -d -x -k 1 3

dd if=/dev/zero of=test bs=8k count=64k oflag=dsync

vmstat

vmstat 1 3

5、网络监测

nmon

dem

ethtool ens33

使用 sar 命令测试网络带宽。

sar 命令使用 -n 选项可以汇报网络相关信息

sar -n DEV 1 3

nmon需要安装

安装方法:

上传安装包

wget https://nchc.dl.sourceforge.net/project/nmon/nmon16h_helpsystems_v2.tar.gz

解压安装包

mkdir nmon

mv nmon16h_helpsystems_v2.tar.gz nmon

tar -zxvf nmon16h_helpsystems_v2.tar.gz

读写赋权

只赋予对应linux系统版本(本次要使用的)授权即可

chmod 777 nmon_x86_64_centos7

重命名

mv nmon_x86_64_centos7 nmon

启动nmon

./nmon

需查看直接按键即可

 

nmon在任何地方都能运行

mv nmon /usr/bin/nmon

命令参数:

c : 显示cpu利用率数据

m:显示内存数据

n:显示网络信息

d:显示磁盘信息

t:系统进程信息

h:查看帮助信息

q:退出Nmon界面

二、数据库实例监控

1、v$sessions

select count(*) from v$sessions;

操作系统命令查询会话数

netstat -apn|grep dmserver|grep ESTABLISHED|wc -l

2、慢sql、阻塞、锁

详见阻塞和锁

v$session

v$lock

v$trxwait

释放会话

sp_close_session(sess_id);

1)查询阻塞锁

select * from v$lock where blocked=1;

2)查询会话

select * from v$sessions;

3)查询事务及事务等待

select * from v$trx;

select * from v$trxwait;

综合查询阻塞(死锁)

select sysdate,datediff(minute,s.last_send_time,sysdate) ZSDate_Mi,

'阻塞信息',s.sess_id SId,t.wait_for_id ZSTId,s.sql_text ZSSql,s.user_name ZSUser,s.clnt_host,s.appname,s.clnt_ip,

'被阻塞信息',s2.sess_id SId,t.id BZSId,s2.sql_text BZSSql,s2.user_name BZSUser,s2.clnt_host,s2.appname,s2.clnt_ip

from v$trxwait t,v$sessions s,v$sessions s2 where t.wait_for_id=s.trx_id and t.id=s2.trx_id;

4)死锁查询

select * from v$deadlock_history;

5)查询完整的死锁事务

select d.sess_id,d.trx_id,wm_concat(s.top_sql_text),happen_time,start_time,time_used

from v$sql_history s,v$deadlock_history d where s.trx_id=d.trx_id and d.sess_id=s.sess_id and d.trx_id=27694;

这里最好指定事务id,否则之前执行的事务都拼接在一起了。

6)死锁和阻塞记录信息(仅记录发生次数和耗时等)可以直接查询:v$system_event;

select * from v$system_event order by TIME_WAITED desc;

7)慢sql查询

select top 10 * from v$system_long_exec_sqls order by exec_time desc;

查询出当前会话活动的慢sql

select datediff(ss,last_recv_time,sysdate),sess_id,sql_text,SF_GET_SESSION_SQL(SESS_ID) fullsql,clnt_ip,thrd_id

from v$sessions

where state='ACTIVE'

order by 1 desc;

查询已执行超过1秒的活动SQL

SELECT* FROM (

SELECT SESS_ID,SQL_TEXT,DATEDIFF(SS,LAST_RECV_TIME,SYSDATE) Y_EXETIME,

SF_GET_SESSION_SQL(SESS_ID) FULLSQL,CLNT_IP

FROM V$SESSIONS WHERE STATE='ACTIVE')

WHERE Y_EXETIME>=1;

查询最近1000条执行时间较长的SQL语句

SELECT * FROM V$LONG_EXEC_SQLS;

查询服务器启动以来执行时间最长的20条SQL语句

SELECT * FROM V$SYSTEM_LONG_EXEC_SQLS;

3、内存监控

v$bufferpool

v$mem_pool

1)查看数据库实际使用内存

select sum(mem)/1024.0 as mem_used_G from(

select sum(total_size)/1024/1024.0 mem from v$mem_pool

union all

select sum(n_pages-free)*page/1024/1024.0 from v$bufferpool);

2)查看内存占用较大的sql

v$sql_stat

v$sql_stat_history

需要开启ENABLE_MONITOR参数,默认是开启的

select * from v$sql_stat order by max_mem_used;

4、monitor监控工具使用及开启sql日志跟踪

生成sql日志文件,没开启sql相关视图中也会有相应的sql记录,貌似只是没有日志输出。

select sf_get_para_value(1,'SVR_LOG');

 

未开启sql日志跟踪,监控工具monitor依然可以监控到sql相应的信息。

使用monitor实时监测sql执行时间

 

SQL语句统计选择显示执行最长时间的SQL还是执行频率最高的SQL

 

选择具体sql查看执行计划

 

SQL日志的开启和关闭

开启:SP_SET_PARA_VALUE(1,'SVR_LOG',1);

关闭:SP_SET_PARA_VALUE(1,'SVR_LOG',0);

只有dm.ini文件中参数SVR_LOG=1即开启sql跟踪时,sqllog.ini文件才有用。

sqllog.ini文件修改后只需要调用sp_refresh_svr_log_config()参数就会生效。

ASYNC_FLUSH=1 打开 SQL 日志异步刷盘提高系统性能。

 

如需进行更为系统全面的分析,可使用 DMLOG工具 对SQL进行分类汇总或直接查看awr报告

5、AWR报告生成及使用

1)启用AWR包和系统包

call sp_init_awr_sys(1);

call sp_create_system_packages(1);

2)查询AWR快照:不创建系统包这里查不到快照

SELECT * FROM SYS.WRM$_SNAPSHOT;

3)设置快照间隔,貌似若不设置快照间隔,手动执行快照后 SYS.WRM$_SNAPSHOT 视图中没有记录。单位分钟。

CALL DBMS_WORKLOAD_REPOSITORY.AWR_SET_INTERVAL(60);

4)手动执行生成快照

CALL DBMS_WORKLOAD_REPOSITORY.CREATE_SNAPSHOT();

5)查询AWR快照

SELECT * FROM SYS.WRM$_SNAPSHOT;

6)根据两个快照对比生成AWR报告

SYS.AWR_REPORT_HTML(快照ID1,快照ID2,'AWR报告存放路径','AWR报告名称.HTLM'):

SYS.AWR_REPORT_HTML(5,6,'/dm/data/awr','AWR2.HTML');

下载到本地后查看慢sql等分析性能。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/716963.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

五年Java学习心路历程

五年Java学习心路历程 从大学毕业到工作的过程中,我度过了五年学习Java的岁月。从基础语法到各种细节技术再到分布式和微服务架构,经历了许多的挑战与成长。接下来,我将详细记录这段心路历程,与大家分享学习Java的经验与感悟。 …

Java基础---String str=new String(“tang“)创建了几个对象

目录 典型回答 常量池基本概念 字符串常量池的结构 再看字面量和运行时常量池 intern 还是创建了几个对象 intern的正确用法 典型回答 创建的对象数应该是1个或者2个如果常量池中存在,则直接new一个对象如果常量池不存在,则在常量池中创建一个对象…

KubeEdge官方示例运行成功_Counter Demo 计数器

运行KubeEdge官方示例_Counter Demo 计数器 KubeEdge Counter Demo 计数器是一个伪设备,用户无需任何额外的物理设备即可运行此演示。计数器在边缘侧运行,用户可以从云侧在 Web 中对其进行控制,也可以从云侧在 Web 中获得计数器值,原理图如下…

前端web入门-移动web-day10

(创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹) 目录 移动Web基础 手机模拟器 屏幕分辨率 视口 二倍图 适配方案 rem 适配方案 rem 媒体查询 rem – …

使用java生成mvt切片的方法

如何使用java生成geoserver的矢量切片供前端(mapbox等)调用 目录新的想法Java能为切片做什么如何生成切片如何转换xyz数据如何查询如何输出mvt格式给前端前端如何调用 目录 好久没发博客了,每日或忙碌、或悠闲、或喜或悲、时怅时朗&#xff…

访问学者怎样准备申请推荐信

作为访问学者,申请推荐信是非常重要的一步,它能够在您的申请过程中增加信誉度和竞争力。一个优秀的推荐信可以更好地展现您的学术能力、研究潜力和个人品质。以下是知识人网小编整理的关于如何准备申请推荐信的建议: 1. 确定推荐人&#xff1…

阿里云OSS上传文件工具类

个人主页:金鳞踏雨 个人简介:大家好,我是金鳞,一个初出茅庐的Java小白 目前状况:22届普通本科毕业生,几经波折了,现在任职于一家国内大型知名日化公司,从事Java开发工作 我的博客&am…

20本期刊影响因子上涨,7月SCI/SSCI/AHCI/EI刊源表已更新!

2023年7月SCI/SSCI/AHCI/EI期刊目录更新 2023年6月28日发布的最新《期刊引证报告》中,我处合作期刊中,7月刊源表有20本期刊影响因子上涨,同时新增多本快刊! 重磅!2023年JCR正式发布(附影响因子名单下载&a…

[github-100天机器学习]day2 simple linear regression

https://github.com/LiuChuang0059/100days-ML-code/blob/master/Day2_SImple_Linear_regression/README.md 简单线性回归 使用单一特征预测响应值。基于自变量X来预测因变量Y的方法,假设两者线性相关,寻找一种根据特征或自变量X的线性函数来预测Y。 目…

工资难以突破升职加薪必看,资深测试经理教你怎么做好“管理岗”!

要了解测试管理岗位需要具备的素质,我们先来看下测试管理岗位的职责。以下是 Boss 直聘上某几家的公司的测试经理的岗位要求: 如果你想学习接口自动化测试,我这边给你推荐一套视频,这个视频可以说是B站播放全网第一的接口自动化测…

从零开始搭建STM32CubeMX开发环境

本文记录一下如何从零开始使用STM32CubeMX,包括软件的安装,环境的搭建,配置代码的生成等; 本文以STM32G030C8T6为例,如果你的单片机不是以STM32G030C8T6为例,换成你的单片机类型即可,过程都是通…

03_单一职责模式

单一职责 在软件组件的设计中,如果责任划分的不清晰,使用继承得到的结果往往是随着需求的变化,子类急剧膨胀,同时充斥着重复代码,这时候的关键是划清责任。 装饰模式 动态(组合)地给一个对象增…

系统没有“internet信息服务(IIS)管理器”

系统没有“internet信息服务(IIS)管理器” 解决方案1.打开控制面板,找到并打开程序。2.找到并打开程序里的启用或关闭windows功能。3.在‘Internet Information Services’下的‘web管理工具’中找到IIS相关功能,在前面的复选框中…

探索数字孪生世界:市场上五款炙手可热的数字孪生产品介绍

山海鲸可视化:山海鲸可视化是一款国内领先的数字孪生软件,具有强大的GIS功能和可视化效果,广泛应用于城市规划、建筑设计和智慧城市等领域。 华为云数字孪生:华为云数字孪生平台提供了全面的数字化解决方案,包括智慧城…

链表中倒数第k个结点(快慢指针问题)

⭐️ 往期相关文章 💫链接1:leetcode 876.链表的中间结点(快慢指针问题) 💫链接2:leetcode 206.反转链表 💫链接3:leetcode 203.移除链表元素 💫链接4:数据结构-手撕单链表代码详解…

实训笔记7.4

实训笔记7.4 7.4一、座右铭二、IDEA集成开发环境的安装和使用三、DEBUG断点调试四、Java设计模式4.1 适配器模式4.2 动态代理模式4.3 单例设计模式 五、Java中网络编程5.1 网络编程三个核心要素5.2 TCP网络编程 六、基于网络编程的聊天系统6.1 需求分析6.2 系统设计6.2.1 概要设…

解放运营人员:钡铼技术S475物联网网关实现养殖环境的远程监控与告警

在养殖行业中,对环境参数的精确监测与控制至关重要。然而,传统的监测方法往往存在诸多痛点,如数据采集不准确、传输速度慢、可视化效果差等。为了解决这些问题,钡铼技术公司推出了其旗舰产品——S475多功能RTU,该产品在…

如何利用思维导图提高项目管理效率

思维导图 是一种强大的工具,可以帮助我们更好地组织和管理项目。它是一种以图形方式展现思维和概念之间关系的方法,通过将主题、子主题和分支串联起来,帮助我们清晰地了解任务的层次结构和相互关系。在项目管理中,思维导图可以帮助…

数据生成实体类解决方案

文章目录 数据生成实体类解决方案 简介工作原理解析JSON生成实体类示例JSON消息解析JSON核心方法:调用示例:将数据保存到实体类中。将实体类转为输出为JSON。 思考 数据生成实体类解决方案 直接将xml导入到Studio里即可。下载文件连接: CSDN…

GPIO点灯

简述:本人使用教材为《嵌入式系统原理与应用》,GPIOCON控制输出,GPIODAT控制高电平和低电平,高电平点亮,低电平熄灭。