[ACDU翻译] MySQL 17.2.3 复制线程

MySQL 复制功能使用三个主线程实现,一个在源服务器上,两个在副本上:

  • 二进制日志转储线程。 当副本连接时,源创建一个线程以将二进制日志内容发送到副本。该线程可以在SHOW PROCESSLIST源上的输出中标识为该Binlog Dump线程。

    二进制日志转储线程获取源二进制日志上的锁,以读取要发送到副本的每个事件。一旦事件被读取,锁就会被释放,甚至在事件被发送到副本之前。

  • 复制 I/O 接收器线程。START REPLICA在副本服务器上发出语句时,副本会创建一个 I/O(接收器)线程,该线程连接到源并要求它发送记录在其二进制日志中的更新。

    复制接收者线程读取源Binlog Dump线程发送的更新(参见上一项)并将它们复制到组成副本中继日志的本地文件中。

    该线程的状态如 Slave_IO_running的输出 所示SHOW SLAVE STATUS

  • 复制 SQL 应用程序线程。 副本创建一个 SQL(应用程序)线程来读取由复制接收线程写入的中继日志并执行其中包含的事务。

每个源/副本连接都有三个主线程。具有多个副本的源为每个当前连接的副本创建一个二进制日志转储线程,并且每个副本都有自己的复制接收者和应用程序线程。

副本使用两个线程将读取更新与源分开并将它们执行到独立的任务中。因此,如果应用它们的过程很慢,读取事务的任务不会减慢。例如,如果副本服务器有一段时间没有运行,它的接收线程可以在副本启动时快速从源获取所有二进制日志内容,即使应用程序线程远远落后。如果副本在 SQL 线程执行完所有获取的语句之前停止,则接收线程至少已获取所有内容,以便将事务的安全副本本地存储在副本的中继日志中,以备下次副本启动时执行.

replica_parallel_workers您可以通过将系统变量(来自 MySQL 8.0.26)或 slave_parallel_workers(在 MySQL 8.0.26 之前)设置为大于 0(默认值)的值来 为副本上的任务启用进一步的并行化 。设置此系统变量后,副本会创建指定数量的工作线程来应用事务,以及一个协调线程来管理它们。如果您使用多个复制通道,则每个通道都有此数量的线程。具有 replica_parallel_workersslave_parallel_workers设置为大于 0 的值的副本称为多线程副本。使用此设置,可以重试失败的事务。

笔记

NDB Cluster 当前不支持多线程副本,它会默默地忽略此变量的设置。有关更多信息,请参阅第 23.7.3 节,“NDB 集群复制中的已知问题”


免责声明:

1、本站资源由自动抓取工具收集整理于网络。

2、本站不承担由于内容的合法性及真实性所引起的一切争议和法律责任。

3、电子书、小说等仅供网友预览使用,书籍版权归作者或出版社所有。

4、如作者、出版社认为资源涉及侵权,请联系本站,本站将在收到通知书后尽快删除您认为侵权的作品。

5、如果您喜欢本资源,请您支持作者,购买正版内容。

6、资源失效,请下方留言,欢迎分享资源链接

文章评论

0条评论