七、linux-mysql下mysql增量备份与恢复
1.备份的意义
运维工作:保护公司的数据 、 网站7*24小时服务
但相当来说,数据更加重要,而数据最核心的就是数据库数据,所以数据库的备份和恢复就显得十分重要。
2.备份的几个参数
mysqldump是mysql自带的一个备份呢命令。
命令:mysqldump -u 用户名 -p 数据库名>备份的文件
1)导出oldboy库里面的所有表结构和数据: mysqldump -uroot -p'oldboy124' oldboy >/dangjingwei/mysql_bak.sql
2)导入oldboy库里面的所有表结构和数据:mysql -uroot -poldboy124 oldboy</dangjingwei/mysql_bak.sql
查看导出的mysql_bak.sql文件:egrep -v "#|\*|--|^$" /dangjingwei/mysql_bak.sql如下,这里有3个点需要说明:
1. 可以看出,在导出中有drop,那么在导入的时候,如果库中有相应的表,就会删除此表
2.会有锁表机制,lock,在导入的时候,是禁止别的人写入的
3.这里可以看到,导入的时候,是一条语句,减少IO输出
3)导出加入B:mysqldump -uroot -p'oldboy124' -B oldboy >/dangjingwei/mysql_bak_B.sql (最大的特点是加入了库,在导入的时候,直接导入,无需创建库)
4)导入加入B:mysqldump -uroot -p'oldboy124' </dangjingwei/mysql_bak_B.sql
5)导出加压缩:mysqldump -uroot -p'oldboy124' -B oldboy|gzip >/dangjingwei/mysql_bak_B.sql.gz
3.mysqldump的原理
利用mysqldump命令备份数据的过程,实际上就是把数据从mysql库里以逻辑的sql语句的形式直接输出或者生成备份的文件的过程。
物理备份:就是直接对文件进行打包
4.备份多个库:
命令:mysqldump -u 用户名 -p 数据库名 库名>备份的文件
5.备份单个表:
mysqldump -u 用户名 -p 数据库名 库名 表名 >备份的文件
6. 备份数据库/表的表结构
mysqldump -u 用户名 -p 数据库名 -d 库名 (表名)>备份的文件
7.备份数据库/表的数据
mysqldump -u 用户名 -p 数据库名 -t 库名 (表名)>备份的文件
8.备份数据库所有库表等为-A,需要bin-log日志切割为-F
mysqldump -u 用户名 -p 数据库名 -A -B -F 库名 (表名)>备份的文件
9.备份数据库所有库表日志刷新的位置--master-data增加binlog日志文件名及对应位置点
mysqldump -u 用户名 -p --master-data=1或者 2 数据库名 >备份的文件
10.关于参数 --single-transaction,适合innodb事务数据库备份
InnoDB表在备份时,通常启用选项--single-transaction来保证备份的一致性,实际上它的工作原理是设定本次会话的隔离级别为:repeatable read,保证在备份期间看不到新的提交的数据
11.恢复/导入:
1)source (库名)sql文件---如果导出的时候有-B则完全可以不用指定库名
2)mysql -uroot -p'oldboy124' 库名 < sql文件
12.非交互式参数:-e用法
mysql -uroot -poldboy124 -e "use oldboy;select *from test;"
13.数据库的连接情况,在某种情况下,如果慢查询,哪里这里是没有变化的,运维需要抓住,交由开发优化,添加索引。show processlist 查看正在执行的sql语句
[root@djw1 ~]# mysql -uroot -poldboy124 -e "show processlist;"
+----+------+-----------+------+---------+------+-------+------------------+
| Id | User | Host | db | Command | Time | State | Info |
+----+------+-----------+------+---------+------+-------+------------------+
| 39 | root | localhost | NULL | Query | 0 | NULL | show processlist |
[root@djw1 ~]# mysql -uroot -poldboy124 -e "show full processlist;"
+----+------+-----------+------+---------+------+-------+-----------------------+
| Id | User | Host | db | Command | Time | State | Info |
+----+------+-----------+------+---------+------+-------+-----------------------+
| 40 | root | localhost | NULL | Query | 0 | NULL | show full processlist |
+----+------+-----------+------+---------+------+-------+------------------
14.查进程的参数show variables,它是mysql的变量,my.cnf里面参数的生效情况。
mysql -uroot -poldboy124 -e "show variables;"---例如my.cnf里面参数的生效情况
如何不重启数据库让参数生效
mysql> show variables like 'key_buffer%';
mysql> set global key_buffer_size=1024*32;
15.查看mysql的状态status,show status是当前会话的数据库状态信息,常用的是global全局状态,表示查看整个数据库运行状态信息,show golbal status ; 这里有一些计数器和性能参数
mysql -uroot -poldboy124 -e "show global status;"|grep select(等)
16.mysqlbinlog--》解析mysql的binlog日志
就是数据目录下的如下文件就是mysql的binlog日志
mysql-bin.000001
mysql的binlog日志作用用来记录mysql内部增删改查等对mysql数据库有更新的内容的记录。查询是不记录的。binlog记录的是mysql数据库中的所有的库,如果只是想要恢复其中的一个库,用如下语句:mysqlbinlog -d oldboy mysql-bin.000020 >oldboy.sql
按照位置截取:
mysqlbinlog mysq-lbin.000020 --start-position=365 --stop-position=456 -r pos.sql
按照时间截取:
mysqlbinlog mysq-lbin.000020 --start-datetime='2014-10-16 17:00:11' --stop-datetime='2014-10-16 17:10:11' -r time.sql
17. master-data参数是非常重要的一个参数,如果恢复主库,可以选择master-data=2,如果是从库,那么需要master-data=1
七、linux-mysql下mysql增量备份与恢复的更多相关文章
- Linux - centos7 下 MySQL(mariadb) 和 主从复制
目录 Linux - centos7 下 MySQL(mariadb) 和 主从复制 MySQL(mariadb) 安装MySQL(mariadb) 配置数据库的中文支持 在远程用 mysql客户端去 ...
- 解决Linux系统下Mysql数据库中文显示成问号的问题
当我们将开发好的javaWEB项目部署到linux系统上,操作数据库的时候,会出现中文乱码问题,比如做插入操作,发现添加到数据库的数据中文出现论码,下面就将解决linux下mysql中文乱码问题! 打 ...
- linux系统下MySQL表名区分大小写问题
linux系统下MySQL表名区分大小写问题 https://www.cnblogs.com/jun1019/p/7073227.html [mysqld] lower_case_table_name ...
- LINUX系统下MySQL 压力测试工具super smack
摘要:1.源文件下载地址:http://vegan.net/tony/supersmack/2.安装:注意在编译时,可以先把对应的libmysqlclient.so.*拷贝到/usr/lib3.测试: ...
- Linux系统下 MYSQL数据库中的数据库文件在本机内迁移 (需暂停服务的方式)
Linux系统下 MYSQL数据库中的数据库文件在本机内迁移 本机采用Ubuntu16.04系统,tar方式安装MySQL5.7.21 数据库安装文件夹为 /home/devil/mysql 现 ...
- Linux系统环境下MySQL数据库源代码的安装
Linux系统环境下MySQL数据库源代码的安装 基本环境:CentOS Linux release 7.8.2003 (Core).MySQL5.6 一. 安装环境准备 若要在Linux系 ...
- MySQL 完整和增量备份与恢复
MySQL 完全备份与恢复 1.数据备份的重要性 在企业中数据的价值至关重要,数据保障了企业的业务的运行,因此数据的安全性及可靠性是运维的重中之重,任何数据的丢失都有可能会对企业产生严重的后果.造成数 ...
- Linux虚拟机下mysql 5.7安装配置方法图文教程
一. 下载mysql5.7 http://mirrors.sohu.com/mysql/MySQL-5.7/ Linux下载: 输入命令:wget http://mirrors.sohu.com/my ...
- Linux(centos)下mysql编译安装教程
Linux下mysql编译安装教程 #查看linux发行版本 cat /etc/issue #查看linux内核版本号 uname -r 本文測试环境centOS6.6 一.Linux下编译安装MyS ...
- Linux(Ubuntu)下MySQL的安装与配置
转自:http://www.2cto.com/database/201401/273423.html 在Linux下MySQL的安装,我一直觉得挺麻烦的,因为之前安装时就是由于复杂的配置导致有点晕.今 ...
随机推荐
- Android进阶——Android视图工作机制之measure、layout、draw
自定义View一直是初学者们最头疼的事情,因为他们并没有了解到真正的实现原理就开始试着做自定义View,碰到很多看不懂的代码只能选择回避,做多了会觉得很没自信.其实只要了解了View的工作机制后,会发 ...
- jsch通过SSH2执行linux命令
public class SSHUtils { private Channel channel; private Session session = null; private int timeout ...
- Python笔记_第五篇_Python数据分析基础教程_相关安装和版本查看
1. IDE说明: 所有的案例用Anacoda中的Jupiter工具进行交互式讲解. 2. 版本和安装: NumPy从如下网站安装:http://sourceforge.net/projects/nu ...
- (day 1)创建项目--2
在pycharm查看创建好的项目 可以将myblog当做模块使用
- JavaScript 之 Function
JavaScript function 语句定义和用法: function 语句用于声明一个函数. 函数声明后,我们可以在需要的时候调用. 在 JavaScript 中,函数是对象,函数也有属性和方法 ...
- CSS(2)之重新认识 CSS3 新特性
CSS3选择器(全) 相邻兄弟选择器:+ 选择到紧随目标元素后的第一个元素 普通兄弟选择器:~ 选择到紧随其后的所有兄弟元素 伪类选择器 :link :visited :hover :active : ...
- 排序算法 python实现
一.排序的基本概念和分类 所谓排序,就是使一串记录,按照其中的某个或某些关键字的大小,递增或递减的排列起来的操作.排序算法,就是如何使得记录按照要求排列的方法. 排序的稳定性: 经过某种排序后,如果两 ...
- UML-GRASP总结
对象设计的核心 1).对象交互 2).职责分配
- 注册网站 captcha reCHAPTCHA 错误
原因 出现这个错误,是因为注册和提交时候,没有正确输出验证码导致的.网站可能会为了防止恶意注册,而使用验证码.如果验证码没有被正确加载或验证,就会出现相关错误. 解决方案 如果是访问类似kaggle, ...
- 问:为什么java是单继承,但却是多实现的呢?
在学习的过程中,我发现了如题的这个有趣的问题. 单继承不必解释,一个类只能有一个直接父类:但是对于接口的实现,一个类却能够实现多个接口. 为什么是这种情况呢?我们来举个简单的栗子看一下: class ...