MySQL数据库复制操作大致可以分成三个步骤,见下图:

1.主服务器将数据的改变或更新记录到二进制日志中。
2.从服务器将主服务器的binlog events复制到自己的中继日志(relay log)中。
3.从服务器SQL线程会读取relay-log日志的内容,完全顺序的执行日志中所记录的各种操作,将其应用到从服务器。
主从同步的详细过程如下:
主服务器验证连接。
主服务器为从服务器开启一个线程。
从服务器将主服务器日志的偏移位告诉主服务器。
主服务器检查该值是否小于当前二进制日志偏移位。
如果小于,则通知从服务器来取数据。
从服务器持续从主服务器取数据,直至取完,这时,从服务器线程进入睡眠,主服务器线程同时进入睡眠。
当主服务器有更新时,主服务器线程被激活,并将二进制日志推送给从服务器,并通知从服务器线程进入工作状态。
从服务器SQL线程执行二进制日志,随后进入睡眠状态。

1.主服务器将数据的改变或更新记录到二进制日志中。
2.从服务器将主服务器的binlog events复制到自己的中继日志(relay log)中。
3.从服务器SQL线程会读取relay-log日志的内容,完全顺序的执行日志中所记录的各种操作,将其应用到从服务器。
主从同步的详细过程如下:
主服务器验证连接。
主服务器为从服务器开启一个线程。
从服务器将主服务器日志的偏移位告诉主服务器。
主服务器检查该值是否小于当前二进制日志偏移位。
如果小于,则通知从服务器来取数据。
从服务器持续从主服务器取数据,直至取完,这时,从服务器线程进入睡眠,主服务器线程同时进入睡眠。
当主服务器有更新时,主服务器线程被激活,并将二进制日志推送给从服务器,并通知从服务器线程进入工作状态。
从服务器SQL线程执行二进制日志,随后进入睡眠状态。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/15498/viewspace-2125537/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/15498/viewspace-2125537/