ORACLE 管理 日志与空间

日志文件的管理

联机日志文件的工作状态:

select * from v$log;


联机日志文件的物理存储信息

select * from v$logfile;


手工切换日志:

alter system switch logfile;


日志切换频率:

select to_char(first_time,'yyyy-mm-dd hh24') first_time,count(*)

from v$log_history

group by to_char(first_time,'yyyy-mm-dd hh24');


增加日志组(可以加快日志切换效率):为什么?

alter database add logfile group 3

'/u01/app/oracle/oradata/demo/redo03.log' size 50m;


增加成员(提高联机日志的安全性):

alter database add logfile member

'/u01/app/oracle/oradata/demo/redo01a.log' to group 1,

'/u01/app/oracle/oradata/demo/redo02a.log' to group 2,

'/u01/app/oracle/oradata/demo/redo03a.log' to group 3;


清空日志组(可以解决INACTIVE组的成员丢失):

alter database clear logfile group 2;


ACTIVE组成员丢失的解决:

要将ACTIVE状态转变为INACTIVE状态!!要使数据写盘!!

alter system checkpoint; --触发完全检查点


CURRENT组成员丢失的解决:

使用基于cancel的不完全恢复(目的是为了使用resetlogs选项):

recover database using backup controlfile until cancel;

cancel

Media recovery cancelled.


alter database open resetlogs;


日志文件的移动和改名:

1.正常停库

shutdown immediate

2.启动到mount

startup mount

3.使用主机命令移动文件

! mv /u01/app/oracle/oradata/demo/redo01a.log /home/oracle/redo01a.log

4.修改控制文件的指针

alter database rename file '/u01/app/oracle/oradata/demo/redo01a.log' to '/home/oracle/redo01a.log';

5.打开数据库

alter database open;


删除日志成员:

alter database drop logfile member '';

当前组的成员不能删除

每组中的最后一个成员不能删除


删除组:

alter database drop logfile group 4;

当前组不能删除

活动组不能删除

只剩两组,任何一组都不能删除


归档模式:

查看数据库的归档状态:

archive log list

或者:

select log_mode from v$database;


将数据库修改为归档模式:

1.正常停库

shutdown immediate

2.启动到mount

startup mount

3.转换为归档

alter database archivelog;

4.打开数据库

alter database open;


将数据库修改为非归档模式:

1.正常停库

shutdown immediate

2.启动到mount

startup mount

3.转换为非归档

alter database noarchivelog;

4.打开数据库

alter database open;


修改存档终点:

log_archive_dest_n (n=1~10)

mkdir /u01/app/oracle/arclog

alter system set log_archive_dest_1='location=/u01/app/oracle/arclog';


归档模式下如果联机日志不能归档对数据库有什么影响?

mkdir /arc

chmod 777 /arc

alter system set log_archive_dest_1='location=/arc';


备用归档路径:

alter system set LOG_ARCHIVE_DEST_1='location=/arclog_huayd/ MANDATORY alternate=log_archive_dest_2 noreopen';

alter system set LOG_ARCHIVE_DEST_2='location=/arclog2/ optional';

alter system set LOG_ARCHIVE_DEST_STATE_1='enable';

alter system set LOG_ARCHIVE_DEST_STATE_2='alternate';


OPTIONAL:该选项是默认选项.使用该选项时,无论归档是否成功,都可以覆盖重做日志.

MANDATORY:强制归档.使用该选项时,只有在归档成功之后,重做日志才能被覆盖.


查看归档终点是否有效:

select dest_name,destination,status,error

from v$archive_dest

where dest_id in (1,2);


日志挖掘:

挖掘dml语句需要将数据库置为追加日志数据模式:

alter database add SUPPLEMENTAL LOG data;

做交易!挖掘!

conn / as sysdba

生成挖掘队列:

exec dbms_logmnr.add_logfile('/home/oracle/redo01a.log',dbms_logmnr.new);

exec dbms_logmnr.add_logfile('/home/oracle/redo02a.log',dbms_logmnr.addfile);

exec dbms_logmnr.add_logfile('/home/oracle/redo03a.log',dbms_logmnr.addfile);

开始挖掘:

exec dbms_logmnr.start_logmnr(options=>dbms_logmnr.dict_from_online_catalog);

查看挖掘结果:

select sql_redo

from v$logmnr_contents

where lower(sql_redo) like '%update%'

and seg_name='EMP'

and seg_owner='SCOTT';


select sql_undo

from v$logmnr_contents

where lower(sql_redo) like '%update%'

and seg_name='EMP'

and seg_owner='SCOTT';

练习

日志文件中存放的是什么内容?有什么用?


联机日志怎样工作?


怎样查看联机日志的工作状态?


怎样查看联机日志的物理信息?


联机日志何时会发生切换?


