mysql如何设置定时自动备份脚本_编写shell脚本与cron任务

必须加--single-transaction(InnoDB)或--lock-all-tables(MyISAM),并搭配--routines--triggers--events、--default-character-set=utf8mb4,密码通过~/.my.cnf(chmod 600)或MYSQL_PWD安全传入,脚本需设PATH、用绝对路径、写全备份路径、重定向stderr,文件按日期命名并用find清理。mysql dump 命令怎么写才不丢数据直接用 mysqldump 默认参数备份,很可能漏掉视图、存储过程、触发器,甚至在有长事务时导致备份不一致。关键不是"能不能导出",而是"导出的能不能原样恢复"。必须加 --single-transaction(InnoDB 表适用),避免锁表又保证一致性;MyISAM 表得用 --lock-all-tables,别混用加上 --routines --triggers --events,否则存储过程和事件不会进备份文件显式指定字符集,比如 --default-character-set=utf8mb4,防止乱码或导入失败不要省略 -h、-P、-u、-p 参数------尤其是 -p 后面**不要直接跟密码**(会暴露在进程列表里),改用配置文件或 MYSQL_PWD 环境变量shell 脚本里怎么安全存数据库密码把密码写死在脚本里等于公开给所有能看 ps aux 的人。Linux 下最稳妥的方式是用 MySQL 的 ~/.my.cnf 配置文件,但权限必须设成 600,否则 mysqldump 会拒绝读取。创建 ~/.my.cnf,内容:[client]host=localhostuser=backup_userpassword=your_real_passwordport=3306立刻执行 chmod 600 ~/.my.cnf,否则脚本运行时会报错:Warning: World-writable config file '/home/user/.my.cnf' is ignored脚本里调用就简化为:mysqldump --single-transaction --routines db_name > backup.sql,不用再传用户密码如果必须用环境变量(比如容器场景),用 MYSQL_PWD=xxx mysqldump ...,但确保该变量不在历史记录或日志中输出cron 执行备份脚本为什么总失败cron 环境非常干净:没有你的 shell profile、没有 PATH、没有当前工作目录保障。脚本在终端能跑,放进 crontab 就报 command not found 或 No such file or directory 是常态。 Fotor AI Image Generator Fotor 平台的 AI 图片生成器

相关推荐
灵犀学长22 分钟前
基于 Spring ThreadPoolTaskScheduler + CronTrigger 实现的动态定时任务调度系统
java·数据库·spring
北秋,42 分钟前
PostgreSQL(Postgres)数据库基础用法 + 数字型 + 字符型 完整联合注入实战
数据库·postgresql·开源
woniu_buhui_fei1 小时前
JVM编译器
jvm
南 阳1 小时前
Python从入门到精通day66
开发语言·python
m0_596749091 小时前
JavaScript中手动实现一个new操作符的底层逻辑
jvm·数据库·python
多加点辣也没关系1 小时前
Redis 的安装(详细教程)
数据库·redis·缓存
DTAS尺寸公差分析软件2 小时前
DTAS3D v13.0 三维尺寸公差分析软件可申请试用
python·尺寸公差分析·三维公差分析·公差仿真软件·尺寸链计算
DTAS尺寸公差分析软件2 小时前
DTAS 3D公差分析软件最新版本介绍
python·3d·尺寸公差分析·尺寸链计算·尺寸工程·尺寸链校核软件·公差仿真分析
PieroPc2 小时前
CAMWATCH — 局域网摄像头监控系统 Fastapi + html
前端·python·html·fastapi·监控
feasibility.2 小时前
反爬十层妖塔:现代爬虫攻防的立体战争
爬虫·python·科技·scrapy·rust·go·硬件