Oracle DBA在新环境下必须了解的事情
2009-06-10 20:33
375 查看
Oracle DBA在新环境下必须了解的事情
面对一个全新的环境,作为一个Oracle DBA,首先应该了解什么呢?本文将为大家具体讲解如何做一个合格的DBA。
在这里,不谈那些大的方面,比如了解整个IT环境整体情况,假设你已经知道了这些,接下来需要面对的就是这些一个个活生生的database了。这里总结了一些一般的思路来面对一个全先的database,从而快速了解你面对的环境概要。
这也不是教科,只是一些心得和体会,对于这种问题,每个人的认识的角度是不一样的。欢迎大家继续补充完善。
1、先要了解当前的Oracle 数据库的版本和平台和相关信息
这个很重要,忙乎了半天还知道你的数据库是哪个版本,跑在什么系统上,那岂不是很悲哀,所以我个人认为这是第一步需要了解的。下面的这些脚本可以帮助你获取你需要的相关信息。
2、其次要了解你的数据库中装了哪些组件
3、搞清楚这个环境是单机还是集群?
这个判断方法很多,我这里给出一个借助dbms_utility来判断的方法。
4、是否配置了DataGuard?
5、是否起用了归档模式?
6、是否起用了flashback database特性?
如果是,再进一步查看FRA的配置情况
7、是否起用了force logging和补充日志?
8、了解控制文件的组成
9、了解日志文件的组成
10、了解参数文件的组成和位置
11、了解instance的相关信息
12、用户和密码相关
是否使用了缺省密码?
是否使用了profile?
是否起用了密码验证函数?
用户身份验证的方法?
密码是否区分大小写等。
13、是否打开了BLOCK CHANGE TRACKING
14、起用了那些特性(Feature)?
15、表空间和数据文件的规划
这个大家都很熟悉,就不写了
16、字符集相关
17、系统中是否存在invalid对象
18、更进一步的
是否使用了ASM?
当前系统的备份方法和策略是什么?
网络文件的配置是如何的?
19、查看一下最近的alert日志,获取一些有用的信息
20、跑几个性能分析报告,看看最近系统的运行状态如何
21、跑一个RDA报告,收集完整的系统状态报告
好了,有了这一些基本信息(不完全),你基本上对你新接触的这个系统有了一个大概的了解,接来下,你再慢慢的深入分析,然后制订出一套符合实际情况的运维规范来,慢慢的养猪吧。
面对一个全新的环境,作为一个Oracle DBA,首先应该了解什么呢?本文将为大家具体讲解如何做一个合格的DBA。
在这里,不谈那些大的方面,比如了解整个IT环境整体情况,假设你已经知道了这些,接下来需要面对的就是这些一个个活生生的database了。这里总结了一些一般的思路来面对一个全先的database,从而快速了解你面对的环境概要。
这也不是教科,只是一些心得和体会,对于这种问题,每个人的认识的角度是不一样的。欢迎大家继续补充完善。
1、先要了解当前的Oracle 数据库的版本和平台和相关信息
这个很重要,忙乎了半天还知道你的数据库是哪个版本,跑在什么系统上,那岂不是很悲哀,所以我个人认为这是第一步需要了解的。下面的这些脚本可以帮助你获取你需要的相关信息。
select * from v$version; select * from dba_registry_database; select dbid, name, open_mode, database_role, platform_name from v$instance; select dbms_utility.port_string from dual; 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; / |
select * from dba_registry; |
这个判断方法很多,我这里给出一个借助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; / |
select protection_mode, protection_level, remote_archive, database_role, dataguard_broker,guard_status from v$database; |
conn /as sysdba archive log list; select log_mode from v$database; |
select flashback_on from v$database; |
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; |
select * from v$controlfile; |
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; |
show parameter spfile create spfile from pfile... create pfile from spfile; create spfile from memory; create pfile from memory; |
select instance_name, host_name, status, archiver, database_status, instance_role, active_state from v$instance; |
是否使用了缺省密码?
是否使用了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; |
select filename, status, bytes from v$block_change_tracking; |
DBMS_FEATURE_USAGE_REPORT |
这个大家都很熟悉,就不写了
16、字符集相关
select * from database_properties; |
select owner, object_type, COUNT(*) from dba_objects where status = 'INVALID' group by owner, object_type; |
是否使用了ASM?
当前系统的备份方法和策略是什么?
网络文件的配置是如何的?
19、查看一下最近的alert日志,获取一些有用的信息
20、跑几个性能分析报告,看看最近系统的运行状态如何
21、跑一个RDA报告,收集完整的系统状态报告
好了,有了这一些基本信息(不完全),你基本上对你新接触的这个系统有了一个大概的了解,接来下,你再慢慢的深入分析,然后制订出一套符合实际情况的运维规范来,慢慢的养猪吧。
相关文章推荐
- 『管理调优』Oracle DBA在新环境下必须了解的事情
- Oracle DBA在新环境下必须了解的事情
- Oracle DBA在新环境下必须了解的事情
- Oracle DBA在新环境下必须了解的事情
- Oracle DBA在新环境下必须了解的事情
- DBA的典型职责(你想做到合格DBA必须要做的事情)
- 面对一个全新的环境,作为一个Oracle DBA,首先应该了解什么?
- 做微信登录前必须先了解的事情
- MySQL迁移到Oracle前必须了解的50件事
- 使用Redis之前5个必须了解的事情
- Oracle 9i的OEM连接10g的服务器,报“您必须具有SELECT ANY DICTIONARY权限才能运行此应用程序。请要求DBA为您授予此权限。”的错误
- oracle体系结构必须先了解的两个基本的概念
- 面对全新的环境,Oracle DBA首先应该了解什么?
- 使用Redis之前5个必须了解的事情
- 【推荐】DBA必须了解的11g中的一些变化
- 云虚机选购指南之四新购云虚拟主机用户必须要了解的事情
- DBA入门必须了解的十件事
- oracle体系结构必须先了解的两个基本的概念
- 关于D3D11,你必须了解的几件事情(二)
- 面对一个全新的环境,作为一个Oracle DBA,首先应该了解什么?