mysql数据库备份
前一段时间因为误操作删除了一张表的几条数据,弄得很尴尬,正好这周有空就折腾了下数据备份的知识,现把mysql的数据备份相关实践和心得总结如下:
一.使用mysqldump命令备份数据库:
备份整个数据库(包括表结构和数据),用法如下
mysqldump -h10.38.14.143 -uroot -prootroot weixin > weixin.sql
其中 weixin 是数据库名,可以一次备份多个数据库 (用空格隔开),默认保存在当前目录下
这个wexin.sql文件里面主要由四部分组成:数据库及操作系统的信息、表结构、具体的数据(实际上是insert语句)、锁表以及释放表的命令语句




补充:
1.读锁定:本人和其他人只能读取数据库
写锁定:只有本人能进行增删改查,其他人不能进行任何操作
2.有时用mysqldump命令会提示没权限去操作数据库相关的提示语 如 mysqldump: Got error: 1044: Access denied for user 'php'@'10.38.%' to database 'cms_fgw' when using LOCK TABLES
这是因为mysql数据库限制了远程服务器对他的相关操作,请和DBA沟通开放权限(主要是执行下面类似的命令去授权)
grant all privileges on *.* to 'root'@'%' identified by '123456' with grant option;
flush privileges;
3.如若忘记mysql命令的一些用法可以多多使用?操作,相当于man帮助,这个很有用,如下

4.用mysqldump也可以只备份表结构,用法如下
mysqldump -h10.38.14.143 -uroot -prootroot --no-data --databases weixin cjdaily > /tmp/table_structure.sql
table_structure.sql中的部内容如下

