Oracle数据库:使用 bash脚本 + 定时任务 自动备份数据

news2025/1/10 16:44:23

Oracle数据库:使用 bash脚本 + 定时任务 自动备份数据

  • 1、前言
  • 2、为什么需要自动化备份?
  • 3、编写备份脚本
  • 4、备份脚本授权
  • 5、添加定时任务
  • 6、重启 crond / 检查 crond 服务状态
  • 7、备份文件检查


💖The Begin💖点点关注,收藏不迷路💖

在这里插入图片描述

1、前言

在日常的系统管理工作中,数据库的备份是至关重要的一环。针对 Oracle 数据库的备份,我们可以编写 Bash 脚本来实现自动化备份操作,从而简化数据库管理的流程,保障数据的安全性和可靠性。

2、为什么需要自动化备份?

数据库作为应用程序的核心数据存储,包含了大量的重要信息,例如用户数据、配置信息等。一旦数据库出现意外故障或数据丢失,可能会给业务带来严重影响甚至损失。因此,定期进行数据库备份并保证备份文件的安全存储是非常重要的。

手动备份存在诸多弊端,例如容易出现疏忽、不及时等问题,因此自动化备份成为了一个更好的选择。通过编写脚本实现自动备份,可以提高效率、减少人为错误,同时也能够更好地保障数据的安全。

3、编写备份脚本

创建备份数据保存目录和bash脚本保存目录。

在 /oracle/backup 目录下创建一个名为 data 的子目录,用于保存备份数据;

在同一目录下创建一个名为 bash 的子目录,用于保存 bash 脚本文件。


mkdir -p /oracle/backup/data 

mkdir -p /oracle/backup/bash 


##先安装 bzip2 压缩工具,后面压缩备份文件用到,或者你使用tar -cvzf 打包为.tar.gz格式也可以
yum install  bzip2

在这里插入图片描述

注意:先对/oracle/backup/data 目录进行授权,要不会报错:

ORA-39002: invalid operation
ORA-39070: Unable to open the log file.
ORA-39087: directory name /ORACLE/BACKUP/DATA is invalid

在这里插入图片描述

解决:

###切换oracle用户
su - oracle 

###启动客户端进程
sqlplus /nolog 

###以管理员登录
conn / as sysdba

##在 Oracle 数据库中创建一个名为 dumpdir 的目录,并将其路径设置为 /oracle/backup/data/。这样,你就能够在数据库中通过目录别名 dumpdir 来引用该路径。

create directory dumpdir as '/oracle/backup/data/';

##针对备份执行备份用户赋予read,write权限,
grant read,write on directory dumpdir to zyl;

在这里插入图片描述

备份脚本模板:

#!/bin/sh

source /home/oracle/.bash_profile

export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=$ORACLE_BASE/product/12.2.0
export ORACLE_SID=orcl
export ORACLE_TERM=xterm
export PATH=$ORACLE_HOME/bin:/usr/sbin:$PATH:$HOME/bin
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib
#export LANG=C
export NLS_LANG=AMERICAN_AMERICA.AL32UTF8

# 以上代码为Oracle数据库运行账号oracle的系统环境变量设置,必须添加,否则crontab任务计划不能执行。

# oracle用户的系统环境变量路径:/home/oracle/.bash_profile

current_date=`date +%Y_%m_%d` # 获取系统当前日期时间
days_to_keep=90 # 设置删除90天之前的备份文件
db_server="192.168.10.19:1521/ORCL"  # Oracle数据库服务器IP、端口、SID
backup_owner="your_username" # 备份此用户下面的数据
backup_user="your_backup_user" # 用此用户来执行备份,必须要有备份操作的权限
backup_password="your_password" # 执行备份的用户密码
backup_dir=/oracle/backup/data  # 备份文件路径,需要提前创建好
backup_data=$backup_owner"_"$current_date.dpdmp # 备份数据库名称
backup_log=$backup_owner"_"$current_date.dplog # 备份执行时生成的日志文件名称
oracle_data_backup=$backup_owner"_"$current_date.tar.bz2 # 最后保存的Oracle数据库备份文件

cd $backup_dir # 进入备份目录
expdp $backup_user/$backup_password DIRECTORY=dumpdir DUMPFILE=$backup_data logfile=$backup_log SCHEMAS=$backup_owner VERSION=11.2.0.1.0   ##注意这里的DIRECTORY值为数据库中创建的 dumpdir 目录
tar -cvjpf $oracle_data_backup $backup_data $backup_log # 压缩备份文件和日志文件
find $backup_dir -type f -name "*.dplog" -exec rm {} \; # 删除备份文件
find $backup_dir -type f -name "*.dpdmp" -exec rm {} \; # 删除日志文件
find $backup_dir -type f -name "*.tar.bz2" -mtime +$days_to_keep -exec rm -rf {} \; # 删除90天前的备份(注意:{} \中间有空格)

