Oracle 日常巡检——数据库基本情况检查

对于线上的业务,Oracle 的 数据库 运行的稳定性和安全性是用户关心的一个至关重要的问题,除了通过监控平台对数据库进行监控以外,还需要定期对数据库进行“体检”,数据库巡检是保障数据库稳定运行的必不可少的辅助手段。

高效进行  <a href='http://www.codercto.com/category/oracle.html'>Oracle</a>  日常巡检——数据库基本情况检查

高效进行 Oracle 日常巡检——数据库基本情况检查

本文将简要介绍一下从哪些方面对 Oracle 数据库进行巡检以及巡检的方法。

一、检查数据库的基本状况

1. 检查 Oracle 实例状态

SQL> select instance_name,host_name,startup_time,status,database_status from v$instance; 

高效进行 Oracle 日常巡检——数据库基本情况检查

其中“STATUS”表示Oracle当前的实例状态,必须为“OPEN”;“DATABASE_STATUS”表示Oracle当前数据库的状态,必须为“ACTIVE”。

SQL> select name,log_mode,open_mode from v$database; 

高效进行 Oracle 日常巡检——数据库基本情况检查

其中

  • “LOG_MODE”表示Oracle当前的归档方式;
  • “ARCHIVELOG”表示数据库运行在归档模式下;
  • “NOARCHIVELOG”表示数据库运行在非归档模式下。

在我们的系统中数据库必须运行在归档方式下。

2.  检查 Oracle 服务进程

$ps -ef|grep ora_|grep -v grep&&ps -ef|grep ora_|grep -v grep|wc –l 

高效进行 Oracle 日常巡检——数据库基本情况检查

在检查Oracle的进程命令输出后,输出显示至少应包括以下一些进程:

  • Oracle写数据文件的进程,输出显示为:“oradbw0CKDB”
  • Oracle写日志文件的进程,输出显示为:“oralgwr CKDB”
  • Oracle监听实例状态的进程,输出显示为:“orasmon CKDB” .
  • Oracle监听客户端连接进程状态的进程,输出显示为:“orapmon CKDB”
  • Oracle进行归档的进程,输出显示为:“oraarc0 CKDB”
  • Oracle进行检查点的进程,输出显示为:“orackptCKDB” .
  • Oracle进行恢复的进程,输出显示为:“orareco CKDB”

3.  检查 Oracle 的监听状态

lsnrctl status  

高效进行 Oracle 日常巡检——数据库基本情况检查

“Services Summary”项表示Oracle的监听进程正在监听哪些数据库实例。

检查监听进程是否存在:

ps -ef|grep lsn|grep -v grep 
oracle 2954 1 0 May07 ? 00:01:17 /data/oracle/product/11.2.0/bin/tnslsnr LISTENER –inherit 

二、检查系统和 Oracle 日志文件

检查相关的日志文件主要包含:

  • 检查操作系统的日志文件
  • 检查Oracle日志文件
  • 检查Oracle核心转储目录
  • 检查Root用户和Oracle用户的email

总共四个部分。

1.  检查操作系统日志文件

# cat /var/log/messages |grep failed 

查看是否有与Oracle用户相关的出错信息。

2.  检查 Oracle 日志文件

$ cat /data/oracle/admin/CKDB/bdump/alert_CKDB.log |grep ora- 
$ cat /data/oracle/admin/CKDB/bdump/alert_CKDB.log |grep err 
$ cat /data/oracle/admin/CKDB/bdump/alert_CKDB.log |grep fail  

在Oracle的运行中,会在警告日志文件中记录数据库的一些运行情况 ,定时查看此文件,可以及时了解数据库运行状态是否异常。

3.  检查 Oracle 核心转储目录

