每天解析一个脚本(八)

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: 【4月更文挑战第16天】shell脚本解析及训练(八)

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

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

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

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

今天我们要分析的是:

每天自动备份 MySQL 数据库

#!/bin/sh

# Database info

DB_USER="batsing"

DB_PASS="batsingpw"

DB_HOST="localhost"

DB_NAME="timepusher"

# 一些变量

BIN_DIR="/usr/bin" #mysql bin路径

BCK_DIR="/mnt/mysqlBackup" #备份文件目录

DATE=`date +%F`

# TODO

# /usr/bin/mysqldump --opt -ubatsing -pbatsingpw -hlocalhost timepusher >

/mnt/mysqlBackup/db_`date +%F`.sql

$BIN_DIR/mysqldump --opt -u$DB_USER -p$DB_PASS -h$DB_HOST $DB_NAME >

$BCK_DIR/db_$DATE.sql

#还原数据库

#用mysql-front导入前一天的 *.sql 文件即可恢复数据

脚本实现过程:

  1. 定义数据库信息:
  • DB_USER:设置备份数据库的用户名,这里是batsing
  • DB_PASS:设置对应的用户密码,这里是batsingpw
  • DB_HOST:数据库所在的主机地址,这里为本地服务器localhost
  • DB_NAME:要备份的数据库名称,这里是timepusher
  1. 设置相关路径与变量:
  • BIN_DIR:指定了MySQL工具(如mysqldump)的路径,这里是/usr/bin
  • BCK_DIR:定义了备份文件的存放目录,这里是/mnt/mysqlBackup
  • DATE:使用date +%F命令获取当前日期,格式为YYYY-MM-DD
  1. 执行数据库备份:
  • 使用mysqldump命令,结合--opt选项(优化备份过程),以指定的用户名、密码、主机和数据库名进行备份。
  • 备份结果以db_加当前日期($DATE)的形式命名,存储在$BCK_DIR目录下。

如何使用:

  1. 权限与执行:
  • 确保执行此脚本的用户具有足够的权限访问MySQL数据库(通过DB_USERDB_PASS)以及写入备份目录(BCK_DIR)。
  • 赋予脚本执行权限:chmod +x backup_script.sh
  1. 手动运行脚本:
  • 执行备份脚本:./backup_script.sh
  1. 自动化备份:
  • 若要让脚本每天自动运行,可以将其添加到系统定时任务中,例如使用crontab
  • 打开定时任务编辑器:crontab -e
  • 添加一行,指定每天某一时刻(例如每天凌晨2点)执行备份脚本:
  • Code
10 2 * * * /path/to/backup_script.sh
  • 保存并退出编辑器,定时任务即设置完成。
  1. 数据库还原:
  • 注意: 这部分仅在脚本注释中提到,未实际编写在脚本中。
  • 若要恢复数据,需找到前一天备份的.sql文件(例如db_2024-04-17.sql)。
  • 使用MySQL客户端(如mysql命令行工具)或者数据库管理软件(如MySQL-Front)将备份文件导入目标数据库。

通过mysqldump工具备份指定的MySQL数据库,并将备份文件保存到指定位置。可以手动或通过定时任务执行该脚本来定期备份数据库。在需要时,可以通过导入备份文件的方式还原数据。

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

入口:新老同学免费试用

目录
相关文章
|
4天前
|
弹性计算 运维 监控
每天解析一个脚本(53)
【4月更文挑战第26天】shell脚本解析及训练(53)
20 5
|
5天前
|
存储 运维 监控
每天解析一个脚本(37)
【4月更文挑战第25天】shell脚本解析及训练(37)
13 1
|
8天前
|
存储 弹性计算 运维
每天解析一个脚本(25)
【4月更文挑战第22天】shell脚本解析及训练(25)
28 0
|
8天前
|
存储 运维 Shell
每天解析一个脚本(16)
【4月更文挑战第20天】shell脚本解析及训练(16)
18 2
|
4天前
|
弹性计算 运维 监控
每天解析一个脚本(51)
【4月更文挑战第26天】shell脚本解析及训练(51)
15 4
|
4天前
|
存储 弹性计算 运维
每天解析一个脚本(49)
【4月更文挑战第26天】shell脚本解析及训练(49)
23 6
|
5天前
|
存储 运维 关系型数据库
每天解析一个脚本(39)
【4月更文挑战第25天】shell脚本解析及训练(39)
7 0
|
5天前
|
运维 监控 Shell
每天解析一个脚本(44)
【4月更文挑战第25天】shell脚本解析及训练(44)
8 0
|
6天前
|
JSON 运维 机器人
每天解析一个脚本(35)
【4月更文挑战第24天】shell脚本解析及训练(35)
6 1
|
6天前
|
存储 运维 网络协议
每天解析一个脚本(34)
【4月更文挑战第24天】shell脚本解析及训练(34)
13 1