不要忘记mtime,atime,以及ctime. 
unix系统为每个文件都记录这三个不同的时间,第一个是mtime,即修改时间。无论何时, 
只要文件内容被改变,mtime的值就会被相应修改。第二个是atime,即访问时间。只要文 
件被访问(比如运行或读取),它就会被修改。第三个是ctime,即变更时间。当文件的属性 
发生变化(比如改变权限或者所有关系)时,ctime的值就会被改变。管理员用ctime来查 
找黑客。 
备份会改变atime,tar,cpio,dd都会这样做,dump通过原始设备来读取文件系统,因此它不 
会改变atime. 

dump的语法。 
dump levelunbdsf blkg-factor density size device-name file_system 
例子: 
把/home完全备份到一个称做/dev/rmt/0cbn的本地磁带驱动器上。 
# dump 0unbdsf 126 141000 11500 /dev/rmt/0cbn /home 
把/home完全备份到一个称做/backup/home.dump的光学CD驱动器上。 
# dump 0unbdsf 126 141000 11500 /backup/home.dump /home 
以上命令由三个不需要参数的选项(0,u and n)以及四个需要一个协作参数的选项(b,d,s and  
f)组成。 
命令选项: 
0---9     指定DUMP应该进行的备份级别。 
b         指定DUMP就应该使用的块因子。 
u         指定DUMP更新dumpdates文件。 
n         完成操作时要通知操作员组的成员。 
d(密度) and s(大小)   告诉DUMP备份卷有多大,DUMP用这些数字来估计要使用 
何种磁带。 
f         告诉DUMP要使用什么设备。 
W,w       告诉DUMP执行一次空运行来告诉你什么文件系统需要备份。 

要避免跨卷DUMP。 

restore的语法 
restore [trxi]vbsfy blocking-factor file-number device-name 
例子: 
要恢复一个使用块因子32创建的DUMP磁带备份(位于/dev/rmt/0cbn)的全部内容。 
# restore rvbfy 32 /dev/rmt/0cbn 
有一个使用块因子32创建的位于/dev/rmt/0cbn中的DUMP磁带,如果想从该磁带中恢复文 
件/etc/hosts and /etc/passwd. 
# restore xvbfy 32 /dev/rmt/0cbn ./etc/hosts ./etc/passwd 
创建内容表 
# restore tfy device >;/tmp/dump.list 
命令选项: 
决定restore的类型 
t       显示卷的内容。 
r       指明卷的整个内容应该被恢复到当前工作目录下。 
x 只提取命令后面所列的文件。 
i 允许执行交互式恢复。 
决定restore的行为 
v 指定详细输出 
s 读取之前跳过的磁带文件个数 
b 块因子 
f 备份驱动器的文件名。 
y 恢复过程禁止询问。 



使用cpio工具进行备份和恢复 
备份的语法 
cpio -o[aBcv] 
恢复的语法 
cpio -i[Btv][patterns] 
例子: 
在一个本地磁带上创建/home的一个完全备份。 
# cd /home 
# touch level.0.cpio.timestamp     使增量备份成为可能。建立时间参考点。 
# find . -print|cpio -oacvB >; device   device可以是一个光学或CD设备。 
# touch level.1.cpio.timestamp     增量备份的时间参考点。 
# find . newer level.1.cpio.timestamp -print|cpio -oacvB >;device 
在远程磁带上创建/home的一个完全备份。 
# cd /home 
# find . -print|cpio -oavB|(rsh remote_system dd of=device bs=5120) 

cpio备份用绝对路径(find  /home/file)会限制恢复时的灵活性。它只能恢复到/home/file。 
如果用相对路径(find home/file)就能把它恢复到任何地方。 
命令选项 
备份类 
o 创建一个备份 
a 把atime重置成备份前的值 
c 用ASCII首部格式 
v 用于详细信息输出 
B,C    指定块大小,它们是互斥的。 
恢复类 
i 指定输入模式,必须是命令列表的第一个。 
t 生成内容表,并不实际操作。 
k 跳过坏区 
d 在需要时创建目录 
m 恢复文件备份时的原始修改时间,否则的话,默认动作是把恢复后的文件的修改时间设 
为新修改时间 
u 无条件覆盖所有文件 
"*pattern"  恢复匹配该模式的文件 
f "*pattern" 恢复不匹配该模式的文件 
r 交互式重命名文件名 

