IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

标签:数据库复制

共 4 篇相关文章

IT 累计浏览 5,404

MySQL5.5数据库复制搭建报错之Could not initialize master info structure

这篇讲的是MySQL5.5主从复制搭建过程中,因一个细节疏忽引发的连锁错误排查。作者从一个实际项目出发,由于服务器配置特殊且需求方指定版本,被迫使用MySQL5.5.27,并在配置双主复制时遭遇了两个错误。 首先,因遗漏了中继日志目录的属主变更,执行`CHANGE MASTER TO`命令时报错“File not found (Errcode: 13)”。修正权限后,问题并未解决,错误日志显示“Could not initialize master info structure”,这个提示颇具迷惑性。 经过深入排查,真正的根因浮出水面:数据目录下存在一个0字节的空`master.info`文件,它导致MySQL无法初始化主库信息结构。删除这个异常文件后,再次执行复制配置命令便成功了。文章最后总结道,这个坑的根源在于前期工作不严谨,而解决问题则需要不被表面现象迷惑,进行正反向的深入分析。

IT 累计浏览 3,495

MySQL半同步复制(Semisynchronous Replication)

这篇讲的是MySQL 5.5版本引入的半同步复制机制。文章从一个实际需求出发:在传统的异步复制中,主库提交事务后并不关心从库是否已经接收,这可能导致短暂的数据不一致窗口。半同步复制正是为了解决这个问题。 它的核心在于修改了复制的确认流程。当主库的一个事务提交后,它不会立即返回成功给客户端,而是会等待至少一个从库确认已接收到该事务的二进制日志(并写入中继日志)。这个“至少一个”的保证,有效避免了主库宕机时可能发生的最新数据丢失,相比异步复制提供了更高的一致性保障。 文章也阐明了这种机制的权衡:因为它需要网络往返等待确认,所以会增加写操作的延迟。作者分析了这使得半同步复制特别适合那些对数据一致性要求极高、可以接受一定性能损耗的金融、交易类系统。而对于读多写少、能容忍极小概率数据回滚的场景,传统的异步复制可能仍是更高效的选择。

IT 累计浏览 2,091

MySQL表名映射方案及扩展应用

这篇讲的是如何用一个简单方案,优雅地解决MySQL主从架构下需求不一致带来的麻烦。问题很典型:主库为了扛住高并发,做了分库分表;但从库要支持各种复杂的多维查询,不分表又更方便。让同一套代码维护两套完全不同的表结构,显然不现实。 作者给出的核心思路是“表名映射”。简单说,就是在代码层面维护一个映射规则,让访问分库分表的主库时,自动转换到正确的物理表名(比如 `order_2023`),而访问从库时,则统一使用一个聚合的逻辑表名(比如 `order_all`)。这样,业务查询代码可以保持统一,不用关心底层存储差异。 方案的巧妙之处在于它的轻量和可扩展性。它不依赖复杂的中间件,实现成本低,并且这个映射思想可以推广到其他场景,比如多活架构中的库表路由、或者灰度发布时的数据隔离。核心是解耦了业务逻辑与底层数据分布,让架构更灵活。

IT 累计浏览 2,399

mysql中now和sysdate的区别

这篇讲的是开发者在实际运维中遇到的一个诡异现象:同一条记录,在MySQL主库和备库上查询到的创建时间戳竟然不一致。起初怀疑是系统时钟漂移,但考虑到binlog本身带有时间戳,这个猜测很快被推翻。 经过排查,根本原因被定位到了`NOW()`与`SYSDATE()`这两个看似相似的函数上。文章指出了它们的核心差异:`NOW()`返回的是语句开始执行时的时间点,在一个事务中所有语句看到的`NOW()`值都是相同的;而`SYSDATE()`返回的则是函数实际被调用时的实时系统时间。在基于语句的复制(SBR)模式下,备库重放binlog时,`SYSDATE()`的取值时机与主库执行时必然存在微小的时间差,这就导致了数据不一致。 作者不仅解释了原理,也给出了解决方案:要么在会话级别设置`SET SQL_LOG_BIN=0`或`SET TIMESTAMP`来固定时间,要么在业务代码和DDL中统一使用`NOW()`或明确转换成`UTC_TIMESTAMP()`。这个案例生动地说明了,在分布式和复制架构中,对时间函数的细微差别保持敬畏,是保证数据一致性的关键细节。