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

转:面对一个全新的环境,作为一个Oracle DBA,首先应该了解什么

转载:面对一个全新的环境,作为一个Oracle DBA,首先应该了解什么

由于时间比较久了,找不到原文章的链接,先贴上内容供大家参考

 

在这里,不谈那些大的方面,比如了解整个IT环境整体情况,假设你已经知道了这些,接下来需要面对的就是这些一个个活生生的database了.这里总结了一些一般的思路来面对一个全先的database,从而快速了解你面对的环境概要.
这也不是教科书,只是一些心得和体会,对于这种问题,每个人的认识的角度是不一样的.欢迎大家继续补充完善.

1、先要了解当前的Oracle 数据库的版本和平台和相关信息
   这个很重要,忙乎了半天还知道你的数据库是哪个版本,跑在什么系统上,那岂不是很悲哀,所以我个人认为这是第一步需要了解的。下面的这些脚本可以帮助你获取你需要的相关信息。

SQL> conn

Enter user-name: scott

Enter password:

Connected.

SQL> set linesize 1000

SQL> set pagesize 1000

SQL> select * from v$version;

BANNER

----------------------------------------------------------------

Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Prod

PL/SQL Release 10.2.0.1.0 - Production

CORE    10.2.0.1.0      Production

TNS for Linux: Version 10.2.0.1.0 - Production

NLSRTL Version 10.2.0.1.0 – Production

SQL> select dbid, name, open_mode, database_role, platform_name from v$database

      DBID NAME      OPEN_MODE  DATABASE_ROLE    PLATFORM_NAME

---------- --------- ---------- ----------------

 341090406 GRS       READ WRITE PRIMARY          Linux IA (32-bit)

select dbms_utility.port_string from dual;

Linuxi386/Linux-2.0.34-8.1.0


   ----select * from dba_registry_database;
   select dbid, name, open_mode, database_role, platform_name from v$instance; V$database

   set serveroutput on
   declare
     ver VARCHAR2(100);
     compat VARCHAR2(100);
   begin
     dbms_utility.db_version(ver, compat);
     dbms_output.put_line('Version: ' || ver ||' Compatible: ' || compat);
   end;
   /


2、其次要了解你的数据库中装了哪些组件
   select * from dba_registry;
 EM Oracle Enterprise Manager 10.2.0.1.0 VALID

SDO Spatial 10.2.0.1.0 VALID

ORDIM Oracle interMedia 10.2.0.1.0 VALID

AMD OLAP Catalog 10.2.0.1.0 VALID

XDB Oracle XML Database 10.2.0.1.0 VALID

CONTEXT Oracle Text 10.2.0.1.0 VALID

EXF Oracle Expression Filter 10.2.0.1.0 VALID

RUL Oracle Rules Manager 10.2.0.1.0 VALID

OWM Oracle Workspace Manager 10.2.0.1.0 VALID

ODM Oracle Data Mining 10.2.0.1.0 VALID

CATALOG Oracle Database Catalog Views 10.2.0.1.0 VALID

CATPROC Oracle Database Packages and Types 10.2.0.1.0 VALID

JAVAVM JServer JAVA Virtual Machine 10.2.0.1.0 VALID

XML Oracle XDK 10.2.0.1.0 VALID

CATJAVA Oracle Database Java Packages 10.2.0.1.0 VALID

APS OLAP Analytic Workspace 10.2.0.1.0 VALID

XOQ Oracle OLAP API 10.2.0.1.0 VALID
3、搞清楚这个环境是单机还是集群?
   这个判断方法很多,我这里给出一个借助dbms_utility来判断的方法。
   set serveroutput on

   declare
     inst_tab dbms_utility.instance_table;
     inst_cnt NUMBER; 
   begin
     if dbms_utility.is_cluster_database then
        dbms_utility.active_instances(inst_tab, inst_cnt);
        dbms_output.put_line('-' || inst_tab.FIRST);
        dbms_output.put_line(TO_CHAR(inst_cnt));
     else
        dbms_output.put_line('Not A Clustered Database');
     end if;
   end;
   /

