CentOS7环境下MySQL的主从配置

一、什么叫主从复制

通过在主服务器和从服务器之间切分处理客户查询的负荷,可以得到更好的客户响应时间。通俗点说就是select查询发送到从服务器,修改数据的语句发送到主服务器,以此来降低主服务器的查询处理压力

二、主从复制工作原理

MySQL主从是基于binlog的,主服务器必须开启binlog才能进行主从。3个过程实现,其中一个过程在主服务器上,另外两个过程发生在从服务器上。

  1. master服务器将增删改操作记录写入到binlog里
  2. slave服务器将binlog中(sql语句)同步到自己的relaylog里
  3. slave服务器从relaylog里面的SQL语句按顺序很执行

三、主从复制的优点

  • 数据库备份 假如一台服务器宕机或数据丢失,我们只需把其他服务器上的数据库copy一份就可以了
  • 读写分离 根据2、8原则,系统中80%的请求多是查询(select),20%请求为增删改(insert、delete、update)。当项目请求数足够大的时候,读写分离可以有效的减轻数据库压力

步骤

1、准备数据库服务器

以centos7下的lnmp集成包为例,保持两台主机网络畅通

  • 主(master) 192.168.0.253
  • 从(slave) 192.168.0.251

首先要考虑防火墙影响,要么关闭防火墙;

[root@localhost jack]# systemctl stop firewalld.service

要么在防火墙里添加开放3306端口的规则:

[root@localhost jack]# firewall-cmd --zone=public --add-port=3306/tcp --permanent
[root@localhost jack]# firewall-cmd --reload

2、主服务器配置

1、修改主服务器上:/etc/my.cnf

server-id = 1
log-bin = mysql-bin #主从服务的核心 定义binblog日志的前缀名
binlog-do-db=test #需要同步的数据库,如果没有本行,即表示同步所有的数据库
binlog-do-db=mydb #需要同步的数据库,同时同步test、mydb库
binlog-ignore-db=mysql #被忽略的数据库

在主服务器创建一个专门用来同步的用户,注意下面:

  • *.* 指定能操作所有的表和库;
  • mysync表示在系统中创建一个用户,用于负责主从工作;
  • %表示允许所有主机,
  • 后面跟具体的ip(192.168.0.251),表示针对某一个主机用来做从服务器
    # GRANT REPLICATION SLAVE ON *.* TO 'mysync'@'%' IDENTIFIED BY '12345678';
    
    mysql> GRANT REPLICATION SLAVE ON *.* TO 'mysync'@'192.168.0.251' IDENTIFIED BY '12345678';
    mysql> show master status; // 等着 留意file 和postion字段

    锁定数据库,此时不允许更改任何数据,当然也可以省略这一步,只要我们人为的不操作数据就好

    mysql> flush tables with read lock;  

    查看主服务器当前状态,这些数据是要记录的,一会要在slave服务器端用到

    mysql> show master status;  // 等着 留意file 和postion字段
    +------------------+----------+--------------+------------------+
    | File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
    +------------------+----------+--------------+------------------+
    | mysql-bin.000006 | 511 | test,mydb | |
    +------------------+----------+--------------+------------------+

3、从服务器

1、修改主服务器上:/etc/my.cnf

server-id = 251  //保证唯一性

2、设置从服务

mysql> CHANGE MASTER TO MASTER_HOST='192.168.0.253',MASTER_USER='mysync',
MASTER_PASSWORD='12345678',MASTER_LOG_FILE='mysql-bin.000006',MASTER_LOG_POS=511;
  • MASTER_LOG_FILE //从主服务器上看status
  • MASTER_LOG_POS //同上
mysql> start slave  #开启从服务
mysql> show slave status\G #查看从服务状态

如下两个选项都为yes标明主从成功

Slave_IO_Running:Yes
Slave_SQL_Running:yes

出现

Fatal error: The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work.

解决

find / -name auto.cnf

删除auto.cnf文件内容

4、测试增删改

具体自己测试,聂哥就不管了,其实就简单创建一个表,或添加几条数据就能测试

5、友情提醒

主从复制搭建起来不算难,只要按照上面步骤来,一般不会有问题。但是一旦我们不小心在slave服务器上写了数据,那么主从也就被破坏了。 另外如果非要重启master服务器,一定要先把slave服务器停掉,也就是说需要在slave上去执行 slave stop 命令,然后再去重启master服务器上的mysql服务,否则很有可能就会中断了。 当然重启完后,还需要把slave服务器给开启 slave start.