怎样手工切换日志?


active状态有何含义?


如何是active状态转变为inactive状态?


如何保证联机日志文件的安全性?


如何修改联机日志文件的大小?


如何移动联机日志文件?


如何修改联机日志文件的名称?


删除组和成员都有什么限制?


清空日志命令有什么作用?


如何做归档模式的转换?有什么注意事项?


如何修改存档终点?


如何挖掘日志中的内容?挖掘dml有什么前提条件?

表空间和数据文件的管理

select tablespace_name,contents from dba_tablespaces order by 2;


永久表空间的管理

创建小文件表空间(1023个文件,每个文件管理4M个oracle块)

create tablespace users datafile '/home/oracle/users01.dbf' size 5m;

create tablespace data01 datafile '/dev/raw/raw1' size 4095m;

查看表空间信息:

select tablespace_name,file_name,bytes/1048576 mb

from dba_data_files;

修改表空间状态:

select tablespace_name,status from dba_tablespaces;

只读状态:只能查询,不能修改,但是可以删除对象!

alter tablespace users read only;

alter tablespace users read write;

离线状态:可以删除对象

alter tablespace users offline;

alter tablespace users online;

表空间改名:

alter tablespace xxx rename to yyy;


不能offline的表空间:

system

default temporary

包含活动事务的undo


创建大文件表空间(只能包含1个文件,文件管理4G个oracle块)

select tablespace_name,bigfile from dba_tablespaces;

create bigfile tablespace test_big datafile '/home/oracle/bigfile01.dbf' size 5m;


数据文件的移动和改名:

1.使用alter tablespace命令

a.表空间要offline

alter tablespace test_big offline;

b.目标文件要存在

! mv /home/oracle/bigfile01.dbf /u01/app/oracle/oradata/demo/bigfile01.dbf

alter tablespace test_big rename datafile '/home/oracle/bigfile01.dbf' to '/u01/app/oracle/oradata/demo/bigfile01.dbf';

alter tablespace test_big online;


2.使用alter database命令

a.数据库要mount

shutdown immediate

startup mount

b.目标文件要存在

! mv /home/oracle/bigfile01.dbf /u01/app/oracle/oradata/demo/bigfile01.dbf

alter database rename file '/home/oracle/bigfile01.dbf' to '/u01/app/oracle/oradata/demo/bigfile01.dbf';

alter database open;


表空间扩容:

select

a.tablespace_name,

a.curr_mb,

round((b.free_mb/a.curr_mb)*100,3)||'%' free_pct,

a.max_mb

from

(select tablespace_name,sum(bytes)/1048576 curr_mb,

sum(maxbytes)/1048576 max_mb

from dba_data_files group by tablespace_name) a,

(select tablespace_name,sum(BYTES)/1048576 free_mb

from dba_free_space group by tablespace_name) b

where a.tablespace_name=b.tablespace_name;


1.使用文件的自动增长属性:

alter database datafile '/u01/beijing/undotbs01.dbf' autoextend on next 10m maxsize 4g;


alter database datafile '/u01/beijing/undotbs01.dbf' autoextend off;


2.增加新文件

alter tablespace users add datafile '/u01/beijing/users02.dbf' size 5m;

oracle 10g,第一个文件和有数据的文件不能删除,

alter tablespace users drop datafile '/u01/beijing/users02.dbf';


3.修改现有文件的大小

alter database datafile '/u01/beijing/users02.dbf' resize 15m;

alter database datafile '/u01/beijing/users02.dbf' resize 10m;


临时表空间的管理:

存放排序的中间结果

存放临时表数据


alter system set pga_aggregate_target=10m;


select USERNAME,TABLESPACE,BLOCKS from v$sort_usage;


select * from database_properties

where rownum<4;


create user u1 identified by u1

default tablespace users --10g

temporary tablespace temp --9i

quota 10m on users

password expire;


create temporary tablespace temp02

tempfile '/u01/app/oracle/oradata/test/temp02.dbf'

size 10m;


select TEMPORARY_TABLESPACE

from dba_users where username='SCOTT';

修改数据库默认排序表空间

alter database default temporary tablespace temp;

修改用户默认排序表空间

ALTER USER SCOTT TEMPORARY TABLESPACE TEMP02;


oracle 10g 临时表空间组:

select * from DBA_TABLESPACE_GROUPS;

将临时表空间加入组

alter tablespace temp tablespace group tempgroup;

将临时表空间移出表空间组

alter tablespace temp02 tablespace group '';


删除临时表空间的文件:

alter database tempfile

'/u01/app/oracle/oradata/test/temp02.dbf' drop;


alter tablespace temp02 add tempfile '/home/oracle/temp02.dbf' size 20m;


回退表空间的管理:

创建undo表空间

create undo tablespace undo02 datafile

