基于Linux的oracle数据库管理 part6 (backup 相关的脚本)
这里只是简单的介绍几种 备份方法
备份: 逻辑备份, 冷备份, 热备份
逻辑备份 也称作 导入(import), 导出(export), 作用是在不同的oracle数据库之间转移数据
物理备份, 就是操作系统级别的文件复制
rman 备份, 是oracle的主要备份方式, rman备份原理与物理备份基本类似, 但是功能更加强大, 主要特点如下:
1) 命令行方式
2) 只备份数据文件中的非空数据块, 而不是备份整个数据文件, 显然这样大大节省了存储空间及备份时间
3) 可以进行增量备份, 即只备份上次备份操作以来发生改变的数据块
4) 可以设置自动备份控制文件及spfile
冷备份: 数据库正常关闭状态下的全库备份, 因为事务时正常结束的, 所以, 冷备份可以用来直接恢复数据库, 而不必应用重做日志.
热备份: 是在数据库打开的状态备份的, 备份文件的数据相互不一致, 所以, 在做热备时, 必须应用归档重做日志或联机重做日志恢复数据库到一致状态.
完全恢复: 借用 重做日志与归档日志 将数据库恢复到一致状态.
不完全恢复: 由于归档日志或者联机日志文件丢失, 另一种情况是, 用户执行了错误操作, 需要恢复到数据库以前状态, 类似 flashback
还原(restore): 把备份文件复制回原来目录的过程
恢复(recover): 还原后, 对备份文件应用归档重做日志或联机重做日志, 使其数据达到最新状态的过程.
全库冷备 shell
#! /bin/bash backup_dir=/oracle/back
log_file = $ORACLE_BASE/admin/$ORACLE_SID/cold_backup_$ORACLE_SID.log
echo "Begin cold backup" > $log_file
date >> $log_file sqlplus -s /as sysdba << EOF > $log_file
set pagesize 0
set linesize 1000
spool file_copy_$ORACLE_SID.sh
select `cp` || name || `$backup_dir/` from v\$controlfile;
select `cp` || filename || `$backup_dir/` from dba_data_files;
select `cp` || member || `$backup_dir/` from v\$logfile;
spool off # prepare finish, now start shutdown db and move the file
shutdown immediate
!bash file_copy_$ORACLE_SID.sh
startup;
exit;
eof # 清理战场
rm -f file_copy_$ORACLE_SID.sh if [ -e $ORACLE_HOME/dbs/init$ORACLE_SID.ora ]
then
cp $ORACLE_HOME/dbs/init$ORACLE_SID.ora $backup_dir /
fi if [ -e $ORACLE_HOME/dbs/spfile$ORACLE_SID.ora ]
then
# cp $ORACLE_HOME/dbs/spfile$ORACLE_SID.ora $backup_dir/
fi if [ -e $ORACLE_HOME/dbs/orapw$ORACLE_SID ]
then
# cp $ORACLE_HOME/dbs/prapw$ORACLE_SID $backup_dir/
fi echo "Cold backup finished." >> $log_file
date >> $log_file
全库热备 shell
物理热备, 只能一次备份一个表空间, 而且要预先将要备份的表空间置于备份状态, 热备完成后, 要结束备份状态. 使用热备恢复肯定要用到归档日志, 所以, 如果要使用热备, 数据库必须使用归档模式
alter tablespace tablespace_name begin backup
alter tablesapce tablespace_name end backup
#! /bin/bash backup_dir = /oracle/backup
log_file = $ORACLE_BASE/admin/$ORACLE_SID/hot_bakcup_$ORACLE_SID.log
echo "Begin hot backup..." > $log_file
date >> $log_file sqlplus -s /as sysdba << EOF >> $log_file
alter database backup controlfile to `/$backup_dir/backup_controlfile.ctl`;
set pagesize 0
set linesize 1000
set feedback off
column tablespace_name noprin
column sortorder noprin
column textout format a120 spool hot_backup_$ORACLE_SID.sql select tablespace_name, '1' sortorder, 'alter tablespace' || tablespace_name || 'begin backup;' textout
from dba_data_files
union
select tablespace_name, '2' sortorder, 'host cp' || file_name || ' ' || '$backup_dir' textout
from dba_data_files
union
select tablespace_name, '3' sortorder, 'alter tablespace' || tablespace_name || 'end backup;' textout
from dba_data_files
order by tablespace_name, sortorder, textout; select 'alter system archivelog current;' from dual;
spool off @hot_backup_$ORACLE_SID.sql
exit
EOF rm -f hot_backup_$ORACLE_SID.sql
echo "Hot bakcup finished." >> $log_file
RMAN 备份 shell 程序
在进行 rman 备份之前要先进行数据库归档设置, 并配置 rman 备份文件所在的目录以及自动备份控制文件及 spfile.
使用 rman 备份数据库, 根据备份信息保存的位置(注意, 不是备份集, 而是备份集的信息(元数据), 可以分为两种方式: 一是使用备份数据库(这个要备份的数据库成为目标target数据库)的控制文件保存备份集信息, 二是使用另外一个数据库保存备份集信息, 这个数据库一般成为目录(catalog)数据库), 很明显, 第二种方式更安全, 但要先配置 catalog 数据库. 第一种方式, 除了rman之外, 不需要进行任何配置.
下边采用的是第1种方式, 因为主要是要介绍 rman的shell程序
首先, 确认是否为归档模式:
sqlplus /nolog, conn /as sysdba
archive log list;
--------------------------------------------------------------------------------
如果是非归档模式, alter system set log_archive_dest_1 = ‘location=/oracle/arch’;
然后重启数据库至 mount 状态, 设置运行归档模式:
startup mount
alter database archivelog;
alter database open;
archive log list; -- 确认是否修改成功
--------------------------------------------------------------------------------
配置 rman
默认情况下, rman 生成的备份文件会创建到数据库的 flash_recovery_area 参数所指定的路径下, 下面先来配置 flash_recovery_area 大小及路径, 如下:
sqlplus /nolog , conn /as sysdba
alter system set db_recovery_file_dest_size=2G;
alter system set db_recovery_file_dest=’/oracle/flash_recovery_area’;
然后, 可以启动 rman, 并以 sys用户连接到数据库, 备份数据文件 4:
rman target /
backup datafile 4;
然后, 在我们刚才设置的目录里, 你就会看到备份的文件.
设置, 每次rman备份时, 都会备份control file 和 spfile:
connect target /
configure controlfile autobackup on
# !/bin/bash if [ $1 ]
then
backup_level = $1
else
backup_level = 0
fi backup_user = sys
backup_user_pw = oracle # caltalog_user = rman
# catalog_user_pw = rman log_file=/oracle/admin/$ORACLE_SID/rman_backup.log echo "Begin rman backup ..." > $log_file
date >> $log_file rman target $backup_user/$backup_user_pw << EOF > $log_file
# catlog $catlog_user/$catlog_user_pw@rman bakcup incremental level = $backup_level database;
quit;
EOF
echo "rman backup finished." >> $log_file
date >> $log_file
逻辑备份 shell
# !/bin/bash log_file = /oracle/admin/$ORACLE_SID/full_exp_$ORACLE_SID.log
exp_arguments="userid=system/oracle buffer = 10485760 owner = $1" if [ $2 ]
then
exp_arguments = "$exp_arguments file = $2"
else
exp_arguments = "$exp_arguments file = "$ORACLE_SID"_full_export.dmp"
fi echo "Begin full db export ..." > $log_file
echo "Exporting with folling arguments : $exp_arguments" >> $log_file
exp $exp_arguments >> $log_file 2>&1
echo "Export finished." >> $log_file
date >> $log_file exp_result = $?
if [ exp_result != 0 ]
then
mail -s "Errors in xeporting $ORACLE_SID." asdf@126.com < $log_file
fi
基于Linux的oracle数据库管理 part6 (backup 相关的脚本)的更多相关文章
- 基于Linux的oracle数据库管理 part1( 准备及linux基础 )
主要内容 1. 安装VMware tools (好处, 显示效果增强, 从虚拟机出来不需要alt+ctrl 切换) 2. Linux 启动过程, 方便以后oracle 自动启动与关闭 3. Linux ...
- 基于Linux的oracle数据库管理 part2( 数据库 准备,安装,创建 )
主要内容 1. 准备 2. 安装 与 删除 软件 3. 创建数据库 4. 配置 SQL*PLUS 环境 准备 1. 软件包, rpm –qa , rpm –ivh *.rpm 2. 检查磁盘空间 3. ...
- 基于Linux的oracle数据库管理 part5( linux启动关闭 自动启动关闭 oracle )
主要内容 1. 数据库自动启动与关闭 数据库自动启动与关闭 - 单数据库模式 启动监听器及数据库 启动脚本: #! /bin/bash su - oracle<<EOF lsnrctl s ...
- 基于Linux的oracle数据库管理 part3( 存储 网络 常用命令 )
主要内容 1. 常用存储模式 2. 配置网络 3. 维护指令 常用存储模式 - 文件系统 优点:管理方便, 缺点:读写慢 - 裸设备 只没有被格式化和挂载的磁盘, 只能有程序直接访问, 不能被操作系统 ...
- 基于Linux的oracle数据库管理 part4( shell管理 上 )
主要内容 1. shell 基础补充 2. shell脚本与 SQL*PLUS shell 基础补充 - $(()) 中内容被看做是算术表达式, 其中的变量有没有”$”都可以, 例如 result = ...
- 基于Linux下catalog方式的 Oracle 备份策略(RMAN)
--********************************** -- 基于Linux下 Oracle 备份策略(RMAN) --******************************* ...
- Linux环境Oracle相关操作命令行
打开Oracle监听:lsnrctl start 关闭监听: lsnrctl stop 监听关闭那么客户端无法连接 进入sqlplus:sqlplus /nolog 使 ...
- Linux 下 Oracle 内核参数优化
数据库的性能优化涉及到整个数据库运行环境的方方面面,诸如操作系统,Oracle自身,存储,网络等等几个大块.而操作系统则是Oracle稳定运行与最大化性能的基石.本文主要描述基于Linux系统下 Or ...
- Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part2:clusterware安装和升级
Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part2:clusterware安装和升级 环境:OEL 5.7 + Oracle 10.2.0.5 RAC 3.安装Clus ...
随机推荐
- Mysql 如何做双机热备和负载均衡
MySQL数据库没有增量备份的机制,但它提供了一种主从备份的机制,就是把主数据库的所有的数据同时写到备份数据库中.实现MySQL数据库的热备份. 下面是具体的主从热备份的步骤:假设主服务器A(mast ...
- PHP正则表达式的使用
1. 正则表达式的主要作用是:分割.匹配.查找.替换2. 正则表达式中包括的元素:原子(普通字符:a-z A-Z 0-9 .原子表.转义字符),元字符(有特殊功能的字符),模式修正符(系统内置部分字符 ...
- 10、会话管理/编程实战分析/Jsp
1 会话管理回顾 会话管理 1)会话管理: 管理浏览器和服务器之间的会话过程中产生的会话数据 2)Cookie技术: 会话数据保存在浏览器客户端. Cookie核心的API: 2.1 在服务器端创建C ...
- stl map底层之红黑树插入步骤详解与代码实现
转载注明出处:http://blog.csdn.net/mxway/article/details/29216199 本篇文章并没有详细的讲解红黑树各方面的知识,只是以图形的方式对红黑树插入节点需要进 ...
- php之属性重载和方法重载
<?php /** * * @authors Your Name (you@example.org) * @date 2016-06-13 20:40:19 * @version $Id$ */ ...
- Oracle连接字符串C#
Password=密码;User ID=ID;Data Source=(DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = ...
- Linux内存模型
http://blog.csdn.net/sunyubo458/article/details/6090946 了解linux的内存模型,或许不能让你大幅度提高编程能力,但是作为一个基本知识点应该熟悉 ...
- ubuntu下查看cpu信息
查看CPU信息cat /proc/cpuinfo 几个cpu more /proc/cpuinfo |grep "physical id"|uniq|wc -l 每个cpu是几核( ...
- 用re-sign.jar重签名apk后安装失败的解决办法
问题 打开re-sign.jar,将下载好的apk拖入re-sign.jar的界面进行重签名.重签名成功后,通过adb intall命令安装重签名后的apk文件失败.提示:Failure [INSTA ...
- ACM-ICPC国际大学生程序设计竞赛北京赛区(2016)网络赛 The Book List
描述 The history of Peking University Library is as long as the history of Peking University. It was b ...