5.可以根据mysqldump命令进行一些扩展写一个备份数据库的shell脚本,如下是根据我们自己的需求写的一个脚本(shell脚本的具体语法就不讲了)
#!/bin/bash
#backup database
if [ $# -ge 1 ] ; then
databaselist=$@
else
databaselist="cjdaily cms_rmrb guangzhou pladaily"
fi
for database in $databaselist
do
if [ ! -e /home/pengyudi/backup_databases/$database ]
then
mkdir -p /home/pengyudi/backup_databases/$database
fi
mysqldump --opt -h10.38.10.5 -uchen -pab#@c-123 $database |gzip > /home/pengyudi/backup_databases/$database/$database$(date +"%Y-%m-%d %H:%M:%S").sql.gz
if [ $? -eq 0 ]
then
echo "$(date +"%Y-%m-%d %H:%M:%S") Database ---$database--- Backup Successfully \r\n"
find /home/pengyudi/backup_databases/$database/ -name $database\* -ctime +1 -exec rm -rf {} \;
else
echo "$(date +"%Y-%m-%d %H:%M:%S") Database ---$database--- Backup unsuccessfully,please check out the reason\r\n"
fi
done
6.备份某台主机上的所有数据库 mysqldump --opt -h10.38.10.5 -uchenliangliagasd -pabcdeqasdadfa -1238 --all-databases> test.dump
二.数据的恢复
1.切换到mysql的工作环境
use test;
source /tmp/table_structure.sql ;
2.不切换到mysql环境
/usr/bin/mysql -h192.168.4.47 -um_bbs_test_admin -P3309 -p89603d5a test</tmp/table_structure.sql ; (注意得指定具体的数据库)
三.使用load导入数据 和select **** from tabelName into outfile 'file_name'的方式导出数据



补充
1.注意保存数据的文件要打引号以及保存数据的文件路径,要特别留意一些细节,如上,确实很容易出错
select * from weixin_data_rmrb into outfile 'weixin_outfile.sql';
2.使用技巧:
当用load命令导入数据时可以通过适当数据提高导入速度,对于MyISAM储存引擎的表
(1)可以通过以下方式快速导入大量数据(disable keys 和enable keys 可以用来打开或关闭非唯一索引的更新,提高导入速度,但是对InnoDB表无效)
alter table weixin_data_rmrb disable keys
load data infile 'weixin_outfile.sql' into table weixin_data_rmrb
alter table weixin_data_rmrb enable keys
(2)关闭唯一性校验可以提高导入速度
在导入数据前后分别执行 set unique_checks=0(关闭唯一性校验) 和 set unique_checks=1来提高导入速度
对于Innodb表可以使用一下方式提高导入速度:
(1)将导入的数据按照主键的顺序排列,可以提高导入速度,因为Innodb表是按照主键顺序保存的
(2)在导入之前执行set autocommit=0关闭自动提交事物,导入结束后执行set autocommit=1回复自动提交事物
四.使用二进制日志恢复数据
1.开启binlog日志
修改/etc/my.cnf配置文件
vim /etc/my.cnf
在[mysqld]下面添加如下两行用于开启及设置binlog日志的保存路径
log-bin=/home/logs/mysql/mysql-bin #记得要修改权限,不然mysql无法启动; mysql-bin为日志文件的名称的组成部分(mysql-bin.000001)
binlog_format=mixed
log=/home/logs/mysql/mysql.log
保存退出
chown mysql.mysql /home/logs/mysql -R #修改目录权限

其中mysql-bin.index记录了生成了哪些二进制日志文件

另外跟日志相关的参数:
expire_logs_days = 7 #保留七天的日志
slow-query-log = on #开启慢查询
slow_query_log_file = /home/logs/mysql/slow.log #慢查询日志保存路径
long_query_time = 1 #慢查询的时间,超过一秒的记录下来
log-queries-not-using-indexes = on #记录没用使用到索引的SQL语句
修改配置后重启mysql:service mysqld restart
进入到mysql命令界面查看二进制日志相关信息:
show variables like "%bin%"

2.与binlog日志有关的命令
flush logs: 执行完之后在存放binlog日志的目录下多一个最新的binlog日志文件
show master status 查看最后一个bin日志
reset master 清空所有的binlog日志
通过binlog日志恢复到某一个日志文件的操作命令:
/usr/bin/mysqlbinlog --no-defaults -f /home/logs/mysql/mysql-bin.000008| mysql -h10.38.14.143 -uroot -prootroot
查看某个binlog日志命令: /usr/bin/mysqlbinlog --no-defaults -f /home/logs/mysql/mysql-bin.000008
说明:可以根据需要恢复到某一个点的数据,mysqlbinlog后面的主要参数有:
--stop-position="120"
--start-positon="20"
--stop-date="2016-11-19 18:50:42"
--start-date="2016-11-19 18:30:21"
友情链接:
binlog详细的操作例子请参考如下博客:
http://blog.chinaunix.net/uid-20494084-id-3753682.html
mysql5.7官方文档地址http://dev.mysql.com/doc/refman/5.7/en/preface.html
mysql数据库备份的更多相关文章
- Xtrabackup原理及使用innobackupex进行MySQL数据库备份恢复
Xtrabackup是由percona提供的mysql数据库备份工具,据官方介绍,这也是世界上惟一一款开源的能够对innodb和xtradb数据库进行热备的工具. Xtrabackup中主要包含两个工 ...
- TODO:MongoDB MySQL数据库备份
TODO:MongoDB MySQL数据库备份 1. MongoDB使用命令备份 mongodump进行整个数据库备份,主要用到的命令参数: -d 要备份的数据库 -o 输出的路径 ./mongodu ...
- Java实现MySQL数据库备份(二)
权声明:本文为博主原创文章,未经博主允许不得转载. 博客<Java实现MySQL数据库备份(一)>使用I/O流的方式实现了MySQL数据库的备份,这种方法比较繁杂,下面介绍另一种备份MyS ...
- Java实现MySQL数据库备份(一)
下班了,利用闲暇时间总结一下如何使用Java语言实现MySQL数据库备份: import java.io.BufferedReader; import java.io.File; import jav ...
- MySQL数据库备份命令
原文参考:MySQL数据库备份的命令 - 司南 mysqldump -hhostname -uusername -ppassword databasename > backupfile.sql备 ...
- MySQL数据库备份和还原的常用命令
其实很多情况下mysql备份就是采用了这些命令,例如: mysql导入和导出数据 linux自动定时备份web程序和mysql数据库 备份MySQL数据库的命令 mysqldump -hhostnam ...
- Java实现mysql数据库备份
Runtime是一个与JVM运行时环境有关的类,这个类是Singleton的. Runtime.getRuntime()可以取得当前JVM的运行时环境,这也是在Java中唯一一个得到运行时环境的方法. ...
- Mysql数据库备份和还原常用的命令
Mysql数据库备份和还原常用的命令是进行Mysql数据库备份和还原的关键,没有命令,什么都无从做起,更谈不上什么备份还原,只有给系统这个命令,让它去执行,才能完成Mysql数据库备份和还原的操作,下 ...
- MySQL数据库备份还原(基于binlog的增量备份)
MySQL数据库备份还原(基于binlog的增量备份) 一.简介 1.增量备份 增量备份 是指在一次全备份或上一次增量备份后,以后每次的备份只需备份与前一次相比增加或者被修改的文件.这就意味 ...
- Mysql数据库备份和按条件导出表数据
Mysql数据库备份和按条件导出表数据 一.备份数据库 # mysqldump -u root -p dbcurr>/home/20090219.sql mysqldum为备份命令,- ...
随机推荐
- 向上滚动或者向下滚动分页异步加载数据(Ajax + lazyload)[上拉加载组件]
/**** desc : 分页异步获取列表数据,页面向上滚动时候加载前面页码,向下滚动时加载后面页码 ajaxdata_url ajax异步的URL 如data.php page_val_name a ...
- Asp.Net WebApi开发注意
1.Api的版本控制 2.Api的异常处理 设置全局异常处理 3.Api的权限控制 4.Api的请求处理 get:查询 post:创建 put:修改 delete:删除 5.Api的文档说明
- 树形DP+DFS序+树状数组 HDOJ 5293 Tree chain problem(树链问题)
题目链接 题意: 有n个点的一棵树.其中树上有m条已知的链,每条链有一个权值.从中选出任意个不相交的链使得链的权值和最大. 思路: 树形DP.设dp[i]表示i的子树下的最优权值和,sum[i]表示不 ...
- 树链剖分+线段树 HDOJ 5029 Relief grain(分配粮食)
题目链接 题意: 分粮食我就当成涂色了.有n个点的一棵树,在a到b的路上都涂上c颜色,颜色可重复叠加,问最后每一个点的最大颜色数量的颜色类型. 思路: 首先这题的输出是每一个点最后的情况,考虑离线做法 ...
- 2016-2017 ACM-ICPC Southwestern European Regional Programming Contest (SWERC 2016)
A. Within Arm's Reach 留坑. B. Bribing Eve 枚举经过$1$号点的所有直线,统计直线右侧的点数,旋转卡壳即可. 时间复杂度$O(n\log n)$. #includ ...
- [VijosP1764]Dual Matrices 题解
题目大意: 一个N行M列的二维矩阵,矩阵的每个位置上是一个绝对值不超过1000的整数.你需要找到两个不相交的A*B的连续子矩形,使得这两个矩形包含的元素之和尽量大. 思路: 预处理,n2时间算出每个点 ...
- T-SQL Recipes之Organizing and Archiving Data
The Problem 当我们处理存档数据或内存数据时,我们想要自定义命名表名,数据库,架构加上日期,时间,或者应用名时,用标准的TSQL来实现是比较困难的. 假设我们有一张日志表,增长速度异常快.但 ...
- 数论 - Moon Game
Fat brother and Maze are playing a kind of special (hentai) game in the clearly blue sky which we ca ...
- HTML解析器HtmlAgilityPack的一些使用总结(C#)
哎~本来这些总结是作为使用时的快速备注,但是用不上了.实际应用当中HtmlAgilityPack的可靠性不太稳定,一主要问题是:-> 一些字符会出现乱码或者变成'?',如韩语字符.由于我是已经有 ...
- UVA103 dp基础题,DAG模型
1.UVA103 嵌套n维空间 DAG模型记忆化搜索,或者 最长上升子序列. 2.dp[i]=max( dp[j]+1),(第i个小于第j个) (1) //DAG模型记忆化搜索 #include< ...