每天解析一个脚本(九)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 【4月更文挑战第17天】shell脚本解析及训练(九)

在信息化浪潮席卷全球的当下,数字化转型已成为各行各业的核心驱动力,而作为这一进程守护者的运维工作,其重要性与日俱增。面对瞬息万变的IT环境,复杂多元的系统架构,以及日益严苛的服务质量要求,高效的自动化工具与脚本已成为运维人员提升工作效率、确保系统稳定性不可或缺的“秘密武器”。有鉴于此,我倾力编撰了这份精心筛选与整理的Shell脚本合集,旨在为广大的运维同行献上一份诚意满满的“运维人福利”,助您在应对日常运维挑战时如虎添翼,从容不迫。

这份脚本合集,犹如一座蕴藏着丰富矿藏的知识宝库,凝结了我在实战运维工作中积累的点滴智慧与宝贵经验。它深度聚焦服务器监控、故障排查、数据备份与恢复、性能调优、自动化部署等运维核心领域,旨在为每一位身处其中的专业人士提供全方位的支持。无论是初涉运维领域的新人,渴望快速掌握实战技巧,还是久经沙场的资深专家,寻求优化现有流程、提升运维效能的新思路,都能在这份合集中找寻到契合自身需求的解决方案。

每一款脚本均经过真实业务场景的反复打磨与严格测试,秉持着简洁高效、易于理解和使用的理念设计。它们不仅具备高度的灵活性与适应性,能够轻松应对各种复杂运维环境下的多样化需求,而且注释详尽,逻辑清晰,旨在成为您日常工作中随时查阅、快速上手的实用指南。无论是自动化执行例行任务,迅速响应突发事件,还是深入挖掘系统瓶颈,优化资源分配,这些脚本都将化身为您的得力助手,使繁复的运维工作变得有条不紊,事半功倍。

我热忱欢迎所有运维同仁自由取阅、广泛分享这份宝贵的Shell脚本资源,将其融入个人的工作实践中,或是作为团队协作、技能培训的参考资料。它们不仅是提升个人技能、优化工作流程的有效工具,更是增进同行间技术交流、知识共享的优质载体。让我们携手共进,充分运用这份脚本合集所蕴含的技术力量,积极推动运维工作的智能化、自动化进程,共同为构建稳定、高效、可靠的信息化系统保驾护航,为企业的数字化转型之路奠定坚实基础。在这个瞬息万变的数字化时代,让我们以匠心独运的运维智慧,驾驭科技之舟,破浪前行,共创辉煌!

今天我们要分析的是:

MySQL 数据库备份单循环

#!/bin/bash

DATE=$(date +%F_%H-%M-%S)

HOST=localhost

USER=backup

PASS=123.com

BACKUP_DIR=/data/db_backup

DB_LIST=$(mysql -h$HOST -u$USER -p$PASS -s -e "show databases;" 2>/dev/null

|egrep -v "Database|information_schema|mysql|performance_schema|sys")

for DB in $DB_LIST; do

BACKUP_NAME=$BACKUP_DIR/${DB}_${DATE}.sql

if ! mysqldump -h$HOST -u$USER -p$PASS -B $DB > $BACKUP_NAME 2>/dev/null;

then

echo "$BACKUP_NAME 备份失败!"

fi

done

脚本实现过程:

  1. 获取当前日期时间:
  • 使用date +%F_%H-%M-%S命令获取当前日期(格式:年-月-日)和时间(格式:时-分-秒),并将其赋值给变量DATE
  1. 设置数据库连接信息:
  • HOST: 指定MySQL服务器的主机名或IP地址,这里为localhost
  • USER: 设置用于备份的MySQL用户名,这里是backup
  • PASS: 设置对应的用户密码,这里是123.com
  1. 定义备份目录:
  • BACKUP_DIR: 设置备份文件的存储路径,这里是/data/db_backup
  1. 获取待备份数据库列表:
  • 使用mysql命令连接到MySQL服务器,执行show databases;命令列出所有数据库。
  • 通过管道(|)将输出传递给egrep命令,过滤掉不需要备份的系统数据库(Database|information_schema|mysql|performance_schema|sys)。
  • 存储过滤后的数据库列表到变量DB_LIST
  1. 循环备份数据库:
  • 对于DB_LIST中的每个数据库(DB):
  • 构造备份文件名:${BACKUP_DIR}/${DB}_${DATE}.sql,即在备份目录下,以数据库名和当前日期时间命名备份文件。
  • 使用mysqldump命令进行全库备份:
  • 参数-h$HOST-u$USER-p$PASS指定连接MySQL服务器的主机、用户名和密码。
  • 参数-B $DB指定要备份的数据库。
  • 输出重定向(>)到备份文件,错误输出(2>/dev/null)丢弃,以保持日志整洁。
  • 如果mysqldump命令执行失败(返回非零状态码),则输出备份失败的提示信息。