$ls $ORACLE_BASE/admin/CKDB/cdump/*.trc|wc -l  
$ls $ORACLE_BASE/admin/CKDB/udump/*.trc|wc –l 

如果上面命令的结果每天都在增长,则说明Oracle进程经常发生核心转储。这说明某些用户进程或者数据库后台进程由于无法处理的原因而异常退出。频繁的核心转储特别是数据库后台进程的核心转储会导致数据库异常终止。

4.  检查Root用户和Oracle用户的email

#tail –n 200 /var/mail/root 
#tail –n 200 /var/mail/oracle 

查看有无与Oracle用户相关的出错信息。

三、检查oracle对象状态

主要检查相关Oracle对象的状态,包含:

  • 检查Oracle控制文件状态
  • 检查Oracle在线日志状态
  • 检查Oracle表空间的状态
  • 检查Oracle所有数据文件状态
  • 检查Oracle所有表、索引、存储过程、触发器、包等对象的状态
  • 检查Oracle所有回滚段的状态

总共六个部分。

1.  检查控制文件状态

SQL> select status,name from v$controlfile; 

高效进行 Oracle 日常巡检——数据库基本情况检查

输出结果“STATUS”应该为空。状态为空表示控制文件状态正常。

2.  检查在线日志文件状态

SQL>select group#,status,type,member from v$logfile; 

高效进行 Oracle 日常巡检——数据库基本情况检查

输出结果“STATUS”应该为非“INVALID”,非“DELETED”。

注:“STATUS”显示为空表示正常。

3. 检查表空间的状态

SQL> select tablespace_name,status from dba_tablespaces; 

高效进行 Oracle 日常巡检——数据库基本情况检查

输出结果中STATUS应该都为ONLINE。

4.  检查所有数据文件状态

SQL> select name,status from v$datafile; 

高效进行 Oracle 日常巡检——数据库基本情况检查

输出结果中“STATUS”应该都为“ONLINE”或者为“AVAILABLE”

5.  检查无效的对象

sql>select owner,object_name,object_type from dba_objects where status!='VALID' and owner!='SYS' and owner!='SYSTEM';  
no rows selected  

如果有记录返回,则说明存在无效对象。若这些对象与应用相关,那么需要重新编译生成这个对象。

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

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

相关文章

matlab对多个矩阵循环,MATLAB:在不使用循环的情况下提取矩阵的多个部分

有许多方法可以在没有循环的情况下完成此操作.大多数解决方案涉及将向量x和y扩展为更大的索引矩阵,并且可能使用函数REPMAT,BSXFUN或SUB2IND中的一个或多个.可以在here找到用于矩阵索引的良好教程.但是,既然你要求一个优雅的解决方案,这里有一点不寻常.它使用anonymous functio…

路由器ospf动态路由配置

技术原理&#xff1a;Ospd开放式最短路径优先协议。是目前网络中应用最广泛的路由协议之一。属于内部网络路由协议。能够适应各种规模的网络环境&#xff0c;是典型的链路状态协议。Ospf路由协议通过向全网扩散本设备的链路状态信息&#xff0c;使网络中每台设备最终同步一个具…

js常用事件整理—兼容所有浏览器

1.鼠标滚动事件。 说明&#xff1a;返回值 大于0向上滚动&#xff0c;小于0向下滚动。 兼容型&#xff1a;所有浏览器。 代码&#xff1a; /*********************** * 函数&#xff1a;鼠标滚动方向* 参数&#xff1a;event * 返回&#xff1a;滚轮方向[向上&#xff08;大…

Kubernetes 持久化存储 Cephfs

熟悉kubernetes volume的同学应该了解&#xff0c;kubernetes 对volume的提供支持“静态PV”和“动态PV”两种方式。 静态PV&#xff1a;集群管理员创建一些PV&#xff0c;之后便可用于PVC消费。 动态PV&#xff1a;相比静态PV而言&#xff0c;动态PV无需管理员手动创建PV&…

RDIFramework.NET — 系列目录 — 基于.NET的快速信息化系统开发框架

RDIFramework.NET — 基于.NET的快速信息化系统开发框架 — 系列目录RDIFramework.NET&#xff0c;基于.NET的快速信息化系统开发、整合框架&#xff0c;给用户和开发者最佳的.Net框架部署方案。框架简单介绍RDIFramework.NET&#xff0c;基于.NET的快速信息化系统开发、整合框…

Visual Studio项目版本转换器(c#项目版本转换器 v1.0)

Visual Studio项目版本转换器&#xff08;c#项目版本转换器 v1.0&#xff09; 使用截图&#xff1a; 下载地址&#xff1a;http://files.cnblogs.com/stone_w/VsConvert.zip vs转换中文通用版&#xff0c;目前版本只支持c#程序。 功能说明&#xff1a; 1.智能判断当前待转换引…

debian apache php mysql,Debian下配置APACHE2+MYSQL5+PHP5

Loading...如果之前安装过apache, mysql, php,要先删除掉&#xff1a;#apt-get remove --purge apache2.2-common apache2#apt-get remove mysql1. 先安装apache2#apt-get install apache2.2-common apache2#apache2ctl start //启动apache2测试&#xff0c;在我的host os中的I…

基于 Kubernetes 构建企业 Jenkins 持续集成平台

1、部署Jenkins 新建kube-ops 命名空间 $ kubectl create namespace kube-ops 新建Deployment文件(jenkins2.yaml) ---apiVersion: extensions/v1beta1kind: Deploymentmetadata: name: jenkins2 namespace: kube-opsspec: template: metadata: labels: …

TC 配置插件

转载&#xff1a;http://hi.baidu.com/accplaystation/item/07534686f39dc329100ef310 1、插件下载地址&#xff1a;http://www.topcoder.com/tc?moduleStatic&d1applet&d2plugins 一般用下面三个插件&#xff1a;CodeProcessor&#xff08;2.0&#xff09;&#xff0…

WebClient 访问间歇性返回403解决方案

说明&#xff1a;前段时间做的一个项目莫名的返回403的错误&#xff0c;这种情况也多大是程序员最不喜欢的了&#xff0c;没办法先来分析一下错误信息。之前的代码如下&#xff1a; WebClient webclient new WebClient();string u9Str webclient.DownloadString("http:/…

bootstrap select2 php,JS组件Bootstrap Select2使用方法详解

在介绍select组件的时候&#xff0c;之前分享过一篇JS组件中bootstrap multiselect两大组件较量的文章&#xff0c;这两个组件的功能确实很强大&#xff0c;本文分享下select组件的一些用法和特性。一些通用的单选、多选、分组等功能这里就不多做介绍了&#xff0c;multiselect…

恢复Linux系统权限

注意 如果Linux整个系统文件权限都被设置为777&#xff0c;请不要重启系统&#xff0c;因为很多同学认为万能的重启能解决98%的问题。重启后权限就能恢复。但这次请不要重启系统&#xff0c;如果重启系统&#xff0c;系统直接损坏。 解决思路 虽然损坏的服务器没有权限备份&…

读《我们终将逝去的青春》

前一阵看了电影版的《致我们终将逝去的青春》&#xff0c;刚好手上有这本小说&#xff0c;于上我急功近利地花了大概2天把文字版的《致青春》看完了。总体感觉电影版对小说的后半部分做了大幅的修改&#xff0c;感觉修改得不太好。也许电影的主题是青春无悔的爱情&#xff0c;而…

文件删除小助手

亲&#xff0c;还在为删除多个文件而发愁吗&#xff1f;还在为删除不同目录下的N多文件而发愁吗&#xff1f;那你就下载这个吧。 功能以及优点&#xff1a; 1.支持删除某一类文件。 2.支持某一路径下所有文件的检索删除。 3.支持复杂文件名称匹配。 4.免安装&#xff0c;绿色中…

2020-11-29

分布式爬虫往往都需要多个环境&#xff0c;多个进程&#xff0c;如果手动去管理这些环境是很费事的&#xff0c;使用Docker集群就能很好地帮你解决这些问题&#xff0c;让你的爬虫管理变得简单。 主节点安装Docker 这里主节点建议大家使用Ubuntu&#xff0c;从节点随意。 Ubun…

用php实现随机点名,使用javascript做的一个随机点名程序

这篇文章主要介绍了使用javascript做的一个随机点名程序&#xff0c;经测试&#xff0c;效果相当不错,需要的朋友可以参考下/p>"http://www.w3.org/TR/html4/loose.dtd">点名var status 1;var name new Array(范 鹏,张子涵,代天明,孙 季,孙 磊,王鸿罡,曾凡丁…

C#模拟POST表单提交 --- WebClient

WebClient&#xff1a;http://msdn.microsoft.com/zh-cn/library/system.net.webclient(vVS.80).aspx&#xff08;MSDN&#xff09; 代码&#xff1a; string postString "arg1a&arg2b";//这里即为传递的参数&#xff0c;可以用工具抓包分析&#xff0c;也可以自…

nginx反向代理配置实例分享

nginx反向代理配置一例。 配置内容如下: user www www; worker_processes 8; error_log /usr/local/webserver/nginx/logs/nginx_error.log crit; pid /usr/local/webserver/nginx/logs/nginx.pid; worker_rlimit_nofile 51200; events { use epoll; worker_connections 51200;…

八伟大的工具,Windows用户永远都不想错过

有许多的应用程序你可以找到&#xff0c;但是获得免费并且好用 的程序不是一件容易的事情&#xff0c;每当你需要这样的软件的时候&#xff0c;你就会网上搜啊搜&#xff0c;结果下载下来一运行达不到想要的效果&#xff0c;这就是今天我分享我收藏的8个工具原因&#xff0c;这…

Python3网络设备巡检(交换机篇)

介绍 只写了交换机的&#xff0c;路由器、防火墙、负载等其它设备以后&#xff0c;有需求再写&#xff0c;下面以一组交换机为例。 思路 1、收取交换机的信息 需要哪些信息&#xff0c;哪些命令&#xff0c;不同品牌交换机命令不同&#xff08;本篇以H3C为例&#xff09;&a…