2004/02/12 
tar命令的基本语法 
# tar -[cx]vf device pattern 

命令选项 
c 创建一个存档 
v 详细信息输出 
W 对存档文件进行校验 
b 块因子 
f 输出到DEVICE参数所指的设备,DEVICE可以是文件,光盘,磁带或者标准输出 
(stdout) 
pattern 模式匹配如“a*” 
x 恢复一个存档 
m 正常情况下,恢复后的文件会保留它们在存档前的修改时间,选用该选项把修改时间改 
成恢复时间,这与CPIO命令的行为完全相反。 
o 把恢复的文件的所有者设置成你。这是对于非root用户的默认行为,除非使用该选项, 
否则,root提取的文件都会归保存在tar文档中的用户和组所有。 
p 默认情况下,tar不会恢复所有的文件属性。文件的许可是由当前umask决定,而不是 
由原始文件的许可决定,包括setuid and sticky位。这个选项告诉tar用原始文件的许可。 
d 能够对存档和文件系统进行一个diff比较。 
a 重设置访问时间 
F 在卷结束时运行一个脚本,这可用于进行自动卷交换。 
Z z     自动调用compress and gzip程序 

dd命令基本语法 
# dd if=device of=device bs=blocksize 
if= 指定输入文件,即dd从中拷贝数据的文件。它可以是需要备份的文件或者原始分区, 
如果从stdin中读取数据,那么该参数不必指定。 
of= 指定输出文件,即dd发送数据的目的地。它可以是需要备份的文件或者原始分区,如 
果从stdout中读取数据,那么该参数不必指定。 
bs 指定块大小,即一次i/o操作中传输的数据量。 

使用dd和rsh and ssh进行远程备份(GNU tar and GNU cpio命令能读取远程设备) 
读取远程设备上的备份 
# rsh remote_host "dd if=device ibs=blocksize" |tar xvBf - 
# ssh remote_host "dd if=device bs=blocksize" |tar xvBf - 
# ssh remote_host "dd if=device bs=blocksize" |restore rvf - 
# ssh remote_host "dd if=device bs=blocksize" |cpio -itv 

把备份写到远程设备上 
# tar -cvf - . |(rsh remote_system dd of=device obs=block_size) 
# dump 0bdsf 64 100000 100000 - |ssh remote_host "dd if=device bs=64k" 
# tar -cvf - |ssh remote_host "dd if=device bs=10k" 
# cpio -oacvB |ssh remote_host "dd if=device bs=5k" 


LINUX裸机恢复方法: 
1、备份重要的元数据    # fdisk -l >;/etc/fdisk-l.txt 
2、用本地工具备份系统  # cd / ; tar cf - . |gzip -c >;/backup/xxx.tar.gz 
3、系统损坏,用其它介质引导系统(引导盘,KNOPPIX等)。 
4、用元数据对硬盘这行分区并格式化。   
解出元数据文件 #gzip -dc /xxx/xxx.tar.gz|tar -xvf - ./etc/fstab ./etc/fdisk-l.txt  
分区  # fdisk /dev/sda 
创建文件系统 # mke2fs /dev/sda1 
5、恢复操作系统信息 # gzip -dc /xxx/xxx.tar.gz|tar xf - 
6、在新根磁盘上恢复引导块  


ORACLE(离线)冷备份 
1、关闭数据库,中止所有允许访问数据库的进程。 
2、通过备份工具对文件进行备份(TAR,DD,CPIO) 