cd 到/oracle/backup/bash ,vi 编写备份脚本,如vi backup_oracle.sh

查看oracle有关的环境变量:

## Oracle 数据库软件的基础目录
echo $ORACLE_BASE

##Oracle 数据库软件的安装目录
echo $ORACLE_HOME

##可执行程序的路径
echo $PATH

在这里插入图片描述

修改模板文件:

#!/bin/sh

source /home/oracle/.bash_profile

export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0
export ORACLE_SID=orcl
export ORACLE_TERM=xterm
export PATH=$ORACLE_HOME/bin:/usr/sbin:$PATH:$HOME/bin
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib
#export LANG=C
export NLS_LANG=AMERICAN_AMERICA.AL32UTF8

# 以上代码为Oracle数据库运行账号oracle的系统环境变量设置,必须添加,否则crontab任务计划不能执行。

# oracle用户的系统环境变量路径:/home/oracle/.bash_profile

current_date=`date +%Y_%m_%d` # 获取系统当前日期时间
days_to_keep=90 # 设置删除90天之前的备份文件
db_server="192.168.234.20:1521/ORCL"  # Oracle数据库服务器IP、端口、SID
backup_owner="zyl" # 备份此用户下面的数据(和模式名一样)
backup_user="system" # 用此用户来执行备份,必须要有备份操作的权限
backup_password="Zyl#123456" # 执行备份的用户密码
backup_dir=/oracle/backup/data  # 备份文件路径,需要提前创建好
backup_data=$backup_owner"_"$current_date.dpdmp # 备份数据库名称
backup_log=$backup_owner"_"$current_date.dplog # 备份执行时生成的日志文件名称
oracle_data_backup=$backup_owner"_"$current_date.tar.bz2 # 最后保存的Oracle数据库备份文件,tar.bz2/.gz格式,选一种即可


cd $backup_dir # 进入备份目录
expdp $backup_user/$backup_password DIRECTORY=dumpdir DUMPFILE=$backup_data logfile=$backup_log SCHEMAS=$backup_owner VERSION=11.2.0.1.0 
tar -cvjpf $oracle_data_backup $backup_data $backup_log # 压缩备份文件和日志文件,.tar.bz2格式,选一种即可

#tar -cvzf $oracle_data_backup $backup_data $backup_log # 压缩备份文件和日志文件,.tar.gz格式


find $backup_dir -type f -name "*.dplog" -exec rm {} \; # 删除备份文件
find $backup_dir -type f -name "*.dpdmp" -exec rm {} \; # 删除日志文件
find $backup_dir -type f -name "*.tar.bz2" -mtime +$days_to_keep -exec rm -rf {} \; # 删除90天前的备份(注意:{} \中间有空格)

在这里插入图片描述

4、备份脚本授权

在添加定时任务之前,需要确保脚本已经有可执行权限。可以使用chmod +x 备份脚本 命令赋予脚本可执行权限。

chmod +x /oracle/backup/bash/backup_oracle.sh

在这里插入图片描述

5、添加定时任务

拓展:

当设置定时任务时,可以使用以下格式来详细定义时间:

* * * * *  执行脚本绝对路径
- - - - -
| | | | |
| | | | +----- 星期几 (0 - 7) (星期天可以用0或7表示)
| | | +------- 月份 (1 - 12)
| | +--------- 日期 (1 - 31)
| +----------- 小时 (0 - 23)
+------------- 分钟 (0 - 59)


通过这五个字段的组合,可以精确地定义定时任务执行的时间。例如:

30 2 * 1-5        表示在周一到周五的凌晨230分执行任务。
0 20 * * 1,3,5    表示在周一、周三、周五的晚上8点执行任务。
0 * * * *         表示每分钟执行一次任务。
0 3 * * *         表示每天凌晨3点执行任务。
0 4 1 * *         表示每月的第一天凌晨4点执行任务。

根据具体的需求,可以灵活地调整定时任务的时间设置。

为脚本添加定时任务可以实现自动备份,以下是添加定时任务的步骤:

打开终端窗口,输入crontab -e命令,编辑当前用户的定时任务配置文件。

crontab -e

