原文地址:https://www.toutiao.com/i6499008214980362765/
oracle数据库启动:oracle服务启动,通过参数文件查找控制文件,启动控制文件,则控制文件调用数据文件和日志文件。
oracle的文件系统组成:参数文件,控制文件,数据文件,日志文件组成。
1.参数文件(initialization parameter file):是 ORALE RDBMS 主要的配置点,它是配置参数和数值的集合。每一个参数值都控制或修改数据库和实例的某个方面。
2.控制文件(control file):由Oracle数据库实例在启动时被访问的内部二进制文件,它们所存放的路径由参数文件的control_files=参数来确定。 Oracle一般有两个或更多的控制文件,每个控制文件记录有相同的信息,在数据库运行中如果某个控制文件出错时,Oracle会自动使用另外一个控制文件。当所有的控制文件都损坏时系统将不能工作;控制文件是实例和数据库的链接文件。
3.数据文件(data file):用于存放所有数据库的数据文件,Oracle安装过程中自动建立多个必要的数据文件。这些数据文件用于存放Oracle系统的基本数据。在应用系统开发过程中,我们可根据需要另建立一些数据文件。如果按数据存放类型来分:用户数据(存放应用系统的数据),系统数据(管理用户数据和数据库系统本身的数据,如:数据字典,用户所建的表名,数据类型等)。
3.日志文件(log file):也叫事务记录文件,该文件记录有事物对数据库进行的一切修改操作或事务。
4.其他支持文件:sqlnet.ora文件,tnsnames.ora文件,listener.ora文件;以linux为例一般存放于/database/oracle/product/11.2.0/db_1/network/admin中。
参数文件:登录到SQLPLUS里键入:show parameter spfile;,查看spfile的位置.windos:G:oracleproduct .2.0db_1dbsSPFILEORCL.ORA,linux:/database/oracle/.../dbs/spfile.ora.
#尽可能的多备份控制文件,以免发生数据瘫痪造成的不便;在备份控制文件时,数据库必须为close状态,对一个open状态的数据库控制文件进行拷贝容易造成某个数据块的损坏。
1.通过oracle的sqlplus的内置工具,登录到数据库.linux:sqlplus ‘/as sysdba’,windows:sqlplus “/as sysdba”,键入:select * from v$controfile ;通过sql命令查询控制文件存放的位置,并记住该控制文件的路径。
2.停止当前数据库,shutdown immediate; 不建议应用 shutdown ,一个面向数据访问比较频繁的数据,直接应用shutdown 有可能造成数据库数据丢失或数据错误问题。
3.找到oracle的初始化参数文件,linux: vi/database/orac/.../SPFILEORCL.ORA;wiondows:G:oracleproduct .2.0db_1dbsSPFILEORCL.ORA;编辑参数文件的control_file的新增路径,编辑完成后注意保存。并在控制文件的存放目录copy任意control.ctl,linux:cp -p /../control01.ctl /../control04.ctl.
4.登录到linux或windows的sqlplus工具里,启动oracle数据库;建议使用:stratup.启动完成后,键入select status,name from v$controlfile 后你会发现新增的备份控制文件.
*通过sqlplus 查看控制文件位置
select status,name from v$controlfile ;
*通过sqlplus 查看数据文件位置
select status,name from v$datafile ;
*通过sqlplus 查看日志文件位置
select status,member from v$logfile ;
*.通过sqlplus查看重做日志文件信息
archive log list;
Select * from v$log;
重做日志文件(Redolog file) Oracle 所作的一切操作都记录在日志文件中,Oracle系统在工作当中并不是每作一条记录的修改就立即存盘(写入数据文件),而是只作修改记录,联机重做日志就保存所有这些改变的信息。当所有的修改最后写入数据文件时,所有的修改仍记录在联机重做日志中,这将有利于对这些事务记录进行恢复操作。但如果不是联机重做日志,则只能恢复部分近期的操作。主要存放数据库执行DML(inset,update,delete)语句,顺序写入,写满之后自动切换。只有归档模式才可以恢复数据,非归档模式只能恢复当前数据。
----查看重做日志文件信息
archive log list;
Select * from v$log;
----切换访问体质文件(正常工作中使用不到)
Alter system switch logfiel ;
Select * from v$logfile;
----增加重做日志文件
Linux:alter database add logfile ‘/database/../redolog09.rdo’size 2g autoextend off;
Windows:alter database add logfie
(‘G:oracleproduct.2.0db_1databasearchive edolog09.rdo’)size 2g ;
Alter system switch logfiel ;使新增日志文件生效
Select * from v$logfile;查看日志信息
-----制定工作组增加重做日志文件
Alter database add logfile member ‘/database/../redolog11.rdo’ to group 1 ,’/database/../redolog12.rdo’ to group 2;
Alter system switch logfiel ;
Select * from v$logfile;