1.上节基本诉说了mysql主从同步,这里想说明的是,其一从库在请求主库进行同步的时候,是主库的主线程进行用户名、密码的验证,在验证通过后,将请求转交给I/O线程负责同步;其二从库sql线程在读取中继日志relay.log写入数据库后,也会在relay.info中记录自己写入的位置

2.在部署实验时,有一个锁表的语句:flush table with read lock ; 这个锁表的时间,在不同的引擎的情况下,会受参数的控制,如果超过时间,会自动解锁。另外,当前窗口如果关闭,也会解锁。

查看时间参数:show variables like '%timeout%'

修改锁表时间:修改的是内存中的参数,因为没有在配置文件中修改,所以关闭此次修改,退出数据库后,会失效。

set global wait_timeout=10;

set global  interactive_timeout=10;

3.mysqldump -uroot -p'oldboy124' -S /data/3306/mysql.sock  -F -B  oldboy >/dangjingwei/t.sql

上述命令中,-F标识自动刷新bin_log日志,因为如果不是操作数据库,一般binlog的日志位置是不会变得,所以这里加入-F后,操作日志会发生变化,但是实际数据库是没有变化的。

4.如果从库还想级联从库,需要打开log-bin和log-slave-updates参数。

5.怎样做从库?

1)申请设备

2)编写文档和实施方案

3)告知项目经理,然后进行实施就可以了

6.查看线程的同步状态:这只是其中的一种状态,剩下的可以百度

show processlist;(主库)

show processlist;(从库)

7.生产场景mysql主从复制读写分离授权方案与实战

当配置好mysql主从复制以后,所有对数据库内容的更新就必须在主服务器上进行,原因在于数据复制是单向的,只有在主库上更新,才能主从一致

授权分离,让连接主库不连接从库,防止连接从库的3个方法:

方案1:

主库:web oldboy 192.168.0.104  3306 (select,insert,delete,update)

从库:主库的web用户同步到从库,然后回收insert,delete,update权限。

不回收从库权限,设置read-only参数确保从库只读。可以不回收了。

方案2:

主库:web_w oldboy 192.168.0.104  3306 (select,insert,delete,update)

从库:web_r oldboy 192.168.0.104  3306 (select)

风险:web_w连接从库,设置read-only参数确保从库只读。

开发:多套用户密码不专业。

方案3:

不同步mysql库:主从库分别进行如下授权

主库:web oldboy 192.168.0.104  3306 (select,insert,delete,update)

从库:web oldboy 192.168.0.104  3306 (select)

缺陷:从库切换主库时候,连接用户授权问题,保留一个从库专门准备接替主。

8.可以看出,一般情况下,我们的主从同步是进行全部库都的同步。如果想要同步某些库的时候,修改配置文件my.cnf: master端:--binlog-ignore-db=库名:二进制忽略的数据库,多个库用,分隔;--binlig-do-db :二进制日志记录数据库,多个库用,分隔;还有很多情况,不常用,需要的可以百度网上

9.read-only参数防止数据写从库的方法:
      除了给从库仅作selectd的授权外,还可以在slave服务器启动选项增加参数或者在my.cnf配置文件中加入read-only确保从库只读,值得注意的是,read-only参数对于具有super权限的用户是没有效果的,换句话说对不是super的用户是有效果的。

10.重现故障是运维最重要的一个能力。
   例如,如果从库有一个库test,但是这时如果主库创建test,在同步到从库的时候就会报错,通过在从库添加如下命令,让指针向下走一格,忽略此报错:
        stop  slave
        set global  sql slave_skip_counter=1
        start slave
  1)   对于普通的互联网业务,忽略问题不是很大。要确保业务不影响
  2)企业场景解决主从同步,比主从不一致对当前更重要,然后如果主从数据一致也很重要,在找个时间恢复下这个从库
  主从数据不一致更重要还是保持主从同步持续状态更重要,这个我们要根据业务进行选择;当然,我们还可以在参数中配置,也可以忽略此错误,slave-skip-errors=1032,10062,1007

11.忽略解析的参数是在my.cnf中的 skip-name-resolve

12.mysql的slave从库记录binlog方法
     需要记录binlog的情况:
  1)当前从库还要作为其他从库的主库,也就是级联同步
  2)把从库作为备份服务器时需要开启binlog

操作方式:

my.cnf下log-bin打开
log-slave-updates
expire_logs_days=7(linlog自动保存多少天,之后的删除)

13.方案:一主多从,主库宕机切换从库方案

1.)登陆从库show  processlist\G,查看两个线程的状态
2.)看从库哪个的master.info更靠前,作为主库
 cat  /data/3307/data/master.info
3.)切换:登陆从库
  stop slave
  retest master
  quit
4.)进入数据库数据目录,删除master.info relay-log.info
检查授权表,类似read-only
5.)提升主库 :/data/3306/restart
6.)如果主库服务器没宕,需要去主库提取binlog日志补全提升主库的从库
  授权同步用户和主库一样
7.)其他从库 stop  slave
  change master to master-host='ip'
   start slave
   show  slave  status \G
8.)修改程序配置文件,切换主库
9.)修复损坏的主库,完成后作为从库使用或者切换
 
14.主主互备
Master1:
auto_increment_increment     =2#自增ID的间隔,如1 3 5间隔2
auto_increment_offset        =1#ID的初始位置
Master2:
auto_increment_increment     =2#自增ID的间隔,如2,4,6间隔2
auto_increment_offset        =2#ID的初始位置

