通过shell脚本监控日志切换频率 (94天)
时间:2022-05-04
本文章向大家介绍通过shell脚本监控日志切换频率 (94天),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
在数据库遇到性能问题的时候,可能从io,cpu等角度能够下手找到性能瓶颈,日志的切换也是影响性能的一个因素,如果日志切换台频繁,等待时间就会在日志相关的事件上,从数据库的角度来说,肯定是io的瓶颈。 可以通过如下的shell脚本来得到一个简单的报告。
---脚本如下:
sqlplus -s $DB_CONN_STR@$SH_DB_SID<<EOF
set linesize 150
set pages 100
set feedback off
set verify off
col dbname new_value dbname
col time_stamp new_value time_stamp
col timestamp_np noprint
col year_np noprint
col month_np noprint
col mon for a3
col day for a2
ttitle off
SELECT name dbname, substr(to_char(sysdate,'YYYY-Mon-DD HH24:MI:SS'),1,20)
time_stamp
FROM v$database
/
col bytes format 9,999,999,999,999
col member format a60
select group#,thread#,sequence#,members,bytes/1024/1024 size_MB,archived,status
from v$log order by 1,2;
ttitle left "Redo Switch times per hour" center "&dbname" right "&time_stamp"
set term on
col tps00 for 999 head "00"
col tps01 for 999 head "01"
col tps02 for 999 head "02"
col tps03 for 999 head "03"
col tps04 for 999 head "04"
col tps05 for 999 head "05"
col tps06 for 999 head "06"
col tps07 for 999 head "07"
col tps08 for 999 head "08"
col tps09 for 999 head "09"
col tps10 for 999 head "10"
col tps11 for 999 head "11"
col tps12 for 999 head "12"
col tps13 for 999 head "13"
col tps14 for 999 head "14"
col tps15 for 999 head "15"
col tps16 for 999 head "16"
col tps17 for 999 head "17"
col tps18 for 999 head "18"
col tps19 for 999 head "19"
col tps20 for 999 head "20"
col tps21 for 999 head "21"
col tps22 for 999 head "22"
col tps23 for 999 head "23"
SELECT *
FROM
( SELECT substr(year_np,1,8) timestamp_np,
substr(year_np,5,2) Mon, substr(year_np,7,2) Day,
sum(decode(substr(year_np,9,2),'00',cnt,0)) tps00,
sum(decode(substr(year_np,9,2),'01',cnt,0)) tps01,
sum(decode(substr(year_np,9,2),'02',cnt,0)) tps02,
sum(decode(substr(year_np,9,2),'03',cnt,0)) tps03,
sum(decode(substr(year_np,9,2),'04',cnt,0)) tps04,
sum(decode(substr(year_np,9,2),'05',cnt,0)) tps05,
sum(decode(substr(year_np,9,2),'06',cnt,0)) tps06,
sum(decode(substr(year_np,9,2),'07',cnt,0)) tps07,
sum(decode(substr(year_np,9,2),'08',cnt,0)) tps08,
sum(decode(substr(year_np,9,2),'09',cnt,0)) tps09,
sum(decode(substr(year_np,9,2),'10',cnt,0)) tps10,
sum(decode(substr(year_np,9,2),'11',cnt,0)) tps11,
sum(decode(substr(year_np,9,2),'12',cnt,0)) tps12,
sum(decode(substr(year_np,9,2),'13',cnt,0)) tps13,
sum(decode(substr(year_np,9,2),'14',cnt,0)) tps14,
sum(decode(substr(year_np,9,2),'15',cnt,0)) tps15,
sum(decode(substr(year_np,9,2),'16',cnt,0)) tps16,
sum(decode(substr(year_np,9,2),'17',cnt,0)) tps17,
sum(decode(substr(year_np,9,2),'18',cnt,0)) tps18,
sum(decode(substr(year_np,9,2),'19',cnt,0)) tps19,
sum(decode(substr(year_np,9,2),'20',cnt,0)) tps20,
sum(decode(substr(year_np,9,3),'21',cnt,0)) tps21,
sum(decode(substr(year_np,9,3),'22',cnt,0)) tps22,
sum(decode(substr(year_np,9,2),'23',cnt,0)) tps23
FROM (SELECT to_char(first_time,'YYYYMMDDHH24') year_np,count(*) cnt
FROM v$log_history where first_time>sysdate -15
GROUP BY to_char(first_time,'YYYYMMDDHH24')
)
GROUP BY substr(year_np,1,8), substr(year_np,5,2), substr(year_np,7,2)
)
ORDER BY timestamp_np
/
<<EOF
exit;
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 带你用 Python 实现自动化群控设备
- Pyhon制作脚本提取日志数据
- 使用Safari或者Chrome远程调试IOS Safari中的页面
- cmake Tips
- 本体入门(一):本体构建 101
- 大数据获取案例:Python网络爬虫实例
- 【pyspark】parallelize和broadcast文件落盘问题(后续)
- 【Tbase开源版测评】基于PostgreSQL的国产开源数据库初体验
- 聊聊RedisToken
- 【Ceph RGW】Bucket Sharding的设置
- 每日手撕一道算法-1143.最长公共子序列
- 理解JavaScript 中的执行上下文和执行栈
- Spring Boot 2.x基础教程:使用集中式缓存Redis
- 彻底理解 Cookie、Session、Token、JWT这些登录授权方法
- 本体入门(二):OWL 本体构建指南f