'/u01/app/oracle/oradata/test/undo02.dbf' size 4m;


回退表空间的作用:undo tablespace --> rollback segment --> 数据修改前的老镜像

1.为事务提供回退数据(rollback)

2.为事务提供恢复

3.提供读一致性


自动管理:只能使用一个undo表空间

相关参数

show parameter undo

undo_management = AUTO

undo_tablespace = UNDOTBS1


undo tablespace --> rollback segment

回滚段:

系统回滚段(系统创建)

为系统表空间的对象提供回退

非系统回滚段(用户创建)

为用户表空间的对象提供回退

延迟回滚段(系统创建)

表空间非正常离线时自动创建


select segment_name,tablespace_name,status

from dba_rollback_segs;


要保证UNDOTBS1表空间有足够的空间可用!


切换回滚表空间:

alter system set undo_tablespace = undo02;

跟踪回滚段使用情况:

select SES_ADDR,USED_UBLK from v$transaction;

select sid,serial#,username,machine

from v$session where saddr=SES_ADDR;


(v$transaction.SES_ADDR=v$session.saddr)


手工管理:

相关参数

show parameter undo_management


alter system set undo_management=manual scope=spfile;


show parameter rollback

transactions_per_rollback_segment=5


手工创建回滚段:

create rollback segment rbs1 tablespace undotbs1;

create rollback segment rbs2 tablespace undotbs1;

手工使回滚段online:

alter rollback segment rbs1 online;

使回滚段在数据库启动时自动online:

alter system set rollback_segments=rbs1,rbs2 scope=spfile;


回退保持力(oracle 9i):

事务内的老的镜像块commit后在回滚段还会保留15分钟

undo_retention=900


conn scott/tiger

update scott.emp set sal=100;

commit;


conn system/oracle

exec dbms_flashback.ENABLE_AT_TIME(sysdate-15/1440);

select empno,sal from scott.emp;

exec dbms_flashback.disable;


declare

cursor c is select empno,sal from scott.emp;

r c%rowtype;

begin

dbms_flashback.ENABLE_AT_TIME(sysdate-15/1440);

open c;

dbms_flashback.disable;

loop

fetch c into r;

exit when c%notfound;

update scott.emp set sal=r.sal where empno=r.empno;

end loop;

close c;

commit;

end;

/

练习

表空间的作用?


数据文件的作用?


按照存储的内容分类,表空间分为几种类型?


怎样创建不同类型的表空间?


表空间有几种状态?如何查看?如何修改?不同状态对数据操作有何影响?


是不是所有的表空间都可以offline ?


大文件表空间有什么特点?


数据文件有几种状态?如何修改?


临时表空间保存何种数据?有什么作用?


undo表空间保存何种数据?有什么作用?


如何查看表空间的空间使用率?


表空间扩容有几种手段?


如何移动数据文件?有几种办法?

移动数据库

select name from

(select name from v$controlfile

union

select name from v$datafile

union

select name from v$tempfile

union

select member from v$logfile);


将所有的数据库文件都移动到:/u01/beijing

正常停库

shutdown immediate

修改参数

control_files='/u01/beijing/control01.ctl'

移动所有数据文件到/u01/beijing/

cd /u01/app/oracle/oradata/demo

mv *.dbf /u01/beijing/

启动数据库到nomount

startup nomount

创建控制文件的同时修改文件指针

CREATE CONTROLFILE REUSE DATABASE "BEIJING" RESETLOGS ARCHIVELOG

MAXLOGFILES 16

MAXLOGMEMBERS 3

MAXDATAFILES 100

MAXINSTANCES 8

MAXLOGHISTORY 292

LOGFILE

GROUP 1 '/u01/beijing/redo01.log' SIZE 50M,

GROUP 2 '/u01/beijing/redo02.log' SIZE 50M,

GROUP 3 '/u01/beijing/redo03.log' SIZE 50M

DATAFILE

'/u01/beijing/system01.dbf',

'/u01/beijing/undotbs01.dbf',

'/u01/beijing/sysaux01.dbf',

'/u01/beijing/users01.dbf',

'/u01/beijing/bigfile01.dbf'

CHARACTER SET WE8ISO8859P1

;


打开数据库:

alter database open resetlogs;


添加临时文件:

alter tablespace temp add tempfile '/u01/beijing/temp01.dbf' reuse;


--生成批量修改控制文件指针的脚本

select 'alter database rename file '||chr(39)||name||chr(39)||' to '||chr(39)||'/u01/app/oracle/oradata/bobo/'||substr(name,instr(name,'/',-1,1)+1)||chr(39)||';'

from

(select name from v$datafile

union all

select name from v$tempfile

union all

select member from v$logfile)

/

练习

将你的数据库的核心文件全部移动到 /oradb/


你可能感兴趣的:(oracle,日志,表空间)