热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Linux下MySQL自动备份脚本

为什么80%的码农都做不了架构师?源码mysqlDump.sh#!binbash#######################################

为什么80%的码农都做不了架构师?>>>   hot3.png

源码 mysqlDump.sh

#!/bin/bash
################################################
# TODO: 备份当前服务器上指定的数据库(多个库,以 , 分隔)
# 示例:
# ./mysqlDump.sh 备份默认设置的数据库
# ./mysqlDump.sh db_name1,db_name2,... 备份指定名称的数据库
#
# Author: whoru.S.Q
# Version: 1.0
################################################# 数据库连接参数
DB_HOST="127.0.0.1"
DB_USER="root"
DB_PWD=""
DB_PORT="3306"# 待备份的数据库名称,多个库时以 , 分隔
DB_NAME=# 备份文件路径
DUMP_FILE_PATH=/opt/backupfunction main {# 参数检查# 如果当前脚本在执行时传递了参数,则优先级高于当前脚本文件中变量的默认设置if [ -n "$1" ]; thenDB_NAME=$1elseif [ ! "$DB_NAME" ]; thenread -p "请输入要备份的数据库名称:" dbnameDB_NAME=$dbnamefifi# 检查备份目录是否存在if [ ! -d "$DUMP_FILE_PATH" ]; thenmkdir -p $DUMP_FILE_PATHif [ "$?" -ne "0" ]; thenecho -en "无法创建备份文件目录:$DUMP_FILE_PATH"exit 1fifi# 操作开始OLD_IFS="$IFS"IFS=","arr=($DB_NAME)IFS="$OLD_IFS"for db in ${arr[@]}do# echo "$db"doDump $dbdone
}function doDump {echo -en "\n\033[32m==>\033[0m 开始备份数据库:$1\n"dump_date=`date +%Y%m%d%H%M%S`dump_file=$1"_"$dump_date".sql"final_dump_file=$dump_file".tar.gz"# 备份# 考虑还原数据库时的通用性,备份的同时不执行压缩操作$(which mysqldump) -u$DB_USER -p$DB_PWD -P $DB_PORT $DB_NAME > $dump_fileif [ "$?" -ne "0" ]; thenecho -en "操作失败"exit 1fi# 压缩、转移备份的文件tar -zcvf $final_dump_file $dump_filemv $final_dump_file $DUMP_FILE_PATHrm -rf $dump_fileecho -en "\n\033[32m==>\033[0m 备份完成,生成备份文件:$DUMP_FILE_PATH/$final_dump_file\n"
}# 运行
main $1

使用说明

  1. 使用前先设置数据库连接参数

  2. 设置待备份的数据库名称

    • 方式一:在脚本文件里修改变量 DB_NAME
    • 方式二:运行脚本时动态传参,如 ./mysqlDump.sh db_name

    注意:脚本运行参数优先级高于脚本文件中的设置;待备份的数据库名称支持多个,以 , 分隔。

示例

[root@local wwwroot]# ./mysqlDump.sh online_v3.0==> 开始备份数据库:online_v3.0
Warning: Using a password on the command line interface can be insecure.
online_v3.0_20181012164400.sql==> 备份完成,生成备份文件:/opt/backup/online_v3.0_20181012164400.sql.tar.gz


更新:https://github.com/whorusq/linux-learning/blob/master/shell/mysqlDump.sh


转:https://my.oschina.net/antsky/blog/2244809



推荐阅读
  • Docker安全策略与管理
    本文探讨了Docker的安全挑战、核心安全特性及其管理策略,旨在帮助读者深入理解Docker安全机制,并提供实用的安全管理建议。 ... [详细]
  • 软件测试行业深度解析:迈向高薪的必经之路
    本文深入探讨了软件测试行业的发展现状及未来趋势,旨在帮助有志于在该领域取得高薪的技术人员明确职业方向和发展路径。 ... [详细]
  • 本文详细介绍如何在华为鲲鹏平台上构建和使用适配ARM架构的Redis Docker镜像,解决常见错误并提供优化建议。 ... [详细]
  • 如何在U8系统中连接服务器并获取数据
    本文介绍了如何在U8系统中通过不同的方法连接服务器并获取数据,包括使用MySQL客户端连接实例的方法,如非SSL连接和SSL连接,并提供了详细的步骤和注意事项。 ... [详细]
  • 本文回顾了作者在求职阿里和腾讯实习生过程中,从最初的迷茫到最后成功获得Offer的心路历程。文中不仅分享了个人的面试经历,还提供了宝贵的面试准备建议和技巧。 ... [详细]
  • 本文详细介绍了在 Red Hat Linux 系统上安装 GCC 4.4.2 的步骤,包括必要的依赖库的安装及常见问题的解决方法。 ... [详细]
  • 对于初学者而言,搭建一个高效稳定的 Python 开发环境是入门的关键一步。本文将详细介绍如何利用 Anaconda 和 Jupyter Notebook 来构建一个既易于管理又功能强大的开发环境。 ... [详细]
  • 本文介绍了SIP(Session Initiation Protocol,会话发起协议)的基本概念、功能、消息格式及其实现机制。SIP是一种在IP网络上用于建立、管理和终止多媒体通信会话的应用层协议。 ... [详细]
  • 我的读书清单(持续更新)201705311.《一千零一夜》2006(四五年级)2.《中华上下五千年》2008(初一)3.《鲁滨孙漂流记》2008(初二)4.《钢铁是怎样炼成的》20 ... [详细]
  • CentOS下ProFTPD的安装与配置指南
    本文详细介绍在CentOS操作系统上安装和配置ProFTPD服务的方法,包括基本配置、安全设置及高级功能的启用。 ... [详细]
  • 从理想主义者的内心深处萌发的技术信仰,推动了云原生技术在全球范围内的快速发展。本文将带你深入了解阿里巴巴在开源领域的贡献与成就。 ... [详细]
  • Jupyter Notebook多语言环境搭建指南
    本文详细介绍了如何在Linux环境下为Jupyter Notebook配置Python、Python3、R及Go四种编程语言的环境,包括必要的软件安装和配置步骤。 ... [详细]
  • 本文详细介绍了在Linux操作系统上安装和部署MySQL数据库的过程,包括必要的环境准备、安装步骤、配置优化及安全设置等内容。 ... [详细]
  • 本文详细介绍了如何在ARM架构的目标设备上部署SSH服务端,包括必要的软件包下载、交叉编译过程以及最终的服务配置与测试。适合嵌入式开发人员和系统集成工程师参考。 ... [详细]
  • 深入解析:存储技术的演变与发展
    本文探讨了从单机文件系统到分布式文件系统的存储技术发展过程,详细解释了各种存储模型及其特点。 ... [详细]
author-avatar
tanhuixi135_414
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有