shell脚本备份oracle数据库

shell脚本备份oracle数据库代码如下:

1、配置文件:

username=SYSDBA
password=123456
ipStr=192.168.99.164
portNumber=5327
serviceName=orcl
directoryName=data_backup_dir
backupsFileDay=3
expdpStr=/JavaSoft/oracle/product/11.2.0/dbhome_1/BIN/expdp
saveDb=HEBEI,KETTLE,KM

2、代码:

注意:不同linux设备的sh路径可能不同,需通过which sh查看sh的绝对路径修改即可。

#!/bin/sh

#db_backups_conf.txt文件路径
db_backups_conf="/wocloud/shell/oracle_db_backups_conf.txt"

#判断文件是否存在
if [ -f "${db_backups_conf}" ];then
	
	echo $(date +'%Y-%m-%d %H:%M:%S')" 数据库配置信息文件存在,开始进行数据备份"

	#获取等号前内容,作为map中的Key值
	dbArrOne=($(awk -F'[=]' '{print $1}' ${db_backups_conf} ))
	
	#获取等号后内容,作为map中的value值
	dbArrTwo=($(awk -F'[=]' '{print $2}' ${db_backups_conf}))

	#创建一个空map
	declare -A map=()
	
	#通过循环,将db_backups_conf配置文件中的信息存储在map中
	for((i=0;i<${#dbArrOne[@]};i++))
	do
		map[${dbArrOne[i]}]=${dbArrTwo[i]}
	done	

	#获取备份数据库
	saveDbStr=${map["saveDb"]}
	
	#获取默认的字符串分隔符
	old_ifs="$IFS"
	
	#设置字符串分隔符为逗号
	IFS=","

	#将用户名的value值的字符串进行分隔,获取一个数组
	saveDbArr=($saveDbStr)

	#将字符串的分隔符重新设置为默认的分隔符
	IFS="$old_ifs"

	#获取当前年月日
	saveday=$(date +%Y%m%d)

	#获取超出备份天数的年月日
	delday=$(date -d ${map["backupsFileDay"]}' days ago' +%Y%m%d)


	#遍历要备份的用户名,删除两天前备份的数据文件
	for delDb in ${saveDbArr[@]};
	do
		echo $(date +'%Y-%m-%d %H:%M:%S')" 删除文件:"${map["backupsFileStr"]}/${delDb}_database_${delday}.dmp

		rm -f ${map["backupsFileStr"]}/${delDb}_database_${delday}.dmp
	done

	#遍历要备份的数据库,备份数据文件
	for saveDb in ${saveDbArr[@]};
	do
		echo $(date +'%Y-%m-%d %H:%M:%S')" 备份数据库:"${saveDb}
   		${map["expdpStr"]} ${map["username"]}/${map["password"]}@${map["ipStr"]}:${map["portNumber"]}/${map["serviceName"]} schemas=${saveDb} dumpfile=expdp_${saveDb}_database_${saveday}.dmp directory=${map["directoryName"]} logfile=expdp_${saveDb}_database_${saveday}.txt
	done	
	
	echo $(date +'%Y-%m-%d %H:%M:%S')" 数据备份完毕,脚本执行完毕"

else
	echo "文件不存在"
fi

3、配置参数说明:

参数意义如下:
username:dm数据库用户名
password:dm数据库密码
ipStr:数据库所在服务器IP地址
portNumber:端口号
backupsFileStr:备份文件路径
logsFileStr:导出数据库日志文件路径
backupsFileDay保留几天的备份文件
dexpStr:导出工具dexp的路径
saveDb:备份的数据库,多个数据库用逗号隔开

4、使用注意事项:

使用注意事项:
1、默认的是.sh、.txt文件都要放在/woclod/shell脚本下,如果放置的路径变了,需要修改.sh中读取.txt配置文件的路径
2、对于不同的Linux环境下,要修改dm_db_backups_conf.txt文件中的配置信息,比如dexp的路径、脚本头部sh路径等信息;
3、用户密码中不要含有@等关键字符;
4、在使用脚本备份前,oracle数据库先设置好真实目录、逻辑目录、用户授权等工作。

 

你可能感兴趣的:(shell,oracle)