exp中是不可能实现自动文件名的
我想到的可能实现方法:
编制程序使用exp自动备份
1。利用exp参数文件
在参数文件中加上file=filename
执行导出前修改filename为所需要的文件名
执行外部命令exp执行导出
(适用于必须手工选择大量表的情况)
2。直接在exp后加参数,参数动态生成
执行exp执行导出
(适用于导出参数少的情况)
利用系统的执行计划
做n个参数文件(对应于星期数)
在执行计划中填加n个计划对应于每一个参数文件
其它
不知道Oracle本身是否提供类似于计划任务的执行方式可以执行外部程序,没有试过
我想到的可能实现方法:
编制程序使用exp自动备份
1。利用exp参数文件
在参数文件中加上file=filename
执行导出前修改filename为所需要的文件名
执行外部命令exp执行导出
(适用于必须手工选择大量表的情况)
2。直接在exp后加参数,参数动态生成
执行exp执行导出
(适用于导出参数少的情况)
利用系统的执行计划
做n个参数文件(对应于星期数)
在执行计划中填加n个计划对应于每一个参数文件
其它
不知道Oracle本身是否提供类似于计划任务的执行方式可以执行外部程序,没有试过
例如:
C:\>echo %DATE%
星期二 2002-10-22C:\>echo %date:~4,10%
2002-10-22C:\>echo %date:~0,3%
星期二C:\>echo %date:~-10%
2002-10-22
你可以在控制面板里设置日期格式E:\>exp system/manager file=www%date:~4,10%.dmpExport: Release 8.1.6.0.0 - Production on 星期二 10月 22 11:34:26 2002(c) Copyright 1999 Oracle Corporation. All rights reserved.
连接到: Oracle8i Enterprise Edition Release 8.1.6.0.0 - Production
ith the Partitioning option
Server Release 8.1.6.0.0 - Production
已导出ZHS16GBK字符集和ZHS16GBK NCHAR 字符集即将导出指定的用户...
正在导出 pre-schema 过程对象和操作
正在导出用户SYSTEM的外部函数程序库名称
正在导出用户SYSTEM的对象类型定义
即将导出SYSTEM的对象 ...
正在导出数据库链接
正在导出序号
正在导出群集定义
即将导出SYSTEM的表通过常规路径 ...
. 正在导出表 DEF$_AQCALL 0 行被导出
. 正在导出表 DEF$_AQERROR 0 行被导出
. 正在导出表 DEF$_CALLDEST 0 行被导出
. 正在导出表 DEF$_DEFAULTDEST 0 行被导出
. 正在导出表 DEF$_DESTINATION 0 行被导出
. 正在导出表 DEF$_ERROR 0 行被导出
. 正在导出表 DEF$_LOB 0 行被导出
. 正在导出表 DEF$_ORIGIN 0 行被导出
. 正在导出表 DEF$_PROPAGATOR 0 行被导出
. 正在导出表 DEF$_PUSHED_TRANSACTIONS 0 行被导出
. 正在导出表 DEF$_TEMP$LOB 0 行被导出
. 正在导出表 SQLPLUS_PRODUCT_PROFILE 0 行被导出
正在导出同义词
正在导出视图
正在导出存储的过程
正在导出运算符
正在导出引用完整性约束条件
正在导出触发器
正在导出索引类型
正在导出位图、功能性索引和可扩展索引
正在导出后期表活动
正在导出快照
正在导出快照日志
正在导出作业队列
正在导出刷新组和子组
正在导出维
正在导出 post-schema 过程对象和操作
正在导出统计
在没有警告的情况下成功终止导出。E:\>dir *dmp
驱动器 E 中的卷没有标签。
卷的序列号是 7067-61B8E:\ 的目录2002-10-22 11:34 28,672 www2002-10-22.dmp
2002-08-28 00:38 4,096 EXPDAT.DMP
2 个文件 32,768 字节
0 个目录 9,075,531,776 可用字节E:\>
好方法嘛,不过写个程序来实现也挺好的。
ORACLE数据库备份实用方案
根据实际需要决定数据库的运行方式
ORACLE数据库有两种运行方式:一是归档方式(ARCHIVELOG),归档方式的目的是当数据库发生故障时最大限度恢复所有已提交的事物;二是不归档方式(NOARCHIVELOG),恢复数据库到最近的回收点。我们根据数据库的高可用性和用户可承受丢失的工作量的多少,把我们正式运行的数据库采用为归档方式;那些正在开发和调试的数据库采用不归档方式。
如何改变数据库的运行方式
---- 3.1在创建数据库时设置数据库的运行的方式
---- 在创建数据库时,作为创建数据库的一部分,就决定了数据库初始的存档方式。一般情况下为NOARCHIVELOG方式。当数据库创建好以后,根据我们的需要把需要运行在归档方式的数据库改成ARCHIVELOG方式。
改变不归档方式为为归档方式
关闭数据库,备份已有的数据
改变数据库的运行方式是对数据库的重要改动,所以要对数据库做备份,对可能出现的问题作出保护。
启动Instance ,Mount数据库但不打开数据库,来改变归档方式
sqldba lmode=y(svrmgrl)
sqldba>connect internal
sqldba>startup mount
sqldba>alter database archivelog; 使能自动存档
在初始化文件init*.ora(一般放ORACLE根目录的下层目录dbs下)加参数:
log_archive_start=true 指定存档的重做登录文件名和存放的位置
同样是在初始化文件init*.ora中加入下面的参数:
log_archive_format=%S.arc
log_archive_dest=/arch12/arch (arch12 是日志文件存放的目录) 关闭数据库,重新启动数据库,归档方式转换完成。
回收制度
根据数据库的运行方式和可承受丢失的工作量来决定数据库的回收制度对于不归档方式,我们用的是ORACLE数据库的逻辑备份Export ,回收的制度是:一个月作一次全备份(x01.dmp),一周作一次累积备份(c*.dmp),一天一次增量备份(I*.dmp),具体的是星期一到星期五作增量备份,星期六做累积备份或全备份,每次做完备份后自动传到其它的机器上存储。这些备份都是自动执行的,后面给出程序文本。
---- 对于归档方式,我们用的是ORCALE的物理备份:当数据库创建好以后,做一次物理上的全备份,平时在不关闭数据库的前提下,一个星期对经常改变的数据文件做联机的数据库数据文件的物理备份;当数据库的结构发生改变,如:增加表空间,加数据文件等,如允许关机,正常关闭数据库,重新做数据库全备份,否则,备份控制文件,备份数据文件照常。联机的日志文件我们是写在阵列上的,不用镜象和备份。
回收的方法
不归档方式
---- 我们拿曙光AIX操作系统为例,来讲解以下如何做自动备份:
---- a.首先建UNIX用户 demo/demo
---- b.拷贝oracle用户下的 .profile 到 demo 用户下,以保证 demo 用户可以用 Export命令
---- c.用root用户登录,编辑 /var/adm/cron/cron.allow 加入用户名demo,这样demo用户就有权自动执行数据库备份的shell程序;
---- d.创建数据库备份程序,放到本用户的下层目录bin下,并且这些文件要有可 执行权文件zlbf1增量备份1,星期一执行的程序)
. /u11/demo/.profile
exp system/manager inctype=INCREMENTAL file=i01.dmp
ftp -n< < !
open 10.10.10.40
user demo demo
binary
prompt
cd backup40
put i01.dmp
close
bye
!
文件zlbf2增量备份2, 星期二执行的程序)
. /u11/demo/.profile
exp system/manager inctype=INCREMENTAL file=i02.dmp
ftp -n< < !
open 10.10.10.40
user demo demo
binary
prompt
cd backup40
put i02.dmp
close
bye
!
文件zlbf3增量备份3, 星期三执行的程序)
. /u11/demo/.profile
exp system/manager inctype=INCREMENTAL file=i03.dmp
ftp -n< < !
open 10.10.10.40
user demo demo
binary
prompt
cd backup40
put i03.dmp
close
bye
!
文件zlbf4增量备份4, 星期四执行的程序)
. /u11/demo/.profile
exp system/manager inctype=INCREMENTAL file=i04.dmp
ftp -n< < !
open 10.10.10.40
user demo demo
binary
prompt
cd backup40
put i04.dmp
close
bye
!
文件zlbf5增量备份5, 星期五执行的程序)
. /u11/demo/.profile
exp system/manager inctype=INCREMENTAL file=i05.dmp
ftp -n< < !
open 10.10.10.40
user demo demo
binary
prompt
cd backup40
put i05.dmp
close
bye
!
文件zlbf6增量备份6, 星期六执行的程序)
. /u11/demo/.profile
js=`ls c*.dmp|wc -l`
if test $js = 0
then
exp system/manager inctype=CUMULATIVE file=c01.dmp
ftp -n< < !
open 10.10.10.40
user demo demo
binary
prompt
cd backup40
put c01.dmp
close
bye
!
fi
if test $js = 1
then
exp system/manger inctype=CUMULATIVE file=c02.dmp
ftp -n< < !
open 10.10.10.40
user demo demo
binary
prompt
cd backup40
put c02.dmp
close
bye
!
fi
if test $js = 2
then
exp system/maneger inctype=CUMULATIVE file=c03.dmp
ftp -n< < !
open 10.10.10.40
user demo demo
binary
prompt
cd backup40
put c03.dmp
close
bye
!
fi
if test $js = 3
then
exp system/manager inctype=COMPLETE file=x01.dmp
ftp -n< < !
open 10.10.10.40
user demo demo
binary
prompt
cd backup40
put x01.dmp
close
bye
!
rm c*.dmp
fi ---- e.在demo 用户下建一个文件,假如叫:cron.demo,文件内容如下
59 22 * * 1 bin/zlbf1
59 22 * * 2 bin/zlbf2
59 22 * * 3 bin/zlbf3
59 22 * * 4 bin/zlbf4
59 22 * * 5 bin/zlbf5
59 22 * * 6 bin/zlbf6 ---- f.在demo用户下执行下面的命令:
crontab cron.demo 执行的结果放到
/var/spool/cron/crontabs/demo文件里 ---- g.重新启动cron 进程,命令:kill -1 进程号
---- h.执行结果放在本用户的邮件里 ---- i.查看结果是否执行,请看:/var/adm/cron/log文件 ---- 4.2.2归档方式 ---- a. 找到要回收的数据文件、联机重做登录文件、控制文件和参数文件 ---- b. 正常关闭数据库,作一次全回收(用操作系统的TAR命令,可以写成shell程序),然后打开数据库供正常使用,shell程序如下: tar cvf /dev/rmt/ctape2 /u1/oracle/dbs/ctrl1ora7.ctl
/u1/oracle/dbs/ctrl2ora7.ctl
/u1/oracle/dbs/ctrl3ora7.ctl
/u1/oracle/dbs/systora7.dbf
/u1/oracle/dbs/rbsora7.dbf
/u1/oracle/dbs/tempora7.dbf
/u1/oracle/dbs/toolora7.dbf
/u1/oracle/dbs/usrora7.dbf
/ls1/ls1.dbf
/u1/oracle/dbs/log1ora7.dbf
/u1/oracle/dbs/log2ora7.dbf
/u1/oracle/dbs/log3ora7.dbf
---- a. 经常作联机的表空间和数据文件的部分回收
首先标记联机表空间回收的开始
alter tablespace 表空间名 begin backup;
用操作系统命令备份数据文件 最后标记联机的表空间回收结束
alter tablespace 表空间名 end backup
---- 多个表空间可以一起做标记,备份做标记的所有数据文件后,一起标记结束。
---- d. 当数据库结构发生改变后,要对它的控制文件做回收 sqldba >alter database backup
controlfile to '文件名' reuse;