运维工做的核心简单归纳起来就是两件事:第一个是保护公司的数据,第二个是让网站可以7*24小时提供服务。mysql
虽然这两件事情都很重要,可是相比较而言,丢失一部分数据和让网站7*24小时提供服务,哪一个更重要呢?sql
对于绝大多数企业来说,失去数据就至关于失去商机,失去产品,失去客户,甚至会形成公司倒闭,那么,在全部的数据中,最核心的数据又是哪些呢?这恐怕要属数据库中的数据了。既然数据库中的数据地位这么高,那么数据库备份与恢复的重要性就不言而喻了。数据库
MySQL数据库自带了一个很优秀的备份命令,即mysqldump。bash
mysqldump oldboy >/opt/mysql_bak.sql
mysqldump -B oldboy >/opt/mysql_bak_B.sql #B参数的做用是增长建立数据库和链接数据库的语句,可同时备份多个库。
mysqldump -B oldboy|gzip>/opt/mysql_bak_B.gz
利用mysqldump命令备份数据的过程,实际上就是把数据(包括库表)从MySQL库里以SQL语句的形式直接输出或者生成备份文件的过程,这种备份成SQL语句的方式称为逻辑备份。运维
使用mysqldump命令能够把数据库中的数据导出来,并经过SQL语句的形式存储。这种备份方式称为逻辑备份,效率不是很高。在当下的生产场景中,多用于数据量不是很大的备份状况,例如30GB之内的数据。若在数据库数据很大的时候采用此备份方法,则所用的时候就会很长,恢复的时间也会很长,所以,当数据大于30GB后,建议选择其余的诸如Xtrabackup的物理方式进行备份和恢复。网站
mysqldump -B oldboy oldboy_utf8 mysql|gzip>/opt/all.sql.gz
分库备份实际上就是每次只执行一个mysqldump备份命令语句备份一个库,若是数据库里有多个库,就执行多条相同的语句来备份各个库。rest
mysqldump -uroot -p'oldboy123' -B oldboy |gzip >/tmp/oldboy.sql.gz mysql -e "show databases;" |egrep -v "_schema|atabase" |sed -r 's#^(.*)#mysqldump -B \1 |gzip >/tmp/\1.sql.gz#g' |bash #bash执行这些备份命令,就是一次分开备份多个库了
当不加-B参数备份数据库时,例如“mysqldump oldboy test”,mysqldump命令默认就会把oldboy看成库,把test看成表,若是后面还有多个字符串,例如“mysqldump oldboy test test1“,那么除了oldboy为库以外,其余的test、test1都是oldboy库的表。日志
mysqldump oldboy test>/tmp/oldboy_test,sql
分表备份的缺点:数据文件多,很碎,一旦须要所有恢复又很麻烦。code
一、作一个完整备份,再作一个分库分表备份。ip
二、虽然文件多、碎,但能够利用脚本批量操做多个SQL文件。
mysqldump mysql user db>/tmp/mysql.sql egrep -v "#|\*|--|^$" /tmp/mysql.sql mysqldump oldboy test > /tmp/oldboy_test.sql
利用mysqldump的-d参数能够只备份表的结构,即建表的语句。
mysqldump -d oldboy >/opt/oldboy.sql
利用-t参数备份数据库表的数据(SQL语句形式)。
mysqldump -t oldboy >/opt/oldboy1.sql
利用-T参数能够实现将数据和表结构同时分离备份。
vi /etc/my.cnf secure_file_priv='' #在[mysqld]模块下增长 /etc/init.d/mysqld restart mysqldump oldboy test --compact -T /tmp/
一、-d参数的做用是只备份库表结构(SQL语句形式)。
二、-t参数的做用是只备份表内的数据(SQL语句形式)。
三、-T将库表和数据分离成不一样的文件,数据是纯文本,表结构是SQL语句。
binlog是一个二进制格式的文件,用于记录用户对数据库更新的SQL语句信息,例如更改数据库库表和更改表内容的SQL语句都会记录到binlog里,可是对库表等内容的查询则不会记录到日志中。
当有数据写入到数据库时,还会同时把更新的SQL语句写入到对应的binlog文件里。
使用mysqldump备份时,通常是对某一时刻的数据进行全备,例如,0点进行数据库备份。
假设是天天0点对数据库进行备份,那么在两次备份之间就有24小时的数据没有备份,在这期间若是数据库发生故障,使用mysqldump全量恢复也只能恢复到当日0点,可是有了binlog文件,就能够将两次完整备份间隔之间的数据还原,由于binlog文件里的数据就是写入数据库的数据,使用binlog文件恢复数据,咱们称之为二进制增量数据恢复。
刷新(切割)binlog日志的目的就是肯定全备和增量备(binlog文件)的临界点,当全备完成后,全备时刻之前的binlog文件就无用了(全备里已有这部分数据了),可是全备之后到下一次全备以前的数据就是十分重要的,这部分数据就存在于binlog文件里,所以在进行全备时须要找到全备以后和binlog增量之间的临界点,使得恢复时,须要的binlog文件数据一条很少(不能和全备的内容重合),一条很多(全备后的全部数据都要有)。