mysql主从复制和读写分离

本文详细介绍MySQL主从复制配置步骤,包括修改主从服务器配置文件、授权从服务器连接、设置复制日志指针等关键操作,并介绍如何解决常见的复制问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.修改master配置my.ini
[mysqld]

log-bin=mysql-bin
log-bin-index=mysql-bin.index
server-id=1
sync_binlog=1
binlog_format=mixed
binlog-do-db=wzk
binlog-ignore-db=mysql
binlog-ignore-db=performance_schema
binlog-ignore-db=information_schema

2.运行命令,授权给从服务器连接到主服务器的用户名和密码
GRANT REPLICATION SLAVE ON *.*TO 'root'@'127.0.0.1' IDENTIFIED BY '';

3.查看主服务器的状态

4.修改从服务器的配置和端口
[mysqld]

server-id=2
port=3307
log-bin=mysql-bin
relay-log-index=slave-relay-bin.index
relay-log=slave-relay-bin
sync_master_info=1
sync_relay_log=1
sync_relay_log_info=1

5.启动从服务器,连接从服务器

6.设置从服务器连接主服务器的信息和日志指针位置
change master to master_host='127.0.0.1',master_user='root',master_port=3306,master_password='',master_log_file='mysql-bin.000002',master_log_pos=326;

查看从服务的配置状态
show slave status \G;
如果Slave_IO_Running:No

则可能原因是(也可能是其他原因):
查看日志PC-20160712ZJIE.err(不同电脑的可能名称不同)

报错:
[ERROR] Slave I/O: 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. Error_code: 1593
解决方法是:
文件auto.cnf中的server-uuid和主数据库的一样,随便修改一位即可。

查看从服务的配置状态
Slave_IO_Running:Yes
Slave_SQL_Running:Yes
则代表成功。
6.在主数据库操作test库,在从服务器能看到同步效果。
7.配置读写分离,用mysql-porxy
8.建立一个conf文件夹和mysql-porxy.conf

[mysqld]

log-bin=mysql-bin
log-bin-index=mysql-bin.index
server-id=1
sync_binlog=1
binlog_format=mixed
binlog-do-db=wzk
binlog-ignore-db=mysql
binlog-ignore-db=performance_schema
binlog-ignore-db=information_schema

9.启动代理服务
mysql-proxy -P 127.0.0.1:4040 --defaults-file=C:/JavaSofts/mysql-proxy-0.8.5-windows-x86-32bit/conf/mysql-proxy.conf

10.将java数据库连接mysql的url替换即可
mysql.url=jdbc:mysql://localhost:3306/wzk
替换
mysql.url=jdbc:mysql://localhost:4040/wzk
<think>嗯,用户想知道MySQL在分布式系统中如何配置主从复制读写分离,以及它们的原理。首先,我需要回忆主从复制的基本流程。主库记录二进制日志,从库通过IO线程读取这些日志,然后SQL线程重放,对吧?这确保了数据一致性。不过用户可能还需要知道具体的配置步骤,比如修改my.cnf文件,创建复制用户,还有CHANGE MASTER命令这些步骤。 然后是读写分离的部分。主库处理写操作,从库处理读操作,这样可以提升性能。但用户可能关心如何实现自动的读写分离,可能需要中间件或者框架支持,比如MyCat或ShardingSphere。这部分需要解释清楚原理,以及配置方法。 另外,用户可能对主从复制的同步机制有疑问,比如异步、半同步全同步的区别,以及各自的优缺点。异步可能性能好但有数据丢失风险,半同步则是在两者之间平衡。需要解释这些模式适用场景。 还有,读写分离带来的数据一致性问题。主从同步有延迟的话,读从库可能拿到旧数据。需要讨论如何解决,比如强制读主库或者监控延迟。用户可能在实际应用中遇到这个问题,所以解决方案很重要。 最后,用户可能想知道高可用性的扩展,比如主库故障时的切换,或者如何监控复制状态。这部分可以提到MHA或者Keepalived这样的工具,帮助提升系统的可靠性。 现在要确保回答结构清晰,分步骤讲解配置,再讲原理,最后讨论注意事项扩展。同时需要引用提供的资料,比如引用[2]提到动态切换分库分表,可能主从配置有关联。但用户的问题更聚焦在主从复制读写分离,所以重点应该放在这里。需要检查引用内容是否相关,适当引用。比如引用[3]提到集中式授权,可能权限配置有关,但可能不太直接相关。可能更多参考引用[2]关于分库分表的动态切换,但主从复制是基础,需要明确区分。 还要生成相关问题,比如主从延迟如何处理,半同步配置,或者读写分离中间件的选择。这些问题能帮助用户深入理解。确保回答中的LaTeX格式正确,数学表达式用$...$,独立公式用$$...$$,并且正确使用引用标记。</think>### MySQL主从复制读写分离的实现原理与配置 #### 一、主从复制核心原理 1. **二进制日志(Binlog)机制** 主库将所有数据变更操作记录到二进制日志中,格式为$binlog\_format=ROW|STATEMENT|MIXED$[^1]。从库通过I/O线程实时拉取主库的Binlog,并写入本地中继日志(Relay Log)。 2. **数据同步流程** $$ \begin{aligned} &\text{主库写入} \rightarrow binlog \xrightarrow[\text{网络传输}]{\text{I/O线程}} relay\ log \xrightarrow{\text{SQL线程}} \text{从库数据} \\ &\Delta t_{同步} = t_{网络} + t_{SQL解析} + t_{从库写入} \end{aligned} $$ 延迟主要受网络带宽、从库硬件性能事务复杂度影响[^2]。 #### 二、配置步骤详解 1. **主库配置** (`my.cnf`) ```ini [mysqld] server-id=1 log-bin=mysql-bin binlog_format=ROW ``` 2. **从库配置** (`my.cnf`) ```ini [mysqld] server-id=2 relay-log=mysql-relay ``` 3. **建立复制链路** ```sql -- 主库创建复制账号 CREATE USER 'repl'@'%' IDENTIFIED BY 'password'; GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%'; -- 从库执行 CHANGE MASTER TO MASTER_HOST='master_ip', MASTER_USER='repl', MASTER_PASSWORD='password', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=154; ``` #### 三、读写分离实现方案 1. **中间件方案** 使用MyCat/ProxySQL等中间件,配置规则: ```sql -- 写路由 INSERT/UPDATE/DELETE -> 主库 -- 读路由 SELECT -> 从库(支持负载均衡) ``` 2. **客户端分离方案** 在ORM框架(如MyBatis)中通过注解指定数据源: ```java @DataSource("master") public void insertData(...); @DataSource("slave") public List<Data> queryData(...); ``` #### 四、关键注意事项 1. **复制延迟问题** - 强制读主库:`/* FORCE_MASTER */ SELECT ...` - 并行复制:设置`slave_parallel_workers=8` - 半同步复制:`rpl_semi_sync_master_timeout=1000` 2. **高可用扩展** 采用MHA+Keepalived实现主库故障自动切换,VIP漂移时间可控制在10-30秒[^3]。 ```mermaid graph TD A[应用层] --> B{SQL类型} B -->|写操作| C[主库] B -->|读操作| D[从库集群] C --> E[Binlog] E --> F[从库I/O线程] F --> G[Relay Log] G --> H[从库SQL线程] ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值