我们之前也介绍过,如何在 Linux 备份 MySQL 。

作为一个后端开发人员,备份数据库是一个良好的习惯,虽然说数据库损坏或者数据丢失的概率很低,但是你不得不防,要不

2019-9-11 10:23:43

0

1.3k

我是备份在本机,所以我采用 Oracle 自带的 expdp 功能进行备份;如需要异地的,则需要针对以下脚本进行加工,这里不阐述

准备工作

本机具有 Oracle 的 expdp 导出功能

开始工作

创建 sh 脚本,命名为:oracle_backup.sh,以下是脚本

#!/bin/sh

export ORACLE_BASE=/mnt/u01/app/oracle

export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/dbhome_1

export ORACLE_SID=orcl

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

export ORACLE_DIRECTORY=bakdir

# 备份目录

export DATA_DIR=/mnt/backup/bakdir

# 删除备份时间 30 天

export DEL_TIME=`date -d "30 days ago" +%Y%m%d`

# 备份时间

export BAKUP_TIME=`date +%Y%m%d%H%M%S`

# 字符编码

export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK

# 账号

export db_user="test"

# 密码

export db_password="123456"

# db schemas

export db_schemas="data_schemas"

mkdir -p $DATA_DIR

echo "-- $(date +'%Y%m%d%H%M%S') 自动备份数据库并压缩开始 " >> $DATA_DIR/BAK_LOG.txt;

echo "------------------------------------------------------------------" >> $DATA_DIR/BAK_LOG.txt;

echo "-- $(date +'%Y%m%d%H%M%S') 开始备份的文件名:$DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.dmp" >> $DATA_DIR/BAK_LOG.txt;

echo "Bakup file path $DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.dmp"

expdp $db_user/$db_password@$ORACLE_SID schemas=$db_schemas directory=$ORACLE_DIRECTORY dumpfile=${ORACLE_SID}_${BAKUP_TIME}.dmp logfile=${ORACLE_SID}_${BAKUP_TIME}.log

echo "-- $(date +'%Y%m%d%H%M%S') 备份成功:$DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.dmp" >> $DATA_DIR/BAK_LOG.txt;

echo "------------------------------------------------------------------" >> $DATA_DIR/BAK_LOG.txt;

echo "-- $(date +'%Y%m%d%H%M%S') 开始进行压缩:$DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.dmp -> tar.gz" >> $DATA_DIR/BAK_LOG.txt;

cd $DATA_DIR && tar -czvf ${ORACLE_SID}_${BAKUP_TIME}.tar.gz ${ORACLE_SID}_${BAKUP_TIME}.dmp ${ORACLE_SID}_${BAKUP_TIME}.log

echo "-- $(date +'%Y%m%d%H%M%S') 压缩成功:$DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.tar.gz" >> $DATA_DIR/BAK_LOG.txt;

echo "------------------------------------------------------------------" >> $DATA_DIR/BAK_LOG.txt;

echo "-- $(date +'%Y%m%d%H%M%S') 开始删除30天前备份记录文件:$DATA_DIR/${ORACLE_SID}_${DEL_TIME}.dmp" >> $DATA_DIR/BAK_LOG.txt;

rm -rf $DATA_DIR/${ORACLE_SID}_${DEL_TIME}*

echo "-- $(date +'%Y%m%d%H%M%S') 删除30天前备份记录文件:$DATA_DIR/${ORACLE_SID}_${DEL_TIME}.dmp 结束" >> $DATA_DIR/BAK_LOG.txt;

echo "------------------------------------------------------------------" >> $DATA_DIR/BAK_LOG.txt;

echo "-- $(date +'%Y%m%d%H%M%S') 开始删除当前备份记录文件:$DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.dmp" >> $DATA_DIR/BAK_LOG.txt;

rm -rf $DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.dmp $DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.log

echo "-- $(date +'%Y%m%d%H%M%S') 删除当前备份记录文件$DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.dmp 成功" >> $DATA_DIR/BAK_LOG.txt;

echo "------------------------------------------------------------------" >> $DATA_DIR/BAK_LOG.txt;

echo "-- $(date +'%Y%m%d%H%M%S') 自动备份数据库并压缩完毕 " >> $DATA_DIR/BAK_LOG.txt;

echo " " >> $DATA_DIR/BAK_LOG.txt;

echo " " >> $DATA_DIR/BAK_LOG.txt;

说明

上面的脚本是备份 30 天的数据库,我们可以每天导出一份 dmp 备份文件,文件的名称按 sid_当日日期 生成,然后进行打包压缩 tar.gz,最后再删除 30 天之前的数据库备份,然后删除当天备份的 dmp 以及 log;

赋予执行权限

chmod +x /mnt/backup/oracle_backup.sh

定时任务

在 Linux 中,我们利用 Crontab 来针对 oracle_backup.sh 脚本进行定时执行

crontab -e

添加一个定时任务,每天凌晨 1 点执行一次脚本,然后开始 Oracle 的备份

0 1 * * * /mnt/backup/oracle_backup.sh

备份日志 BAK_LOG.txt

-- 20200624010001 自动备份数据库并压缩开始

------------------------------------------------------------------

-- 20200624010001 开始备份的文件名:/mnt/backup/bakdir/orcl_20200624010001.dmp

-- 20200624010126 备份成功:/mnt/backup/bakdir/orcl_20200624010001.dmp

------------------------------------------------------------------

-- 20200624010126 开始进行压缩:/mnt/backup/bakdir/orcl_20200624010001.dmp -> tar.gz