如何使用:

  1. 确认权限与配置:
  • 确保执行脚本的用户具有执行mysqldump命令的权限,并能访问MySQL服务器(通过HOSTUSERPASS)以及写入备份目录(BACKUP_DIR)。
  • 如有必要,修改脚本中的数据库连接信息和备份目录,使之符合您的实际环境。
  1. 执行备份脚本:
  • 给脚本赋予执行权限:chmod +x backup_script.sh
  • 运行脚本:./backup_script.sh
  1. 检查备份结果:
  • 在备份目录/data/db_backup下查看是否有以数据库名和日期时间命名的.sql文件生成,确认备份是否成功。
  1. 自动化备份:
  • 若要让脚本定期自动执行,可以将其添加到系统定时任务中,例如使用crontab
  • 打开定时任务编辑器:crontab -e
  • 添加一行,指定每天某一时刻(例如每天凌晨2点)执行备份脚本:
  • Code
10 2 * * * /path/to/backup_script.sh
  • 保存并退出编辑器,定时任务即设置完成。

定期备份指定MySQL服务器上的非系统数据库,并将备份文件按日期存储在指定目录。在备份过程中,脚本会自动记录并报告任何备份失败的情况。

如果想上手操作练代码的同学们可以通过阿里云ecs服务器免费试用参与!

入口:新老同学免费试用

目录
相关文章
|
2月前
|
设计模式 存储 人工智能
深度解析Unity游戏开发:从零构建可扩展与可维护的游戏架构,让你的游戏项目在模块化设计、脚本对象运用及状态模式处理中焕发新生,实现高效迭代与团队协作的完美平衡之路
【9月更文挑战第1天】游戏开发中的架构设计是项目成功的关键。良好的架构能提升开发效率并确保项目的长期可维护性和可扩展性。在使用Unity引擎时,合理的架构尤为重要。本文探讨了如何在Unity中实现可扩展且易维护的游戏架构,包括模块化设计、使用脚本对象管理数据、应用设计模式(如状态模式)及采用MVC/MVVM架构模式。通过这些方法,可以显著提高开发效率和游戏质量。例如,模块化设计将游戏拆分为独立模块。
160 3
|
3月前
|
XML Web App开发 数据挖掘
Postman接口测试工具全解析:功能、脚本编写及优缺点探讨
文章详细分析了Postman接口测试工具的功能、脚本编写、使用场景以及优缺点,强调了其在接口自动化测试中的强大能力,同时指出了其在性能分析方面的不足,并建议根据项目需求和个人偏好选择合适的接口测试工具。
101 1
|
3月前
|
Java Shell Linux
【Linux入门技巧】新员工必看:用Shell脚本轻松解析应用服务日志
关于如何使用Shell脚本来解析Linux系统中的应用服务日志,提供了脚本实现的详细步骤和技巧,以及一些Shell编程的技能扩展。
49 0
【Linux入门技巧】新员工必看:用Shell脚本轻松解析应用服务日志
|
5月前
|
缓存 监控 安全
深入解析Elasticsearch中脚本原理
深入解析Elasticsearch中脚本原理
|
6月前
|
弹性计算 运维 Shell
每天解析一个shell脚本(75)
【4月更文挑战第28天】shell脚本解析及训练(75)
39 7
|
6月前
|
弹性计算 运维 Shell
每天解析一个shell脚本(76)
【4月更文挑战第28天】shell脚本解析及训练(76)
35 4
|
6月前
|
弹性计算 Shell Apache
每天解析一个shell脚本(78)
【4月更文挑战第28天】shell脚本解析及训练(78)
29 3
|
6月前
|
弹性计算 运维 Shell
每天解析一个shell脚本(83)
【4月更文挑战第28天】shell脚本解析及训练(83)
23 2
|
6月前
|
弹性计算 运维 Shell
每天解析一个shell脚本(81)
【4月更文挑战第28天】shell脚本解析及训练(81)
37 1

推荐镜像

更多