接触php已快有3年了,一直想有所突破,最近看了下分布和数据库读写分离。总算也小有成果.....前段时间发布了,用ngix实现分流
今天就来分享一下,数据库读写分离并且同步。我目前,介绍的是1台写入服务器,n台读取服务器....
写这个的同时,我在思考一个问题,如果写入压力过大的时候,1台服务器写入不够用,那么写入该怎么办!利用队列,缓存!一台服务器慢慢写?还求大神给解释,求带!
mysql的配置我就不多说了,看我 另一篇文章
我是再这个环境下做测试的,我是配置了1台。利用VMware Workstation拷贝出来多台服务器的,所以环境绝对一样。
主数据库服务器:192.168.10.130
从数据库服务器:192.168.10.131
修改从服务器的配置文件,my.cnf 不一定路径和我一样哦,注意修改
vi etc/my.cnf确定 server-id = 1,并确保这个ID没有被别的MySQL服务所使用。
启动mysql服务(192.168.10.130)
/etc/init.d/mysqld start
mysql -uroot -p
mysql> GRANT REPLICATION SLAVE ON *.* to 'rep1'@'192.168.10.131' identified by '123';
Mysql> show master status;+------------------+----------+--------------+------------------+
vi etc/my.cnf将 server-id = 1修改为 server-id = 2,并确保这个ID没有被别的MySQL服务所使用。
/opt/mysql/init.d/mysql start
mysql -uroot -p
注意上面的数据要和主服务器一样,否则同步会失败!
正确执行后启动Slave同步进程
mysql> start slave;
mysql> show slave status\G
如果不是,请检查上面是否那一步骤有问题!可以留言给我。。。如果都YES 可以进入下一步操作
锁定主服务器mysql:
mysql> FLUSH TABLES WITH READ LOCK;
mysql> FLUSH TABLES WITH READ LOCK;
开启主服务器mysql:
mysql> UNLOCK TABLES;
mysql> UNLOCK TABLES;
在主服务器上操作:
mysql> create database first_db; mysql> use first_db; mysql> create table first_tb(id int(3),name char(10)); mysql> INSERT INTO `first_tb` VALUES ('1', '1');
mysql> show databases;=============================
数据已经同步过来了。现在只要在主服务器上有任何操作,都会自动同步到从服务器来。