在文件中添加如下一行,注意是脚本的绝对路径,表示每天凌晨3点执行备份:

0 3 * * * /oracle/backup/bash/backup_oracle.sh

在这里插入图片描述

如果出现下面报错:

UDE-00013: Message 13 not found; No message file for product=RDBMS, facility=UDE
UDE-00019: You may need to set ORACLE_HOME to your Oracle software directory

在这里插入图片描述

是因为指定的ORACLE_HOME没有生效。

如果是直接用expdp命令执行,执行前先做一次 source /home/oracle/.bash_profile 。

如果是使用shell脚本调度执行,需要在shell脚本中再次声明赋值 ORACLE_HOME、ORACLE_SID 变量,因为shell脚本调度的时候,使用的是 全局环境变量 /etc/profile。

如果频繁使用shell执行Oracle命令,可以把这些配置参数刷新到 /etc/profile 中。如果没有设定ORACLE_HOME、ORACLE_SID,在调度shell命令的时候,会报错 UDE-00013、UDE-00019

解决:

1、su root

vi /etc/profile ,末尾加上如下配置:

####添加内容
# use for oracle

unset   TNS_ADMIN
export  ORACLE_BASE=/u01/app/oracle
export  ORACLE_HOME=$ORACLE_BASE/product/11.2.0

export  ORACLE_SID=orcl

export  PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin

export  LD_LIBRARY_PATH=$ORACLE_HOME/lib:/usr/lib
#防止Oracle安装界面乱码,先把语言环境改为英文
export LANG=en_US

if [ $USER = "oracle" ];then

   if [ $SHELL = "/bin/ksh" ];then

     ulimit -p 16384

     ulimit -n 65536

   else

    ulimit -u 16384 -n 65536

   fi

   fi

在这里插入图片描述

2、使配置文件生效:

source /etc/profile

6、重启 crond / 检查 crond 服务状态

#重启 
systemctl restart crond

#服务状态查看
systemctl status crond

在这里插入图片描述

7、备份文件检查

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述


💖The End💖点点关注,收藏不迷路💖

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1521546.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Golang实现Redis分布式锁(Lua脚本+可重入+自动续期)

Golang实现Redis分布式锁(Lua脚本可重入自动续期) 1 概念 应用场景 Golang自带的Lock锁单机版OK(存储在程序的内存中),分布式不行 分布式锁: 简单版:redis setnx》加锁设置过期时间需要保证原…

3.Redis命令

Redis命令 Redis 根据命令所操作对象的不同, 可以分为三大类: 对 Redis 进行基础性操作的命令,对 Key 的操作命令,对 Value 的操作命令。 1.1 Redis 首先通过 redis-cli 命令进入到 Redis 命令行客户端,然后再运行下…

横向移动 --> PTT(Kerberos)

好不容易到了周末,终于有时间来写自己的东西了,那么就来讲一下PTT吧 目录 1.PTT(Past The Ticket) 2.Golden Ticket 1.Krbtgt的NTLM hash 2.获取域的sid 3.查看要伪造的管理员 4.查看域控名字 5.查看并且清除票据 6.制造黄金票据 3.Sliver Ticke…

Python 基础语法:基本数据类型(字典)

为什么这个基本的数据类型被称作字典呢?这个是因为字典这种基本数据类型的一些行为和我们日常的查字典过程非常相似。 通过汉语字典查找汉字,首先需要确定这个汉字的首字母,然后再通过这个首字母找到我们所想要的汉字。这个过程其实就代表了…

【Algorithms 4】算法(第4版)学习笔记 18 - 4.4 最短路径

文章目录 前言参考目录学习笔记0:引入介绍1:APIs1.1:API:加权有向边1.2:Java 实现:加权有向边1.3:API:加权有向图1.4:Java 实现:加权有向图1.5:AP…

NVidia NX 中 ROS serial软件包的安装

自己装的ROS是noetic版本,受限于网络,直接用命令安装串口包不行。于是手动安装了一次。 1 下载源码 git clone https://github.com/wjwwood/serial.git 或者直接在浏览器里面输入 https://github.com/wjwwood/serial.git 2 解压 然后在serial&#xf…

【考研数学】高等数学总结

文章目录 第一章 极限 函数 连续1.1 极限存在准则及两个重要极限1.1.1 夹逼定理1.1.1.1 数列夹逼定理1.1.1.2函数夹逼定理 1.1.2 两个重要极限1.1.2.1 极限公式11.1.2.1.1 证明1.1.2.1.2 数列的单调有界收敛准则1.1.2.1.2.1 二项式定理1.1.2.1.2.2 证明 1.1.2.2 极限公式21.1.2…