CentOS7环境下MySQL的主从配置的更多相关文章

  1. Centos7下mysql的主从配置

    最近,有朋友业务并发量比较大,让我帮他配置个主从,来缓解数据库的压力.下面就是我配置的,有需要的朋友可以借鉴下. 首先,我得到2台服务器: 172.18.2.142(主) 172.18.2.141(从 ...

  2. Linux环境下mysql安装并配置远程访问

    环境:centOS 1.下载mysql安装文件 [root@localhost ~]# wget http://dev.mysql.com/get/mysql-community-release-el ...

  3. centos7环境下mysql安装

    1.去官网下载合适的yum源安装包 https://dev.mysql.com/downloads/repo/yum/ 2.yum 本地安装 命令:yum localinstall mysql57-c ...

  4. Linux centos7环境下安装MySQL的步骤详解

    Linux centos7环境下安装MySQL的步骤详解 安装MySQL mysql 有两个跟windows不同的地方 1).my.ini 保存到/etc/my.ini 2).用户权限,单独用户执行 ...

  5. centos7.2环境nginx+mysql+php-fpm+svn配置walle自动化部署系统详解

    centos7.2环境nginx+mysql+php-fpm+svn配置walle自动化部署系统详解 操作系统:centos 7.2 x86_64 安装walle系统服务端 1.以下安装,均在宿主机( ...

  6. Linux下MySQL数据库主从同步配置

    说明: 操作系统:CentOS 5.x 64位 MySQL数据库版本:mysql-5.5.35 MySQL主服务器:192.168.21.128 MySQL从服务器:192.168.21.129 准备 ...

  7. 在ConoHa上Centos7环境下源码安装部署LNMP

    本文记录了从源码,在Centos 7上手动部署LNMP环境的过程,为了方便以后对nginx和mariadb进行升级,这里采用yum的方式进行安装. 1.建立运行网站和数据库的用户和组 groupadd ...

  8. [转帖]mysql数据库主从配置

    mysql数据库主从配置 https://www.toutiao.com/i6680489302947791371/ 多做实验 其实挺简单的 很多东西 要提高自信 去折腾. 架构与我 2019-04- ...

  9. linux centos7环境下安装apache2.4+php5.6+mysql5.6 安装及踩坑集锦

    linux centos7环境下安装apache2.4+php5.6+mysql5.6 安装及踩坑集锦(一) 一.Linux下安装MySQL 1.下载 下载地址:http://dev.mysql.co ...

  10. [原] KVM 环境下MySQL性能对比

    KVM 环境下MySQL性能对比 标签(空格分隔): Cloud2.0 [TOC] 测试目的 对比MySQL在物理机和KVM环境下性能情况 压测标准 压测遵循单一变量原则,所有的对比都是只改变一个变量 ...

随机推荐

  1. 浅谈 Java 中的 AutoCloseable 接口

    本文对 try-with-resources 语法进行了较为深入的剖析,验证了其为一种语法糖,同时给出了其实际的实现方式的反编译结果,相信你在看完本文后,关于 AutoCloseable 的使用你会有 ...

  2. <vue 路由 5、动态路由-标签上传递参数>

    一.效果 在about页面点击"我的",路径里传入了参数zhangsan,在"我的"页面里接收传递过来的张三并展现出来.注:标签中传递参数写法 二.代码结构 注 ...

  3. 第七届蓝桥杯大赛个人赛省赛(软件类)B组

    3.凑算式     B      DEFA + --- + ------- = 10     C      GHI     (如果显示有问题,可以参见[图1.jpg])   这个算式中A~I代表1~9 ...

  4. Proxifier 2023年11月时最新版 激活教程

    前言 Proxifier 是一款功能非常强大的socks5客户端,可以让不支持通过代理服务器工作的网络程序能通过HTTPS或SOCKS代理或代理链.支持64位系统支持Xp,Vista,Win7,支持s ...

  5. java基础-构建工具mvn-day20

    目录 1. 初识mvn 2. 用maven创建工程 3. maven工程 之间的关系 4. 父子 mvn工程 5. mvn常见的插件 6. tomcat插件 1. 初识mvn mvn是一个项目构建工具 ...

  6. Nacos源码 (2) 核心模块

    整体架构 服务管理:实现服务CRUD,域名CRUD,服务健康状态检查,服务权重管理等功能 配置管理:实现配置管CRUD,版本管理,灰度管理,监听管理,推送轨迹,聚合数据等功能 元数据管理:提供元数据C ...

  7. 搞了个Blazor工具站,域名一次性买了10年!

    大家好,我是沙漠尽头的狼. 在 Dotnet9 上线在线小工具和小游戏后,服务器的压力感觉挺大的,打开25个页面,内存占用170MB左右,CPU保持在60~70%,看来Server真不适合搞这类交互较 ...

  8. AHB-SRAMC Design-02

    AHB-SRAMC Design SRAMC(另外一种代码风格)解析 SRAM集成,顶层模块尽量不要写交互逻辑 module ahb_slave_if( input hclk, input hrest ...

  9. 【Freertos】任务切换分析

    任务切换实现 xPortPendSVHandler: mrs r0, psp // 获取进入异常时的进程栈 isb ldr r3, =pxCurrentTCB // 加载线程控制块地址到r3 ldr ...

  10. Net Core中使用EF Core连接Mysql数据库

    Entity Framework Core的前身是微软提供并主推的ORM框架,简称EF,其底层是对ADO.NET的封装.EF支持SQLServer.MYSQL.Oracle.Sqlite等所有主流数据 ...