zoukankan      html  css  js  c++  java
  • MySQL 主从

    MySQL读写分离技术

     

    一、读写分离(主从复制)

    主从复制:当主服务器有写入(insert/update/delete)语句时候,从服务器自动获取
    读写分离:insert/update/delete语句操作一台服务器,select操作另一个服务器

     


    从库生成两个线程,一个I/O线程,一个SQL线程;
    i/o线程去请求主库 的binlog,并将得到的binlog日志写到relay log(中继日志) 文件中;
    主库会生成一个 log dump 线程,用来给从库 i/o线程传binlog;
    SQL 线程,会读取relay log文件中的日志,并解析成具体操作,来实现主从的操作一致,而最终数据一致

    二、bin-log日志

    概念:binlog即二进制日志,它记录了数据库上的所有改变并以二进制的形式保存在磁盘中,它可以用来查看数据库的变更历史、数据库增量备份和恢复、Mysql的复制(主从数据库的复制)。
    简单概括:binlog日志就是记录MySQL数据库增/删/改SQL语句
    作用:实现主从复制、灾难恢复

    1、开启binlog日志
    步骤1:打开MySQL配置文件vi /etc/my.cnf并修改

     


    步骤2:重启服务

     


    步骤3:登录MySQL查看bin-log日志是否开启

     
     


    2、查看binlog日志里面的内容
    列表:show master logs
    清空:reset master
    刷新:flush logs
    查看指定日志:show binlog events in '日志键名'
    步骤1:查看列表

     


    步骤2:刷新(生成一个新文件存储)

     
     


    步骤3:创建d1数据库和t1表
    create database data1;
    use data1;
    create table table1 (id int);
    步骤4:查看binlog日志中的SQL语句

     

    三、主从复制具体配置步骤

    1、配置主服务器
    步骤1:修改配置文件,开启binlog日志
    步骤2:修改配置文件,设置一个server_id=数字(注:数字必须唯一)

     


    步骤3:重启服务
    步骤4:创建用户(目的,让从服务器来复制数据)
    create user 'copyer'@'%' IDENTIFIED BY '666666';
    grant all on . to 'copyer'@'%';
    FLUSH PRIVILEGES;
    步骤5:关闭防火墙或开放3306端口
    2、配置从服务器
    步骤1:修改配置文件,设置一个server-id=数字(注:数字必须唯一)

     


    步骤2:重启服务
    步骤3:通过change master 语句指定同步主位置
    -> 切换到主服务器并查看当前主服务器信息,通过SQL语句:【show master status】

     


    -> 切换到从服务器执行同步语句
    change master to
    master_host='192.168.142.131',master_user='copyer',master_password="666666",master_log_file='localhost-bin.000013',master_log_pos=839;

     


    步骤4:从服务器开启同步

     


    步骤5:从服务器验证

     


    注意:
    -> 如果出现错误,可以重新登陆MySQL然后重启slave服务尝试。
    -> 如果使用的是虚拟机克隆的两个系统,则MySQL是一样的,也会报错’UUIDs’问题,需要删除MySQL数据目录下的auto.cnf然后重启(注:重启后会自动创建一个唯一的uuid),然后重启nysql服务即可。
    3、测试

     
    我们只需要努力,然后剩下的交给时间。
  • 相关阅读:
    『轉』windows文件的占用空间与文件大小
    『轉』asterisk入门连载二
    vm系統出現This Virtual Machine Appears To Be In Use的問題
    linux 7788
    鸿蒙开发板外设控制 之 实现按键“按下事件”和“释放事件”的通用框架(V0.0.1)
    【开发板试用报告】学习GPIO编程
    前言「HarmonyOS应用开发基础篇」
    【开发板试用报告】鸿蒙OS环境搭建及代码烧录
    动态设置和访问cxgrid列的Properties
    cxgrid导出excel
  • 原文地址:https://www.cnblogs.com/lgj8/p/13590263.html
Copyright © 2011-2022 走看看