Not A Clustered Database


4、是否配置了DataGuard?
   select protection_mode, protection_level, remote_archive, database_role, dataguard_broker,guard_status
   from v$database;
5、是否起用了归档模式?
   conn /as sysdba
   archive log list;
   select log_mode from v$database;
 
6、是否起用了flashback database特性?
   select flashback_on from v$database;
   如果是,再进一步查看FRA的配置情况

SQL> show parameter db_recover;

 

NAME                                 TYPE        VALUE

------------------------------------ ----------- ------------------------------

db_recovery_file_dest                string      /u01/app/oracle/flash_recovery

                                                 _area

db_recovery_file_dest_size           big integer 2G

select * from v$parameter where name like 'db_recovery_file%';

 select * from v$flash_recovery_area_usage;


7、是否起用了force logging和补充日志?
   select force_logging,supplemental_log_data_min, supplemental_log_data_pk, supplemental_log_data_ui,
          supplemental_log_data_fk, supplemental_log_data_all
   from v$database;
8、了解控制文件的组成
   select * from v$controlfile;
9、了解日志文件的组成
   select l.group#, lf.type, lf.member, l.bytes, l.status LOG_STATUS, lf.status LOGFILE_STATUS
   from v$log l, v$logfile lf
   where l.group# = lf.group#
   order by 1,3;
10、了解参数文件的组成和位置
    show parameter spfile
    create spfile from pfile...
    create pfile from spfile;
    create spfile from memory;
    create pfile from memory;
11、了解instance的相关信息
    select instance_name, host_name, status, archiver, database_status, instance_role, active_state from v$instance;
12、用户和密码相关
    是否使用了缺省密码?
    是否使用了profile?
    是否起用了密码验证函数?
    用户身份验证的方法?
    密码是否区分大小写等。
    select name, value from gv$parameter where name = 'resource_limit';
    select profile, resource_name, limit from dba_profiles order by 1,2;

    select username, profile from dba_users where account_status = 'OPEN' order by 1;
 
    select d.username, u.account_status
    from dba_users_with_defpwd d, dba_users u
    where d.username = u.username and account_status = 'OPEN' 
    order by 2,1;
 
13、是否打开了BLOCK CHANGE TRACKING
    select filename, status, bytes from v$block_change_tracking;
14、起用了那些特性(Feature)?
    DBMS_FEATURE_USAGE_REPORT
 
15、表空间和数据文件的规划
    这个大家都很熟悉,就不写了
 
16、字符集相关
    select * from database_properties;
 
17、系统中是否存在invalid对象
    select owner, object_type, COUNT(*)
    from dba_objects
    where status = 'INVALID'
    group by owner, object_type;
18、更进一步的
    是否使用了ASM?
    当前系统的备份方法和策略是什么?
    网络文件的配置是如何的?
 
19、查看一下最近的alert日志,获取一些有用的信息
20、跑几个性能分析报告,看看最近系统的运行状态如何
21、跑一个RDA报告,收集完整的系统状态报告
 
好了,有了这一些基本信息(不完全),你基本上对你新接触的这个系统有了一个大概的了解,接来下,你再慢慢的深入分析,然后制订出一套符合实际情况的运维规范来,慢慢的养猪吧。

 

select dbid, name, open_mode, database_role, platform_name from v$instance; (should be V$database)

 

 

 

有个建议: RDA工具...连数据库相关的数据库信息也会抓出来..非常的完整...

 

个人感觉在RDA的基础上还需要一下的信息需要收集:

select username,account_status,default_tablespace,temporary_tablespace,profile,to_char(created,'yyyy-mm-dd hh24:mi:ss')
from dba_users order by created;

select * from dba_profiles order by 1;