ORACLE(在线)热备必要步骤 
1、请求ORACLE的所有表空间及数据文件的列表。 
2、请求存储ORACLE归档日志的位置。 
3、请求存储ORACLE控制文件的位置(可选)。 
4、将所有表空间置于备份模式,可且用ALTER TABLESPACE tablespace_name BEGIN  
BACKUP命令。 
5、将每个表空间的数据文件复制到磁盘或磁带上。 
6、去除各个表空间的备份模式,可使用ALTER TABLESPACE tablespace_name END  
BACKUP命令。 
7、切换重做日志文件。 
8、备份控制文件,可使用BACKUP CONTROL file命令。 
9、手工复制控制文件(可选)。 
10、手工复制在线重做日志。 
11、确保所有在备份期间的归档重做日志均保存完好。 

说明: 
在表空间被置于备份模式时,会有以下事件发生: 
1、ORACLE检查点表空间,将所有改变从内存存储到磁盘上。 
2、表空间中各个数据文件的SCN标识都“冻结”在当前值,即使对数据文件进一步更新, 
SCN值都不会被更新,直到去除备份模式。 
3、ORACLE从记录完整的更改数据库块的映像转向记录重做日志。不再记录某特定的块是 
怎样改变的,而是记录整个改变后块的映像。这就是重做日志在热备份过程中迅速增长的原 
因。 

自动备份的ORABACK.SH脚本支持特性: 
1、备份磁盘或磁带。 
2、自动检测数据库配置。 
3、基于文件系统或原始分区备份数据库。 
4、多任务,可以将备份时间减少到75%。 
5、使用邮件发送成功或错误通知。 
6、备份ORATAB中的一个或多个实例。 

使用方法介绍 
1、备份所有实例; 
# ORABACK.SH 
2、备份一个或更多实例,要带上参数ORACLE_SID; 
# ORABACK.SH ORACLE_SID1 ORACLE_SIDn 
3、如果要在ORABACK.CONF中指定的某一时刻调度备份,则带上at: 
# ORABACK.SH at ORACLE_SID1 ORACLE_SIDn 
安装ORABACK.SH,首先将ORABACK.SH、CONFIG.GUESS以及LOCALPATH.SH放在一 
个目录下,然后核对脚本头部特定位置的下列值。 
BINDIR 安装ORABACK.SH的目录。 
ORATAB 设为ORACLE的ORATAB文件的名称和位置。 
ORACONF 设为ORABACK.CONF文件的名称和位置。 

ORABACK.CONF配置 
1、HOSTNAME.MASTER 系统主机名,去掉域名(如AAA.DOMAIN.COM 变成AAA) 
2、SKIP 如果今天晚上跳过该主机上的所有备份,可以在这里输入“SKIP” 
3、COLD DAY 进行冷备份的日期,可以是每周的某一天(FRI,即星期五),或每月 
的某一天(03,即第三天)。 
4、COLD TIME 进行冷备份的时间,采用24小时制。 
5、HOT TIME 一天中进行热备份的时间,采用24小时制。 
6、TYPE DEVICE 非回绕磁带设备,备份到磁带。(如只允许磁盘备份,则保持空白)。 
7、USERS 充许运行脚本的用户名列表,以|隔开,如ORACLE|DBA,空白表示仅允许 
ORACLE用户运行。 
8、PARALLELISM 同时运行数据文件拷贝数,空缺 = 1. 
9、BACKUP DIR 备份目录。 
10、Y 表示在写入磁盘前先对文件进行压缩。 
11、MAIL DS 邮件ID列表,用来发关备份成功与否的通知,之间用“,”号分开。 

进行完全逻辑备份时需要RESTRICT模式。关闭数据库,然后用STARTUP RESTRICT OPEN 
打开数据库,再进行完全导出。导出完成后用ALTER DATABASE DISABLE RESTRICTED  
SESSION恢复连接。 

集萃 

镜像重做日志 一个ACTIVE或CURRENT日志组的所有成员均丢失,会造成数据丢失。 
镜像重做日志,所有日志组成员均丢失的可能性就极小。 
观察告警日志 镜像控制文件   使用ARCHIVELOG模式