MySQL手册版本 5.0.20-MySQL同步(二)

2016-01-29 13:51 1 1 收藏

MySQL手册版本 5.0.20-MySQL同步(二),MySQL手册版本 5.0.20-MySQL同步(二)

【 tulaoshi.com - PHP 】

6.4 设置同步

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

以下描述了如何快速设置MySQL同步服务器。假设你打算同步全部的数据库,并且之前没有设置过。需要关闭master服务器以完成全部的步骤。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

本章描述的过程可以用于一个slave的情况,也可以用于多个slave的情况。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

这只是一个最直接设置slave的办法,并不是只有一个。例如,已经有了master的数据快照(snapshot),master已经设置了服务器编号ID(server_id)并且启用了二进制日志,这就无需关闭master或者阻止在master上更新数据了。详情请看"6.9 Replication FAQ"。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

想要完全掌握MySQL同步设置,最好把本章全部读完,并且测试在"14.6.1 SQL Statements for Controlling Master Servers"和"14.6.2 SQL Statements for Controlling Slave Servers"中提到的全部语句。而且要熟悉各种同步设置选项,详情请看"6.8 Replication Startup Options"。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

注意,这个过程以及后面一些同步SQL语句需要有 SUPER 权限。MySQL 4.0.2以前,则是 PROCESS 权限。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

请确认master和slave上都安装了较近的MySQL版本,且这些版本之间要能兼容,在"6.5 Replication Compatibility Between MySQL Versions"中列出来了。请确认在最新版本中还有存在问题,否则不要报告该bug。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

在master上新加一个帐户,slave才能用它来连接。这个帐户必须授予 REPLICATION SLAVE 权限。如果这个帐户只用于同步(推荐这么做),那就没必要授予其他权限了。设定你的域是 mydomain.com,想要授权一个帐户 repl 使用密码 slavepass,允许它可以在域里的任何主机连接到master上。用 GRANT 语句来创建帐户:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

mysql GRANT REPLICATION SLAVE ON *.*

- TO 'repl'@'%.mydomain.com' IDENTIFIED BY 'slavepass';

在MySQL 4.0.2以前,用 FILE 权限来代替 REPLICATION SLAVE:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

mysql GRANT FILE ON *.*

- TO 'repl'@'%.mydomain.com' IDENTIFIED BY 'slavepass';

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

如果打算在slave上执行 LOAD TABLE FROM MASTER 或 LOAD DATA FROM MASTER 语句,那么必须给该帐户授予附加权限:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

授予全局 SUPER 和 RELOAD 权限。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

授予对想要加载的所有表上的 SELECT 权限。在master上任何没有 SELECT 权限的表都会被 LOAD DATA FROM MASTER 略过。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

如果只用到 MyISAM 表,执行 FLUSH TABLES WITH READ LOCK 语句刷新所有表并且阻止其他写入:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

mysql FLUSH TABLES WITH READ LOCK;

不要退出执行 FLUSH TABLES 语句的客户端,以保持读锁有效(如果退出了,读锁就释放了)。然后从master上取得数据快照。比较简单的办法就是把数据目录打包压缩。例如,Unix上的 tar, PowerArchiver, WinRAR, WinZip,或Windows上的类似程序。想要用 tar 来创建一个压缩包,包括所有的数据库,只需执行以下命令(把目录改成你的真实路径):

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

shell tar -cvf /tmp/mysql-snapshot.tar .

如果只想打包一个数据库 this_db,只需执行命令:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

shell tar -cvf /tmp/mysql-snapshot.tar ./this_db <

来源:https://www.tulaoshi.com/n/20160129/1491736.html

延伸阅读
标签: PHP
可以在锁表后,一起执行几个语句来加速 INSERT 操作: LOCK TABLES a WRITE; INSERT INTO a VALUES (1,23),(2,34),(4,33); INSERT INTO a VALUES (8,26),(6,29); UNLOCK TABLES; 这对性能提高的好处在于:直到所有的 INSERT 语句都完成之后,索引缓存一次性刷新到磁盘中。通常情况是,多有少次 INSERT 语句就会...
标签: PHP
想要提高 ORDER BY 的速度,首先要看MySQL能否使用索引而非额外的排序过程。如果不能使用索引,可以试着遵循以下策略: 增加 sort_buffer_size 的值。 增加 read_rnd_buffer_size 的值。 修改 tmpdir,让它指向一个有很多剩余空间的专用文件系统。如果使用MySQL 4.1或更新,这个选项允许有多个路径用循环的格...
标签: PHP
通常地,应该保存所有的冗余数据(在数据库原理中叫做"第三范式")。然而,为了能取得更高的效率复制一些信息或者创建摘要表也是划算的。 存储过程或者 UDFs(用户定义函数) 的方式在执行一些任务时可能性能更高。尽管如此,当数据库不支持这些特性时,还是有其他的替代方法可以达到目的,即使它们有点慢。 可...
标签: PHP
7.2.12 加速 INSERT 插入一条记录花费的时间由以下几个因素决定,后面的数字大致表示影响的比例: 连接:(3) 发送查询给服务器:(2) 解析查询:(2) 插入记录:(1 x 记录大小) 插入索引:(1 x 索引数量) 关闭:(1) 这里并没有考虑初始化时打开数据表的开销,因为每次运行查询只会做这么一次...
mysql从3.23.15版本以后提供数据库复制功能。利用该功能可以实现两个数据库同步,主从模式,互相备份模式的功能。 数据库同步复制功能的设置都在mysql的设置文件中体现。mysql的配置文件(一般是my.cnf),在unix环境下在/etc/mysql/my.cnf 或者在mysql用户的home目录下的my.cnf。 window环境中,如果c:根目录下有my.cnf文件则...

经验教程

520

收藏

76
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部