linux下手动备份mysql以及定时备份mysql
2017-03-23 10:21
501 查看
一,数据库的备份与导入
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 安装使用详细说明
第一步:
第二步:
dbbackup.sh脚本:
设置时可以通过设置较短的周期来测试定时任务是否能够运行。
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
设置时可以通过设置较短的周期来测试定时任务是否能够运行。
相关文章推荐
- Linux下MySQL备份以及crontab定时备份
- Linux下MySQL备份以及crontab定时备份
- Linux下MySQL备份以及crontab定时备份
- Linux下MySQL备份以及crontab定时备份
- Linux下MySQL备份以及crontab定时备份(crontab表达式简介)
- Linux下使用crontab对MYSQL进行备份以及定时清
- Linux下MySQL备份以及crontab定时备份
- linux简单的mysql备份和导入,以及文件的备份和导入
- 设置某个ip对mysql服务器有权限,以及mysql定时备份
- linux下定时执行mysql备份
- linux 定时备份mysql
- Linux下mysql定时备份
- linux定时备份Mysql
- Linux下mysql定时自动备份并FTP到远程脚本
- linux 定时自动备份 mysql
- linux 简单的mysql备份和导入,以及文件的备份和导入
- Linux下MySQL定时按日期备份数据
- Linux/Windows 下MySQL定时按日期备份数据
- linux 简单的mysql备份和导入,以及文件的备份和导入
- linux下mysql定时备份数据库