我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Oracle11g数据库使用expdp每周进行数据备份并上传到备份服务器

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Oracle11g数据库使用expdp每周进行数据备份并上传到备份服务器

学校需要将之前的生产数据库备份到华为云,之后实现每周自动备份

1.看看数据库情况

1.1先看了下表空间情况,生产环境表空间大概90G,用了才一半不到

查看所有表空间及使用情况

SELECT
  B.FILE_NAME 物理文件名,
  B.TABLESPACE_NAME 表空间名称,
  B.BYTES/1024/1024 大小M,
  (B.BYTES-SUM(NVL(A.BYTES,0)))/1024/1024 已使用M,
  SUBSTR((B.BYTES-SUM(NVL(A.BYTES,0)))/(B.BYTES)*100,1,5) 使用率
FROM DBA_FREE_SPACE A,DBA_DATA_FILES B
WHERE A.FILE_ID=B.FILE_ID
GROUP BY B.TABLESPACE_NAME,B.FILE_NAME,B.BYTES
ORDER BY B.TABLESPACE_NAME;

2.数据库备份

2.1登陆数据库

[root@]$ sqlplus / as sysdba

2.2创建逻辑目录

执行这个操作并不会在Linux中创建/opt/data_backup这个文件,最后需要手动去创建该文件才能进行备份。

SQL> create directory back_dir as '/opt/backup'
SQL> select * from dba_directories; #查看所有逻辑目录,看是否创建成功

2.3给数据库用户文件操作权限#dbuser为数据库用户名,更具实际情况更改

Grant read,write on directory back_dir to dbuser;

2.3创建物理目录

[root@]$ mkdir -p /opt/backup #-p 确保目录名称存在,不存在的就建一个,可使用参数创建多级目录

1.3备份数据库

[root@]$ expdp dbuser/passwd@192.168.110.9:1521/orcl dumpfile=dbback.dmp log=log.log directory=back_dir schemas=cbyxy

exedp有很多参数,这里是用到的一些解释
dbuser/passwd@192.168.110.9:1521/orcl #导出用户名/密码@数据库IP/数据库SID
dumpfile=导出的文件名.dmp
log=导出过程的日志名.log
directory=备份放的路径名,用的之前的逻辑目录名
schemas=要备份的数据库用户名字
FULL=y #加上意思为导出整个数据库就不需要schemas参数了
也可以按表空间导出TABLESPACES=
表名导出TABLES=
等等还有很多参数自行了解

3.shell脚本实现自动备份

#!/bin/bash
#导入环境变量,根据具自己实际情况填写
export ORACLE_BASE=/home/oracle/app
export ORACLE_HOME=$ORACLE_BASE/oracle/product/11.2.0/dbhome_1
export PATH=$ORACLE_HOME/bin:$PATH
export LOCAL_IP=192.168.110.183:1521
export BACKUP_USER_IP_DIR=root@192.168.110.187:/opt/   #备份服务器的用户,ip,保存地址
export ORACLE_USER_NAME=system #数据库的用户密码根据实际情况填写,备份整个库最好使用system或sys管理员用户
export ORACLE_USER_PASSWD=Abc123556..
export ORACLE_SID=orcl #不知道可以使用Oracle用户执行echo $ORACLE_SID,或者SQL> SELECT instance_name FROM v$instance
export DATA_DIR=/opt/backup   #与数据库中的逻辑地址相同,用来储存备份文件
export DELTIME=`date -d "7 days ago" +%Y%m%d` # -d "7 days ago" 为获取七天前的日期,以日期命名方便任务自动删>除
export BAKUPTIME=`date +%Y%m%d` #备份日期年月日
export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK #定义语言地域和字符集属性的环境变量,根据自己数据库情况修改
mkdir -p $DATA_DIR
echo "Starting bakup..."
echo "Backup file path $DATA_DIR/$BAKUPTIME.dmp"
expdp $ORACLE_USER_NAME/$ORACLE_USER_PASSWD@$LOCAL_IP/$ORACLE_SID dumpfile=$BAKUPTIME.dmp log=$BAKUPTIME.log directory=expdp full=y
echo "backup file success..."
tar -zcvPf $DATA_DIR/$BAKUPTIME.tar.gz $DATA_DIR/$BAKUPTIME.dmp --remove-files ##-P:指定绝对路径 --remove-files :打包后删除原文件
echo "tar the file backup successfully"
echo "scp to":$BACKUP_IP
scp $DATA_DIR/$BAKUPTIME.tar.gz $BACKUP_USER_IP_DIR #远程服务器防火墙有限制scp端口需要加:-P 端口号
rm -f $DATA_DIR/$DELTIME.log #删除之前的备份
echo "Bakup completed."

4.添加定时任务

[root@ ]$ crontab -e

添加行:* 1 * * 6 /opt/back.sh #每个星期的星期六早上执行备份任务

*    *    *    *    *
-    -    -    -    -
|    |    |    |    |
|    |    |    |    +----- 星期中星期几 (0 - 6) (星期天 为0)
|    |    |    +---------- 月份 (1 - 12) 
|    |    +--------------- 一个月中的第几天 (1 - 31)
|    +-------------------- 小时 (0 - 23)
+------------------------- 分钟 (0 - 59)

