文件服务器主从读写权限分离,CentOS7,MySQL主从配置和读写分离(MySQL主从、MySQL读写分离、MySQL分布式、数据库读写分离、主从配置)...

1、实验目标

搭建两台MySQL服务器,一台做为主服务器,一台做为从服务器,主服务器进行写操做,从服务器进行读操做。

2、测试环境

主数据库: CentOS7, MySQL15.1 , 192.168.1.233

从数据库: CentOS7, MySQL15.1 , 192.168.1.234

3、主从配置步骤

一、确保主数据库与从数据库里的数据同样

例如:主数据库里的a的数据库里有b,c,d表,那从数据库里的就应该有一个模子刻出来的a的数据库和b,c,d表

我这里在两台MySQL上都建立了个名为“test”的数据库来测试,如图:

b47985499bdd8c2ee017d84566718570.png

二、在主数据库里建立一个同步帐号

1)每一个从数据库会使用一个MySQL帐号来链接主数据库,因此咱们要在主数据库里建立一个帐号,而且该帐号要授予 REPLICATION SLAVE 权限,你能够为每一个从数据库分别建立帐号,固然也能够用同一个!)

2)你能够用原来的帐号不必定要新创帐号,但你应该注意,这个帐号和密码会被明文存放在master.info文件中,所以建议单首创一个只拥有相关权限的帐号,以减小对其它帐号的危害!)

3)建立新帐号使用“CREATE USER”,给帐号受权使用“GRANT”命令,若是你仅仅为了主从复制建立帐号,只须要授予REPLICATION SLAVE权限。

4)下面来建立一个帐号,帐号名:repl,密码:repl123,只容许192.168.1.的IP段登陆,以下:

mysql> CREATE USER 'repl'@'192.168.1.%' IDENTIFIED BY 'repl123';

mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'192.168.1.%';

5)若是开发防火墙,可能要配置下端口,以下:

firewall-cmd --zone=public --add-port=3306/tcp --permanent

firewall-cmd --reload

三、配置主数据库

1)要主数据库,你必需要启用二进制日志(

binary logging),而且建立一个惟一的Server ID,这步骤可能要重启MySQL。

2)主服务器发送变动记录到从服务器依赖的是二进制日志,若是没启用二进制日志,复制操做不能实现(主库复制到从库)。

3)复制组中的每台服务器都要配置惟一的Server ID,取值范围是1到

(2

32

)−1,你本身决定取值。

4)配置二进制日志和Server ID,你须要关闭MySQL和编辑my.cnf或者my.ini文件,在 [mysqld] 节点下添加配置。

5)下面是启用二进制日志,日志文件名以“mysql-bin”做为前缀,Server ID配置为1,以下:

[mysqld]

log-bin=mysql-bin

server-id=1

#网络上还有以下配置

#binlog-do-db=mstest //要同步的mstest数据库,要同步多个数据库,就多加几个replicate-db-db=数据库名 #binlog-ignore-db=mysql //要忽略的数据库

提示1:若是你不配置server-id或者配置值为0,那么主服务器将拒绝全部从服务器的链接。

提示2:在使用InnoDB的事务复制,为了尽量持久和数据一致,你应该在my.cnf里配置innodb_flush_log_at_trx_commit=1 和 sync_binlog=1;

For the greatest possible durability and consistency in a replication setup using

InnoDB

with transactions, you should use

innodb_flush_log_at_trx_commit=1

and

sync_binlog=1

in the master

my.cnf

file.

提示3:确保主服务器里的skip-networking选项未启用,若是网络被禁用,你的从服务器将不能与主服务器通讯而且复制失败。

注意:

实际操做发现 /etc/my.cnf文件和教材说的不同,可能我装的是MariaDB,以下:

97d61ddb0b513b676162200415808758.png

目测文件被放到了 /etc/my.cnf.d 目录里,以下:

e09a0b32e3d0b36eaf335e0181f3f9af.png

在 /etc/my.cnf.d/server.cnf 增长相关配置,以下:

83a960b7413e8e96ad72ab25e122716e.png

重启MySQL,如图:

24f9826441d50dd5221b5fe5739bd5a1.png

查看主服务器状态,mysql> show master status;, 如图:

184370fcfd3f4b3f5eed6550a968dae7.png

(注意:记录好File和Position,后面要用)

四、配置从数据库

1)从服务器,同理,要分配一个惟一的Server ID,须要关闭MySQL,修改好后再重启,以下:

[mysqld]

server-id=2

#能够指定要复制的库

replicate-do-db = test #在master端不指定binlog-do-db,在slave端用replication-do-db来过滤

replicate-ignore-db = mysql #忽略的库

#网上还有下面配置

#relay-log=mysqld-relay-bin

提示1:若是有多个从服务器,每一个服务器的server-id不能重复,跟IP同样是惟一标识,若是你没设置server-id或者设置为0,则从服务器不会链接到主服务器。

提示2:通常你不须要在从服务器上启用二进制日志,若是你在从服务器上启用二进制日志,那你可用它来作数据备份和崩溃恢复,或者作更复杂的事情(好比这个从服务器用来看成其它从服务器的主服务器)。

2)配置链接主服务器的信息

mysql> stop slave;

mysql> CHANGE MASTER TO

-> MASTER_HOST='192.168.1.233',

-> MASTER_USER='repl',

-> MASTER_PASSWORD='repl123',

-> MASTER_LOG_FILE='mysql-bin.000002',

-> MASTER_LOG_POS=313;

mysql> start slave;

3)查看从服务器状态

mysql> show slave status \G;

e1fa5fc0314b2a98c1e7e9ee2d122dde.png

五、测试数据同步

测试,链接主服务器 192.168.1.233,添加了表 stu_user,

而后再链接上 192.168.1.234,发现也本身同步建立了表 stu_user,如图:

35c8246a52ec1996c009aa1e5ba07b20.png

而后在主数据库添加一条记录,从数据库也自动添加了记录,如图:

b35ab91dbe3600e0d99873085f954480.png

至此,主从的配置已经完成了, 目前是在从库里面配置复制“test”这个库,

若是要添加其它库,能够在主服务器中添加“binlog-do-db”配置,或者在从服务器中添加“replicate-do-db”配置。

4、读写分离实现

主从配置是读写分离的前提,如今前提已经配置好了,读写分离就看具体项目的实现,

读写分离,就是“写”的操做都在主数据库,“读”的操做都在从数据库!

这里我选用一个比较轻量的框架SpeedPHP来作读写分离演示,

这个框架作读写分离很是简单,按要求在配置文件填好信息便可,如图:

1f777a18abb13401d767a77b53f0eef0.png

简单写了些增长/删除/查询的方法,如图:

da05500f15c07421012f03199117da0e.png

05fea21fb413377298b2483942211360.png

页面效果以下图:

1bfbee4fbffeefe7ddb63d9c314d4210.png

再来看看两个数据库,信息一致,如图:

f0743e085c9a3e1da1f53ea2b508acb2.png

这个例子中,

读取帐号列表的是从 192.168.1.234 (从数据库)上面的数据库操做的,

添加和删除帐号是从 192.168.1.233 (主数据库)上面的数据库操做的,

实现了读写分离!

(完)

参考:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值