码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【Java实战】Mysql读写分离主从复制搭建保姆级教程


    MySQL 的数据同步通常采用主从复制(Master-Slave)的方式。 主从复制基于二进制日志(binlog)。主服务器(Master)在 binlog 中记录数据更改,从服务器(Slave)将这些日志读取并应用到自己的数据库,以此实现数据的同步。从服务器有两个线程:IO线程从主服务器读取 binlog 并保存在本地的中继日志(relay log);SQL线程读取中继日志,执行其中的事件,确保从服务器数据与主服务器保持一致

    以下是配置 MySQL 主从复制的步骤:

    一 配置主服务器(Master)

    1.0 编辑 MySQL 配置文件 /etc/my.cnf

    1. [mysqld]
    2. server-id=1
    3. log-bin=mysql-bin
    4. binlog-do-db=你创建的dbname

    1.1 重启 MySQL 服务

    systemctl restart mysqld

    1.2 登录 MySQL,并创建用于复制的用户。

    1. mysql -uroot -p 
    2. CREATE USER 'repl_user'@'%' IDENTIFIED BY '你的密码';
    3. GRANT REPLICATION SLAVE ON *.* TO 'repl_user'@'%';

    1.3 查看主服务器状态,记录文件名和位置。

    SHOW MASTER STATUS;

    二 配置从服务器(Slave)

    2.0 编辑 MySQL 配置文件 my.cnf(Slave)

    1. [mysqld]
    2. server-id=2

    2.1 重启从服务器(Slave)

    systemctl restart mysqld

    2.2 登录 MySQL

    mysql -uroot -p

    2.3 并配置从服务器连接到主服务器(slave)

    1. CHANGE MASTER TO
    2.   MASTER_HOST='你的master的IP',
    3.   MASTER_USER='repl_user',
    4.   MASTER_PASSWORD='你的master上repl_user用户的密码',
    5.   MASTER_LOG_FILE='你的master_log_file',
    6.   MASTER_LOG_POS=你的master_log_position;

    如何获取 MASTER_LOG_FILE 和 MASTER_LOG_POS

    在主服务器(Master)上登录, MySQL 执行以下 SQL 命令:

    SHOW MASTER STATUS;

    这里,File 列是 MASTER_LOG_FILE 的值(如:mysql-bin.000002),Position 列是 MASTER_LOG_POS 的值

    2.4 启动 Slave

    START SLAVE;

    查看从服务器状态,确认复制是否正在运行。

    SHOW SLAVE STATUS\G;

    三 验证Mysql主从服务器

    在Master上,创建表、添加几个字段、数据增加、修改、删除。

    观察Slave上面数据是否一致。

  • 相关阅读:
    LightDB中的存储过程(一)
    Eureka高可用集群服务端和客户端配置
    Linux常用命令
    【PAT甲级 - C++题解】1096 Consecutive Factors
    【JavaEE】Spring更简单的存储和获取对象(类注解、方法注解、属性注入、Setter注入、构造方法注入)
    七牛云创建存储空间并绑定自定义域名-https协议
    Kernel: 宏:__KERNEL__
    Java教程之高阶源码分析-ConcurrentHashMap
    【Leetcode刷题笔记02】977.有序数组的平方 209.长度最小的子数组 59.螺旋矩阵II
    Ubuntu常见问题解决
  • 原文地址:https://blog.csdn.net/forgetmiss/article/details/133881224
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号