Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >超简单的MySQL主从复制配置步骤

超简单的MySQL主从复制配置步骤

作者头像
张戈
发布于 2018-03-23 09:28:27
发布于 2018-03-23 09:28:27
1K00
代码可运行
举报
文章被收录于专栏:张戈的专栏张戈的专栏
运行总次数:0
代码可运行

MySQL 估计就是俺的主战场了,看来得多收藏一些 MySQL 的技术教程才行。正愁没啥东西可以写,就先转载一篇超简单的 MySQL 主从复制的配置教程好了。

怎么安装 mysql 数据库,这里不说了,只说它的主从复制,步骤如下:

1、主从服务器分别作以下操作:

①、版本一致

②、初始化表,并在后台启动 mysql

③、修改 root 的密码

2、修改主服务器 master:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#vi /etc/my.cnf
[mysqld]
log-bin=mysql-bin //[必须]启用二进制日志
server-id=222 //[必须]服务器唯一ID,默认是1,一般取IP最后一段

3、修改从服务器 slave:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#vi /etc/my.cnf
[mysqld]
log-bin=mysql-bin //[必须]启用二进制日志
server-id=226 //[必须]服务器唯一ID,默认是1,一般取IP最后一段

4、重启两台服务器的 mysql

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/etc/init.d/mysql restart

5、在主服务器上建立帐户并授权 slave:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#/usr/local/mysql/bin/mysql -uroot -pmttang
mysql>GRANT REPLICATION SLAVE ON *.* to 'mysync'@'%' identified by 'q123456';
#一般不用root帐号,“%”表示所有客户端都可能连,只要帐号,密码正确,此处可用具体客户端IP代替,如192.168.145.226,加强安全。

6、登录主服务器的 mysql,查询 master 的状态

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mysql>show master status;
   +------------------+----------+--------------+------------------+
   | File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
   +------------------+----------+--------------+------------------+
   | mysql-bin.000004 |      308 |              |                  |
   +------------------+----------+--------------+------------------+
   1 row in set (0.00 sec)

注:执行完此步骤后不要再操作主服务器 MYSQL,防止主服务器状态值变化

7、配置从服务器 Slave:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mysql>change master to master_host='192.168.145.222',master_user='tb',master_password='q123456', master_log_file='mysql-bin.000004',master_log_pos=308; //注意不要断开,“308”无单引号。
Mysql>start slave; //启动从服务器复制功能

8、检查从服务器复制功能状态:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mysql> show slave status\G
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.2.222 //主服务器地址
Master_User: myrync //授权帐户名,尽量避免使用root
Master_Port: 3306 //数据库端口,部分版本没有此行
Connect_Retry: 60
Master_Log_File: mysql-bin.000004
Read_Master_Log_Pos: 600 //#同步读取二进制日志的位置,大于等于>=Exec_Master_Log_Pos
Relay_Log_File: ddte-relay-bin.000003
Relay_Log_Pos: 251
Relay_Master_Log_File: mysql-bin.000004
Slave_IO_Running: Yes //此状态必须YES
Slave_SQL_Running: Yes //此状态必须YES
......

注:Slave_IO 及 Slave_SQL 进程必须正常运行,即 YES 状态,否则都是错误的状态(如:其中一个 NO 均属错误)。

以上操作过程,主从服务器配置完成。

9、主从服务器测试:

主服务器 Mysql,建立数据库,并在这个库中建表插入一条数据:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mysql> create database hi_db;
Query OK, 1 row affected (0.00 sec)
mysql> use hi_db;
Database changed
mysql>  create table hi_tb(id int(3),name char(10));
Query OK, 0 rows affected (0.00 sec)
mysql> insert into hi_tb values(001,'bobu');
Query OK, 1 row affected (0.00 sec)
mysql> show databases;
   +--------------------+
   | Database           |
   +--------------------+
   | information_schema |
   | hi_db              |
   | mysql              |
   | test               |
   +--------------------+
   4 rows in set (0.00 sec)