4.参考文章

https://www.cnblogs.com/xwdreamer/p/3511047.html
https://www.cnblogs.com/farmer-y/p/5888432.html
https://blog.csdn.net/weixin_41607523/article/details/110817646
https://blog.csdn.net/XUEYUTIANQI/article/details/113976558

到此这篇关于Oracle 11g数据库使用expdp每周进行数据备份并上传到备份服务器的文章就介绍到这了,更多相关Oracle 11g使用expdp备份数据内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Oracle11g数据库使用expdp每周进行数据备份并上传到备份服务器

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Oracle 11g数据库使用expdp每周进行数据备份并上传到备份服务器

目录1.看看数据库情况1.1先看了下表空间情况,生产环境表空间大概90G,用了才一半不到2.数据库备份2.1登陆数据库2.2创建逻辑目录2.3给数据库用户文件操作权限#dbuser为数据库用户名,更具实际情况更改2.3创建物理目录1.3备份
2022-06-28

Centos7中MySQL数据库使用mysqldump进行每日自动备份

数据库的备份,对于生产环境来说尤为重要,数据库的备份分为物理备份和逻辑备份。我们将使用mysqldump命令进行数据备份。使用自动任务进行每日备份。一、需求说明:数据库的备份,对于生产环境来说尤为重要,数据库的备份分为物理备份和逻辑备份。物理备份:使用相关的复
Centos7中MySQL数据库使用mysqldump进行每日自动备份
2014-07-08

CentOS中使用Shell脚本实现每天自动备份网站文件和数据库并上传到FTP中

一、安装Email发送程序yum install sendmail mutt二、安装FTP客户端程序本脚本需要用到FTP客户端程序将文件上传到FTP空间上面,因此必须安装FTP客户端,否则将出现ftp命令无法找到的错误。 安装步骤请参考:《
2022-06-04

如何利用PHP脚本在Linux服务器上进行数据备份

在日常的网站运维工作中,数据备份是一项重要的任务。有了完善的数据备份策略,可以确保网站数据的安全和可靠性。本文将介绍如何利用PHP脚本在Linux服务器上进行数据备份,并提供具体的代码示例。在Linux服务器上进行数据备份可以借助一些常用的
2023-10-21

Centos7中MySQL数据库怎么使用mysqldump进行每日自动备份的编写

这篇文章主要介绍“Centos7中MySQL数据库怎么使用mysqldump进行每日自动备份的编写”,在日常操作中,相信很多人在Centos7中MySQL数据库怎么使用mysqldump进行每日自动备份的编写问题上存在疑惑,小编查阅了各式资
2023-06-20

云服务器数据备份到本地服务器上还能用吗

本地备份恢复是指在云服务器上备份的数据,可以通过一种特殊的技术恢复到云服务器上。这项技术主要涉及到云备份数据的同步和复制。在云备份恢复中,备份数据被保存在本地存储设备中,并通过网络连接传输到云服务器上。云服务器会自动同步和复制这些备份数据到云备份存储设备中。这样,当本地备份数据出现问题时,就可以通过云服务器上的备份数据
云服务器数据备份到本地服务器上还能用吗
2023-10-28

CentOS中如何使用Shell脚本实现每天自动备份网站文件和数据库并上传到FTP中

这篇文章主要讲解了“CentOS中如何使用Shell脚本实现每天自动备份网站文件和数据库并上传到FTP中”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CentOS中如何使用Shell脚本实现
2023-06-09

云服务器数据库备份怎么恢复正常使用

云服务器数据库备份的恢复方法备份数据库通常需要选择可靠的云服务器提供商来进行备份。选择云服务器提供商时,需要考虑以下因素:云服务器提供商的信誉和品牌选择知名度高、品牌声誉良好的云服务器提供商,可以保证备份的数据的可靠性和安全性。同时,品牌声誉也是用户选择的一个重要考虑因素。云服务器提供商的服务质量选择一个可靠的云服务器
云服务器数据库备份怎么恢复正常使用
2023-10-28

云服务器数据备份到本地服务器上还能用吗苹果

在使用云服务之前,用户需要确定哪些数据可以备份到本地服务器上。通常情况下,用户需要备份他们的个人数据、历史记录、文档、图片和视频等数据。此外,用户还需要备份他们的社交媒体账户、密码、登录凭据、应用程序和其他敏感信息。对于本地服务器上的数据,用户需要注意以下几点。首先,本地服务器上的数据需要经过加密才能备份到本地服务器上
云服务器数据备份到本地服务器上还能用吗苹果
2023-10-28

云服务器数据备份到本地文件怎么恢复正常使用

一、备份数据到云服务器在使用云服务器之前,最好将数据备份到云服务器上。这样可以确保数据的安全性,并且可以在出现问题时恢复数据。云服务器是一个托管在网络上的服务器,可以为您提供可扩展的存储和计算资源。在备份数据到云服务器之前,您需要确保云服务器是可用的,并且有足够的存储空间。步骤1:购买云服务器选择一家可信赖的云服务器提
2023-10-27

编程热搜

目录