|
last edited 9 months ago by yangjing |
2004.02.11 不要忘记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模式