未来洞见:亚信安慧AntDB在数据可靠性上的愿景

和国外成熟稳定的商业数据库相比,国产数据库在性能、稳定性、生态等方面存在一定差距,我国数据库的自主可控替换,也不是简单的以库换库,而是用新体系替换旧体系,在架构、研发、上线、运维等方面,全面降低对…

Pyqt5中,QGroupBox组件标题字样(标题和内容样式分开设置)相对于解除继承

Python代码示例: import sys from PyQt5.QtWidgets import QApplication, QWidget, QVBoxLayout, QGroupBox, QLabelclass MyApp(QWidget):def __init__(self):super().__init__()# 创建一个 QVBoxLayout 实例layout QVBoxLayout()# 创建 QGroupBox 实例self.grou…

系统分析与设计作业 --- 酒店管理系统(2~3周)

第二周 作业一: (1)需求分析NABCD 我们的项目是一个酒店管理系统,所i对应的NABCD描述 NABCD是一种产品描述框架,用于全面阐述产品的各个方面。其中,N代表需求(Need),描…

5_springboot_shiro_jwt_多端认证鉴权_禁用Cookie

1. Cookie是什么 ​ Cookie是一种在客户端(通常是用户的Web浏览器)和服务器之间进行状态管理的技术。当用户访问Web服务器时,服务器可以向用户的浏览器发送一个名为Cookie的小数据块。浏览器会将这个Cookie存储在客户端,为这个Co…

字符串分割(C++)

经常碰到字符串分割的问题,这里总结下,也方便我以后使用。 一、用strtok函数进行字符串分割 原型: char *strtok(char *str, const char *delim); 功能:分解字符串为一组字符串。 参数说明:str为要分解的字符串&am…

LeetCode每日一题 将有序数组转换为二叉搜索树(分治)

题目描述 给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵平衡二叉搜索树。 示例 1: 输入:nums [-10,-3,0,5,9] 输出:[0,-3,9,-10,null,5] 解释:[0,-10,5,null,-3,null,9] 也将被视…

[RAM] RAM 突发传输(Burst ,Burst size, length) | Burst 读写过程与时序 精讲

主页: 元存储博客 文章目录 前言1. Burst 基本概念含义Burst Width &Burst Length 2. CPU Burst mode3. 总线 burst mode总线的仲裁总线突发传输时序 4. Burst Chop (突发终止)5. Burst Mode 应用什么时候用突发模式 总结 前言 在DMA(直接内存访问&…

MD5算法:密码学中的传奇

title: MD5算法:密码学中的传奇 date: 2024/3/15 20:08:07 updated: 2024/3/15 20:08:07 tags: MD5起源算法原理安全分析优缺点比较技术改进示例代码应用趋势 MD5算法起源: MD5(Message Digest Algorithm 5)算法是由MIT的计算机…

Web框架盘点:好用又实用的技术解析

​随着2024年的临近,我们满怀热情地为新的一年制定计划,探索未来一年可以学习或实现的目标。此时是探索未来一年值得学习的框架、理解其功能和特点的最佳时机。我们将以2023年JavaScript新星为指南,力求保持客观公正的态度。对于每个值得关注…

调皮的String及多种玩法(下部)

👨‍💻作者简介:👨🏻‍🎓告别,今天 📔高质量专栏 :☕java趣味之旅 欢迎🙏点赞🗣️评论📥收藏💓关注 💖衷心的希…

修复 error Delete `␍` prettier/prettier 错误

修复 error Delete ␍ prettier/prettier 错误 问题背景报错信息报错原因解决办法修改CRLF----针对单个文件yarn run lint --fix 一键修复(官方提供) 问题背景 今天在使用 openapi 自动生成前端接口代码的时候,爆了一个类似 eslint 规范的错…

C/C++炸弹人游戏

参考书籍《啊哈,算法》,很有意思的一本算法书,小白也可以看懂,详细见书,这里只提供代码和运行结果。 这里用到的是枚举思想,还有更好地搜索做法。 如果大家有看不懂的地方或提出建议,欢迎评论区…

外包干了9天,技术退步明显。。。。。

先说一下自己的情况,本科生,2018年我通过校招踏入了南京一家软件公司,开始了我的职业生涯。那时的我,满怀热血和憧憬,期待着在这个行业中闯出一片天地。然而,随着时间的推移,我发现自己逐渐陷入…