-- 20200624010237 压缩成功:/mnt/backup/bakdir/orcl_20200624010001.tar.gz

------------------------------------------------------------------

-- 20200624010237 开始删除30天前备份记录文件:/mnt/backup/bakdir/orcl_20200525.dmp

-- 20200624010237 删除30天前备份记录文件:/mnt/backup/bakdir/orcl_20200525.dmp 结束

------------------------------------------------------------------

-- 20200624010237 开始删除当前备份记录文件:/mnt/backup/bakdir/orcl_20200624010001.dmp

-- 20200624010238 删除当前备份记录文件/mnt/backup/bakdir/orcl_20200624010001.dmp 成功

------------------------------------------------------------------

-- 20200624010238 自动备份数据库并压缩完毕

linux下expdp定时备份_Linux 自动备份 Oracle 数据库 Shell 脚本相关推荐

  1. Linux 下qt 程序打包发布(使用linuxdelpoyqt ,shell 脚本)

    Linux 下qt 程序打包发布(使用linuxdelpoyqt ,shell 脚本) 转载于:https://www.cnblogs.com/zhehan54/p/9549017.html

  2. Linux下将数据文件的指定域读取到shell脚本中

    Linux下将数据文件的指定域读取到shell脚本中 这个例子说明了怎样在Linux下shell脚本中从数据文件读取特定的域(field)并进行操作.例如,假设文件employees.txt的格式是{ ...

  3. qt调用linux 进程,Linux 下qt 程序打包发布(使用linuxdelpoyqt ,shell 脚本)

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/u014746574/article/d ...

  4. linux下expdp定时备份_Linux下定时任务的配置

    定时任务在日常开发中的重要性不用多说了,直接上方法. 下面以ubuntu 18.04系统为例,来看下如何配置定时任务. 下载cron root@ubuntu18-vmware:~# apt-get i ...

  5. Linux下超简单的Mysql自动备份+定期删除之前备份文件脚本

    引言: 前段时间闹得沸沸扬扬的"微盟"事件,让人们更加明白了数据安全的重要性.一个企业数据丢失会付出很大的代价,最坏的情况下,丢失数据可能会导致企业的崩溃.根据国家档案与记录管理局 ...

  6. linux下部署mysql数据库连接_Linux远程部署MySQL数据库详细步骤

    Linux远程部署MySQL数据库,供大家参考,具体内容如下 1.0 安装 yum install lrzsz -y 命令(导入外界压缩包插件(已下载无视即可)) 1.1 将mysql压缩包拷贝到 / ...

  7. linux下使用DBCA(database configuration assistant)创建oracle数据库

    前提:切换到图形界面 到Oracle的bin文件夹下,使用oracle用户.运行dbca就可以.和windows的效果一样. 假设出现乱码 export LANG="en_US:UTF-8& ...

  8. shell脚本导出oracle数据库,Shell脚本备份恢复Oracle数据库简单示例

    exp_p.sh #!/bin/sh #$1生成dmp文件保存路径 if [ -d $1 ]; then echo $1 exist #用户名/密码 生成文件名称根据当天 exp_p.sh #!/bi ...

  9. linux下mysql日志管理及mysql备份还原

    linux下mysql日志管理及mysql备份还原 1.SHOW GLOBAL VARIABLES LIKE '%log%';  显示所有日志相关的选项 2.错误日志:log_error和log_wa ...

最新文章

  1. bad cpu type in executable_【简讯】Intel将每5年重新开发一次CPU架构;华为EMUI 11曝光…...
  2. oracle xe 连接数据库,【Oracle XE系列之二】PLSQL Developer 远程连接Oracle XE数据库-Go语言中文社区...
  3. 黑盒测试方法_黑盒测试方法 收集
  4. usb打印机linux识别不了怎么办,win10不识别usb打印机怎么回事_win10系统不识别usb打印机如何修复-系统城...
  5. 零基础入门NLP之搭建中文分词工具
  6. 《构建高可用Linux服务器》卓越网和互动网上架了
  7. Linux系统下MySQL数据库的超级管理员root的密码忘记/忘记密码怎么办?
  8. 原型设计+用户规格说明书
  9. oracle ocx加载错误,flash9.ocx 加载错误解决方法
  10. maven异常001---报错The folder is already a source folder.的解决办法
  11. Qt4_十六进制微调框
  12. python遗传算法最短路径问题有几种类型_用遗传算法求解最短路径问题.pdf
  13. Word基础(八)带圈字符
  14. 【题解】【AcWing】3505. 最长ZigZag子序列
  15. 你会用微信付款码支付吗?一定要打开这个设置,保障你资金安全
  16. 国外广告联盟前期需要准备的事情
  17. ddmmyy日期格式是多少_如何用SAS读取月份为英文缩写并且格式为ddmmyy的日期数据...
  18. javaScript判断当前浏览器(谷歌、火狐、IE)兼容IE11
  19. PyTorch深度学习(18)网络结构LeNet、AlexNet
  20. 解决android studio打包后安装APK提示“签名不一致,该应用可能已被修改。“

热门文章

  1. windows下docker安装mysql
  2. ROS( C++ )订阅 robot 的 path 话题
  3. C#:winform开发的System.AccessViolationException错误,已解决
  4. RBF、GRNN和PNN神经网络的深入浅出
  5. 生产者与消费者模式(python 版)
  6. 深入浅出VC++串口编程--基本概念
  7. Datalist Repeater分页
  8. Imdb影评的数据集介绍与下载
  9. arduino运行java_IC之路(一)Proteus-Arduino仿真环境搭建
  10. mysql中in的使用