[自动运维]oracle自动备份

  数据是应用的核心部分,程序坏了换台机器从新发布就能够,但数据一旦丢失,形成的损失将不可挽回,程序发布到生产后,数据的备份便显得尤其重要,因为不必定全部的服务均有资金完成高级的备份如RAC和DG,在咱们只有一台数据库服务器的,暂时采起最简单的备份策略,export出dmp进行保存。web

1、备份脚本数据库

一、初始化变量,记录开始日志服务器

#变量
sysname=填写本身的系统名称
syspath=/home/oracle/databak/$sysname
v_date=$(date '+%Y%m%d%H%M%S')
#日志目录
logfile=${syspath}/backup.${v_date}.log
#打印开始时间
echo backup_time>>${logfile}
date '+%Y-%m-%d %H:%M:%S' >> ${logfile}

echo "backup jcd">>${logfile}
echo "start_time">>${logfile}
date '+%Y-%m-%d %H:%M:%S' >> ${logfile}

二、进入oracle目录,设置oracle的参数oracle

#进入oracle目录,设置oracle变量
cd /home/11g/app/oracle/product/11.2.0
export ORACLE_HOME=/home/11g/app/oracle/product/11.2.0/db_1
export PATH=$PATH:/home/11g/app/oracle/product/11.2.0/db_1/bin
export ORACLE_SID=SID名称

三、导出数据app

echo $syspath
v_date=$(date '+%Y%m%d%H%M%S')
filename=$syspath/jcd${v_date}.dmp
#导出命令
exp username/password file=${filename} compress=n >> ${logfile}
echo "end_time">>${logfile}
date '+%Y-%m-%d %H:%M:%S'>>${logfile}

四、压缩dump包ssh

gzip ${filename}

五、使用scp,将压缩后的包传递到备份服务器,注意备份服务器上目录须要预先建立加密

scp ${filename}.gz remot_name@remot_ip:/home/weblogic/databak/备份目录

2、设定脚本执行时间spa

咱们设定规则为天天凌晨2点执行一次,采用crontab来进行处理日志

执行crontab -e,设定以下规则code

0 2 * * * sh /home/oracle/db.sh

3、关于scp命令密码处理

执行scp命令时候,会提示输入远程主机的密码

scp ${filename}.gz remot_name@remot_ip:/home/weblogic/databak/备份目录

此时有两种处理办法进行解决:

一、使用加密文件进行认证

1)进入本地主机的~/.ssh目录下

2)运行ssh-keygen -t [rsa|dsa],将会生成密钥文件和私钥文件 id_rsa,id_rsa.pub或id_dsa,id_dsa.pub,此处咱们使用rsa方式进行

3)将生成的id_rsa和id_rsa.pub权限修改成700

4)将.pub文件复制到远程主机的~/.ssh目录,执行cat id_rsa.pub >> ~/.ssh/authorized_keys,将内容拷入authorized_keys文件

5)修改authorized权限为700

  完成以上修改以后,从本地主机scp到远程主机便无须密码,简单理解应该是通信时候,本地主机发送scp指令时,采用本地私钥进行签名,远程主机使用公钥验签后,判断问主机能够信赖,开放通信服务。

二、使用expect命令完成密码交互

  expect命令主要用于脚本中出现必须人工干预的状况下,预先输入指令,模拟的场景为使用expect命令捕捉到提示输入指令的文字,一旦文字出现,自动使用send命令输入须要交互的命令。

  此处使用为:

  expect "*password:"#此处填写系统提示文字
  send "your password\r"#此处填写咱们输入的交互命令
  expect eof
相关文章
相关标签/搜索