Oracle 数据库全库备份脚本

#!/bin/bash
# 按照日期为备份文件名取值
export NLS_LANG=AMERICAN_AMERICA.AL32UTF8
a=$(date +%Y%m%d)
#b=$(date -d '7 days ago' +%Y%m%d)
echo $a
#echo $b

location='/home/oracle/backup'
find $location -mtime +30 -type f |xargs rm -f 
location1='/home/oracle/log'
find $location1 -mtime +30 -type f |xargs rm -f

# 设置Oracle环境变量
export ORACLE_HOME=/u01/app/oracle/product/11.2.0/db_1;
export ORACLE_SID=ctms;
export PATH=/u01/app/oracle/product/11.2.0/db_1/bin:$PATH;

# 运行exp命令执行输出
exp system/oracle file=/home/oracle/backup/$a.dmp log=/home/oracle/log/Exp_$a.log full=y

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1、提供了oracle数据库备份脚本,导出dmp文件 2、定时任务由操作系统提供的支持,在操作系统中设置定时任务,由操作系统定期执行脚本 3、补充。压缩包脚本有点问题,不能删除旧的备份文件。需要自动删除历史备份文件请用最新脚本: @echo off @echo ================================================ @echo windows环境下Oracle数据库的自动备份脚本 @echo 说明:启动备份时,需要配置以下变量 @echo 1、BACKUP_DIR 指定要备份到哪个目录 @echo 2、ORACLE_USERNAME 指定备份所用的Oracle用户名 @echo 3、ORACLE_PASSWORD 指定备份所用的Oracle密码 @echo 4、ORACLE_DB 指定备份所用的Oracle连接名 @echo 5、BACK_OPTION 备份选项,可以为空,可以为full=y,可以为owner=a用户,b用户 等等.... @echo 6、RAR_CMD 指定RAR命令行压缩工具所在目录 @echo ================================================ rem 以下变量需要根据实际情况配置 set BACKUP_DIR=D:\tools\oracle_bak\backup230 set ORACLE_USERNAME=PLATADMIN set ORACLE_PASSWORD=123456 set ORACLE_DB=ORCL set BACK_OPTION=owner=PLATADMIN set RAR_CMD="D:/Program Files/WinRAR/Rar.exe" rem for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a rem set BACK_NAME=%ORACLE_DB%_%TODAY%(%time:~0,2%时%time:~3,2%分)_ set BACK_NAME=%Date:~0,4%%Date:~5,2%%Date:~8,2%%Time:~0,2%%Time:~3,2%%Time:~6,2% set BACK_FULL_NAME=%BACKUP_DIR%/%BACK_NAME% rem 开始备份 exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB% %BACK_OPTION% file="%BACK_FULL_NAME%.dmp" log="%BACK_FULL_NAME%exp.log" rem 压缩并删除原有文件 %RAR_CMD% a -df "%BACK_FULL_NAME%back.rar" "%BACK_FULL_NAME%.dmp" "%BACK_FULL_NAME%exp.log" rem 删除15天前的备份文件 forfiles /p %BACKUP_DIR% /s /m *.rar /d -15 /c "cmd /c del @file"
Oracle自动数据库备份脚本可以通过编写适当的PL/SQL脚本来实现。以下是一个简单的示例备份脚本: ``` -- 创建一个存储过程来备份数据库 CREATE OR REPLACE PROCEDURE backup_database AS BEGIN -- 定义备份文件名 DECLARE backup_file VARCHAR2(100) := 'D:\backup\database_backup_' || TO_CHAR(SYSDATE, 'YYYYMMDDHH24MISS') || '.dmp'; BEGIN -- 执行备份命令 EXECUTE IMMEDIATE 'expdp system/password@SID directory=DATA_PUMP_DIR dumpfile=' || backup_file || ' full=y'; -- 在这里可以添加其他操作,比如将备份文件上传到远程服务器 -- 输出备份成功信息 DBMS_OUTPUT.PUT_LINE('数据库备份完成'); EXCEPTION -- 处理异常 WHEN OTHERS THEN -- 输出错误信息 DBMS_OUTPUT.PUT_LINE('备份失败:' || SQLERRM); END; END; / -- 创建一个定时任务,每天定时执行备份 BEGIN DBMS_SCHEDULER.CREATE_JOB( job_name => 'DAILY_BACKUP', job_type => 'PLSQL_BLOCK', job_action => 'BEGIN backup_database; END;', start_date => SYSTIMESTAMP, repeat_interval => 'FREQ=DAILY', enabled => TRUE); END; / ``` 上述脚本创建了一个名为`backup_database`的存储过程来备份数据库,并使用PL/SQL中的`EXECUTE IMMEDIATE`语句执行了`expdp`命令来导出数据库。在存储过程中,可以根据需求进行其他操作,如拷贝备份文件到远程服务器等。最后,使用`CREATE_JOB`过程创建了一个名为`DAILY_BACKUP`的定时任务,每天定时执行备份操作。 请注意,上述示例仅供参考,实际使用时需要根据具体情况进行适当的修改和调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值