my.cnf下log-bin打开
log-slave-updates

然后change slave进行配置即可;主键的增长不是有规律的,但是不影响业务,如上,可以是1,3,5,6,8等

九、linux-msyql下的mysql主从复制深度实战的更多相关文章

  1. 1.Mysql集群------Docker下的Mysql主从复制

    前言: 实话说,我想做的是Mysql集群架构. 我的计划是: 1.实现Docker下的Mysql主从复制 2.实现MyCat基于Mysql的读写分离 3.实现MyCat的分库分表 4.实现pxc集群 ...

  2. Linux系统下启动MySQL报错:Neither host 'localhost.localdomain' nor 'localhost' could be looked up with

    Linux系统下启动MySQL报错:Neither host 'localhost.localdomain' nor 'localhost' could be looked up with 摘要 Li ...

  3. 使用kettle工具将文本文件的内容插入Linux虚拟机下的mysql表中

    一.      解压kettle包 1.把包拷到Linux系统下 还有mysql的驱动包 2.解压zip后缀的包 输入命令:unzip /software/pdi-ce-7.0.0.0-25.zip ...

  4. Linux平台下卸载MySQL的方法

    转载自: https://www.cnblogs.com/taomylife/p/7234925.html Linux平台下卸载MySQL的方法: MySQL的安装主要有三种方式:二进制包安装.RPM ...

  5. Linux系统下授权MySQL账户访问指定数据库和数据库操作

    Linux系统下授权MySQL账户访问指定数据库 需求: 1.在MySQL中创建数据库mydata 2.新建MySQL账户admin密码123456 3.赋予账户admin对数据库mydata具有完全 ...

  6. 在linux系统下安装mysql详解,以及远程调用连接不上mysql的解决方法。

    步骤: 1)查看CentOS自带的mysql 输入 rpm -qa | grep mysql 2)将自带的mysql卸载 3)上传Mysql的安装包到linux 4)安装mysql的依赖(不是必须) ...

  7. 虚拟机中ubuntu-16.04 Linux系统下配置mysql数据库,并在windows下使用navicat远程连接

    Linux系统下mysql数据库安装配置步骤: 1.在服务器上安装mysql:sudo apt-get install mysql-server sudo apt-get install mysql- ...

  8. centos7下部署mysql主从复制

    首先大致看一下这个图 环境说明: 系统:centos7 IP:master:192.168.7.235 slave:192.168.7.226 mysql版本MySQL-5.7 1.Master 下载 ...

  9. linux环境下搭建MySQL

    linux下搭建mysql的方式很多,网上也详解了很多种搭建方式,有直接yum的.有rpm的..总之,“坑”是层出不穷,有相关文件依赖性.权限.GPG keys等等. 本人也在今天搭建了一下.是出“坑 ...

随机推荐

  1. SASS - 混合(Mixin)

    SASS – 简介 SASS – 环境搭建 SASS – 使用Sass程序 SASS – 语法 SASS – 变量 SASS- 局部文件(Partial) SASS – 混合(Mixin) SASS ...

  2. Day 3:集合

    数组: 存储同一种数据类型的集合容器数组的特点: 1. 只能存储同一种数据类型的数据. 2. 一旦初始化,长度固定.  3. 数组中的元素与元素之间的内存地址是连续的. 注意: Object类型的数组 ...

  3. (递归)P1192 台阶问题

    题解: 这其实是变相的斐波那契,观察下列等式: //k=2 : 1 2 3 5 8 13 21 34...... //k=3 : 1 2 4 7 13 24 44 81... //k=4 : 1 2 ...

  4. 基于仿生算法的智能系统I

    仿生算法仿生算法是什么? 什么是仿生? 蜜蜂会造房子,人类就学习蜜蜂盖房子的方法,之后便有了航空建造工程的蜂窝结构. 仿生是模仿生物系统的功能和行为,来建造技术系统的一种科学方法.生活仿生作品现代的飞 ...

  5. python安装wordcloud、jieba,pyecharts

    1.安装wordcloud: 适用于无法使用pip install wordcloud安装的情况: 据python和windows 版本 到https://www.lfd.uci.edu/~gohlk ...

  6. 如何在MySQL目录下找到my.ini

    1. 打开ProgramData目录 2. 进入目录C:\ProgramData\MySQL\MySQL Server 8.0

  7. ftp限制

    /etc/hosts.deny /etc/vsftpd/user_list 从2.3.5之后,vsftpd增强了安全检查,如果用户被限定在了其主目录下,则该用户的主目录不能再具有写权限了!如果检查发现 ...

  8. javaweb05 文件的上传一

    2.使用fileupload组件完成文件的上传应用 1).需求: I. 上传 >在upload.jsp页面上使用jQuery实现"新增一个附件","删除附件&quo ...

  9. 我读《DOOM启世录》——成为一个真正厉害的人

    序言 谈到游戏, 你的当然会想到几乎统治游戏市场多年的英雄联盟,你可能还会想起前段时间风头大盛的王者荣耀手游,你应该还会想起正在冲击着游戏市场的"吃鸡"类型游戏. 那么, 大家是否 ...

  10. Django2.0模型基础——(一)

    Django模型封装python操作数据库的代码,让我们可以更加方便的执行SQL语句.每个创建的app下都会有一个叫models.py的文件,在这个文件下创建的模型类映射于数据库的表名,类属性映射于数 ...