在从服务器 Mysql 查询:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mysql> show databases;
   +--------------------+
   | Database           |
   +--------------------+
   | information_schema |
   | hi_db              |          //I'M here,大家看到了吧
   | mysql              |
   | test               |
   +--------------------+
   4 rows in set (0.00 sec)
   mysql> use hi_db
   Database changed
   mysql> select * from hi_tb;    //可以看到在主服务器上新增的具体数据
   +------+------+
   | id   | name |
   +------+------+
   |    1 | bobu |
   +------+------+
   1 row in set (0.00 sec)

10、附加:监控

编写一 shell 脚本,用 nagios 监控 slave 的两个“yes”,如发现只有一个或零个“yes”,就表明主从有问题了,发短信警报吧。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2014年06月18日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
编辑精选文章
换一批
Java开发环境系列:MySQL实战之开启主从复制功能
3)本次测试使用的数据库分别为阿里云MySQL和本地安装的MySQL,版本:mysql-5.7.20-winx64
架构师小跟班
2019/08/06
6070
Java开发环境系列:MySQL实战之开启主从复制功能
MYSQL分布式集群使用-主从复制
要达到分布式布局,需要满足2个条件: 1. 框架程序的支持,如Thinkphp、YII2。 > TP的支持文档:http://document.thinkphp.cn/manual_3_2.html#distributed_database 2. 数据库的配置,使其支持主从或主主关系拷贝。 > 主从复制(亦叫 读写分离) > 主主复制(亦叫 互为主从,主主互备或双机热备) 主从复制,亦可称为读写分离 假设: 主服务器 -> 192.168.1.110 从服务器 -> 192.168.1.111 主服务器配
码农编程进阶笔记
2021/07/20
7510
MySQL主从复制与相关问题解决方法
所有的关系型数据库都存在一个通病性能差,在企业中如果用户量特别打,将所有的数据都存放在一台服务器上,其性能时远远达不到要求的。所以需要使用一些手段来解决其性能的问题。 提升性能的方式有向上扩展以及向外扩展 向上扩展(Scale Up):使用更新更好的硬件,但硬件在怎么更新也有其性能的极限。盲目的向上扩展无法结局根本的问题 向外扩展(Scale Out):就是使用多台机器分摊压力来提供服务
星哥玩云
2022/08/18
8880
MySQL主从复制
编写复杂的SQL语句一开始让我觉得很困难,当你熟悉了类似Java等的面向对象编程语言,要适应面向集合的SQL语言,还是需要一段时间的。不过作为一名数据工程师,不熟悉SQL,实在说不过去。我们就以互联网最常用的MySQL数据库为例,一起探索SQL的奥秘。本文主要讲解MySQL主从复制原理和搭建过程。
soundhearer
2020/10/15
1.6K0
MySQL主从复制
CentOS mysql配置主从复制
环境: centos 7.0 mysql5.6 (yum包 yum localinstall mysql-yum) 1、主从服务器分别作以下操作: 版本一致 初始化表,并在后台启动mysql 修改root的密码 2、修改主服务器master: #vi /etc/my.cnf [mysqld] log-bin=mysql-bin //[必须]启用二进制日志 server-id=232 //[必须]服务器唯一ID,默认是1,一般取IP最后一段 3、修改从服务器slave: #
冷冷
2018/02/08
7670
mysql主从复制配置与问题解决
原理:MySQL使用3个线程来执行复制功能(其中1个在【主服务器】上,另两个在【从服务器】上)       当【从服务器】发出START SLAVE时,【从服务器】创建一个I/O线程,以连接【主服务器】并让它发送记录在其二进制日志中的语句。     【主服务器】创建一个线程将二进制日志中的内容发送到【从服务器】。该线程可以识别为【主服务器】上SHOW PROCESSLIST的输出中的Binlog Dump线程。
洋仔聊编程
2019/01/15
7180
mysql主从复制
由于我这里使用docker搭建,所以需要把配置文件和数据文件映射到宿主机,让容器运行时挂载数据
earthchen
2020/09/24
1K0
MySQL主从复制(一主一从)部署
①当Master节点进行insert、update、delete操作时,会按顺序写入到binlog中。
Alone-林
2023/03/17
2.5K0
MySQL主从复制(一主一从)部署
CentOS 7.2下MySQL主从复制配置
MySQL的 Replication 是一个异步的复制过程(mysql5.1.7以上版本分为异步复制和半同步两种模式),从一个 Mysql instace(我们称之为 Master)复制到另一个 Mysql instance(我们称之 Slave)。在 Master 与 Slave 之间的实现整个复制过程主要由三个线程来完成,其中两个线程(Sql线程和IO线程)在 Slave 端,另外一个线程(IO线程)在 Master 端。
星哥玩云
2022/08/17
5190
mysql主从复制实现
对于ubuntu16.04和mysql 5.6,配置文件的路径为: /etc/mysql/mysql.conf.d/mysqld.cnf
羽翰尘
2019/11/20
7360
基于 SSL 实现MySQL主从复制
注:启用 mysql 支持 ssl 安全连接主要用于 mysql 主从复制(局域网可以非 ssh 连接即明文 复制,但 internet 复制建议采用 ssl 连接)
小手冰凉
2020/06/22
5380
MySQL两主(多主)多从架构配置
一、角色划分 1、MySQL数据库规划 我现在的环境是:zhdy04和zhdy05已经做好了主主架构配置,现在需要的是把两台或者多台从服务器与主一一同步。 如果搭建主主环境,参照此链接! 主机名 IP 地址 角色 Mysql_server_id zhdy04 192.168.230.145 masterA 145 zhdy05 192.168.230.146 masterB 146 zhdy06 192.168.230.147 slaveA 147 zhdy07 192.168.230.148 slaveB
老七Linux
2018/05/09
7.3K3
MySQL主从复制及读写分离
还有一个半同步复制,他在协议中添加了一个同步步骤,这意味着主节点在提交时需要等待从节点确认它已经接收到事务。只有这样,主节点才能继续提交操作。
黑马金牌编程
2022/05/01
5240
Mysql5.7主从复制配置全过程
mysql主从复制是最常见的高可用方式,通过主-从的方式,实现系统的高可用。在生产环境种,通常采用一主多从的方式,通过主库写数据,从库读数据,来提升系统的性能。 现在就演示一下,mysql5.7之下,如何配置主从复制。
冬天里的懒猫
2021/09/26
4.2K0
MySQL主从复制配置
Mysql中有一种日志叫做bin日志(二进制日志)。这个日志会记录下所有修改了数据库的SQL语句(INSERT,UPDATE,DELETE,ALTER TABLE,GRANT等等)。
Java帮帮
2018/12/24
4760
mysql架构备份之M-S-S级联复制
master需要开启二进制日志 中间的slave1也需要打开二进制日志,但是它默认不把应用master的操作记录到自己的二进制日志。所以需要打开一个参数让它记录,才可以传给第三级的从;然后在中间从和第三级从之间再做一次AB复制就可以了。 打开log-slave-updates=1,让第一台传过来relay日志记录到自己的二进制日志。
剧终
2020/08/27
1.3K0
Mysql的主从复制
答:主从同步的核心是二进制日志文件binary log,对数据库所有的增加、修改、删除操作都会在日志表里面记录一下的。mysql主从复制是异步的,串行化的,有延迟的,并不是实时的。
别先生
2020/09/01
1.3K0
Mysql的主从复制
linux下mysql主从复制
1、在本地搭建两个linux虚拟机,其主服务器ip为192.168.0.1,从服务器ip为192.168.0.2。
93年的老男孩
2019/12/18
1.4K0
Mysql主从复制的搭建及原理
这次来了解一下MySQL的主从复制,为什么要用主从复制?是什么原理? MySQL的主从复制带来很大的好处首先那就是数据复制的一致性,在生产环境中保证了数据的备份,而且主宕机后,从节点可以也可以保证正常工作, 模式有很多一主一从,一主两从,一主多从等等…
全栈程序员站长
2021/06/08
4100
Mysql主从复制的搭建及原理
MySQL主从复制
修改mysql配置文件,不同的系统my.cnf路径不同(CentOS中位于/etc/my.cnf)
十毛
2019/03/27
1.8K0
相关推荐
Java开发环境系列:MySQL实战之开启主从复制功能
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验