select job_name,to_char(start_date,'yyyy-mm-dd hh24:mi:ss'),enabled from Dba_Scheduler_Jobs order by 3,2;

select * from v$controlfile_record_section;

col comp_id for a30
col comp_name for a30
col version for a30
col status for a30
select comp_id,comp_name,version,status from dba_registry order by 4;

select * from dba_sys_privs where grantee='<user_name>';
select * from dba_tab_privs where grantee='<user_name>';
select * from dba_role_privs where grantee='<user_name>';

select * from dba_role_privs order by grantee;
select * from role_sys_privs order by role;
select * from role_tab_privs order by role;

 

转载于:https://www.cnblogs.com/yhq1314/p/9923073.html

相关文章:

  • 什么是I2C管理总线
  • Java多线程系列---“JUC锁”03之 Condition
  • Junit Test 的时候出错java.lang.IllegalStateException: Failed to load ApplicationContext
  • 小教练教MM如何去掉你的小肚子
  • vue cli 3 webpack-merge webpack 3 bug
  • 一句话介绍python线程、进程和协程
  • ASP.NET中上传并读取Excel文件数据
  • 在 ISA Server 2004 中发布 ××× 服务器
  • Linux Command
  • ACM-ICPC 2018 青岛赛区现场赛 D. Magic Multiplication ZOJ 4061 (思维+构造)
  • 实战 HTTP 处理程序(HTTP Handler) (4)--与Web程序共享Session
  • DOM事件流
  • 绝对路径 相对路径 相对虚拟目录路径
  • Oracle Long类型转换为Clob类型
  • 三维模型逐渐透明化
  • angular组件开发
  • CSS居中完全指南——构建CSS居中决策树
  • js算法-归并排序(merge_sort)
  • Linux快速复制或删除大量小文件
  • React Native移动开发实战-3-实现页面间的数据传递
  • SpriteKit 技巧之添加背景图片
  • vue2.0项目引入element-ui
  • 表单中readonly的input等标签,禁止光标进入(focus)的几种方式
  • 从地狱到天堂,Node 回调向 async/await 转变
  • 分类模型——Logistics Regression
  • 基于Javascript, Springboot的管理系统报表查询页面代码设计
  • 基于Mobx的多页面小程序的全局共享状态管理实践
  • 你不可错过的前端面试题(一)
  • 前端代码风格自动化系列(二)之Commitlint
  • 如何使用Mybatis第三方插件--PageHelper实现分页操作
  • 实现简单的正则表达式引擎
  • 它承受着该等级不该有的简单, leetcode 564 寻找最近的回文数
  • 携程小程序初体验
  • 新版博客前端前瞻
  • 智能合约开发环境搭建及Hello World合约
  • Mac 上flink的安装与启动
  • 阿里云服务器购买完整流程
  • 交换综合实验一
  • ​Linux·i2c驱动架构​
  • ###项目技术发展史
  • #NOIP 2014#day.2 T1 无限网络发射器选址
  • (03)光刻——半导体电路的绘制
  • (06)Hive——正则表达式
  • (9)目标检测_SSD的原理
  • (八十八)VFL语言初步 - 实现布局
  • (二)Linux——Linux常用指令
  • (附源码)springboot学生选课系统 毕业设计 612555
  • (完整代码)R语言中利用SVM-RFE机器学习算法筛选关键因子
  • (原創) 是否该学PetShop将Model和BLL分开? (.NET) (N-Tier) (PetShop) (OO)
  • .net framwork4.6操作MySQL报错Character set ‘utf8mb3‘ is not supported 解决方法
  • .net MVC中使用angularJs刷新页面数据列表
  • .Net 垃圾回收机制原理(二)
  • .NET 使用 ILMerge 合并多个程序集,避免引入额外的依赖
  • .NET开发人员必知的八个网站
  • 。Net下Windows服务程序开发疑惑