linux下手动备份mysql以及定时备份mysql

一,数据库的备份与导入

1),数据库的备份

1.导出整个数据库
mysqldump -u 用户名 -p 数据库名 > 导出的文件名
例:mysqldump -u dbadmin -p myblog > /home/zhangy/blog/database_bak/myblog.sql

2.导出一个表
mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名
例:mysqldump -u dbadmin -p myblog wp_users> /home/zhangy/blog/database_bak/blog_users.sql

3.导出一个数据库结构
mysqldump -u dbadmin -p -d --add-drop-table myblog > /home/zhangy/blog/database_bak/blog_struc.sql
说明:-d 没有数据 --add-drop-table 在每个create语句之前增加一个drop table

4.导出数据库一个表结构
mysqldump -u dbadmin -p -d --add-drop-table myblog  wp_users> /home/zhangy/blog/database_bak/blog_users_struc.sql
说明:-d 没有数据 --add-drop-table 在每个create语句之前增加一个drop table

 

2),数据库的导入

1,用 mysqldump 备份出来的文件是一个可以直接倒入的 SQL 脚本,有两种方法可以将数据导入。
例如:
#/usr/local/mysql/bin/mysql -u root -p *****  myblog   < /home/zhangy/blog/database_bak/myblog.sql

这种方法,我以前经常现在很少用了,因为很容易产生乱码,因为:

a,导出数据库时,你如果忘了设置导出字符集的话,在导入的时候,就有可能会出问题.

b,假如,你导出时设置导出时设置了utf8的编码,但是你又把你的数据库现在的字符集改成了gb2312的.这样又会乱码。

2,用 source 语句
例如:

mysql -u dbadmin -p

use myblog;

set names utf8;  #这里的字符集根你的将要导入的数据库的字符集一至。

source /home/zhangy/blog/database_bak/myblog.sql;


二、mysql定时备份

定时备份需利用liunx的crontab命令,如果服务器缺少此命令,可参考此文章安装:Linux Crontab 安装使用详细说明

第一步:

crontab -e

00 3 * * * root sh /home/data/dbbackup.sh
表示每天3点00分执行脚本dbbackup.sh备份所有数据库

第二步:

vi /etc/crontab


SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
HOME=/

# For details see man 4 crontabs

# Example of job definition:
# .---------------- minute (0 - 59)
# |  .------------- hour (0 - 23)
# |  |  .---------- day of month (1 - 31)
# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# |  |  |  |  |
# *  *  *  *  * user-name command to be executed
#表示每天3点00分执行备份
00 3 * * * root sh /home/data/dbbackup.sh

00 3 * * *:执行的任务周期

root:执行的用户

sh /home/data/dbbackup.sh:执行脚本


dbbackup.sh脚本:

#!/bin/sh
day_1_befor=$(date -d "1 day ago" '+%Y%m%d')
DST_PATH="/home/data/dbbackup"
mysqldump -uroot -proot --events --ignore-table=mysql.events --all-databases | gzip > $DST_PATH/db_lst_center_cm_geli_$day_1_befor.gz
mysqldump -uroot -proot --events --ignore-table=mysql.events --all-databases > $DST_PATH/db_lst_center_cm_geli_$day_1_befor.sql
find $DST_PATH -name "db_lst_center_cm_geli_*.sql" -type f -mtime +7 -exec rm -rf {} \; > /dev/null 2>&1
find $DST_PATH -name "db_lst_center_cm_geli_*.gz" -type f -mtime +7 -exec rm -rf {} \; > /dev/null 2>&1

设置时可以通过设置较短的周期来测试定时任务是否能够运行。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值