在阿里云Centos7.6上面配置Mysql主从数据库

在阿里云Centos7.6上面配置Mysql主从数据库(master/slave),实现读写分离

mysql主从同步的原理很简单,从库生成两个线程,一个I/O线程,一个SQL线程;i/o线程去请求主库 的binlog(二进制日志),并将得到的binlog日志写到relay log(中继日志) 文件中;主库会生成一个 log dump 线程,用来给从库 i/o线程传binlog;

SQL 线程,会读取relay log文件中的日志,并解析成具体操作,来实现主从的操作一致,而最终数据一致。

进入master服务器

修改mysql配置文件 vim /etc/my.cnf,加入如下配置

server-id=1 
innodb_flush_log_at_trx_commit=2 
sync_binlog=1 
log-bin=mysql-bin-1

配置说明:

#设置主服务 的ID (id可以自己随便设置但是要保证和slave的id不一样)
server-id=1

#设为1当然是最安全的,但性能也是最差的(相对其他两个参数而言,但不是不能接受)。如果对数据一致性和完整性要求不高,完全可以设为2,如果只最求性能,例如高并发写的日志服务器,设为0来获得更高性能
innodb_flush_log_at_trx_commit=2

#开启binlog 志同步功能
sync_binlog=1

#binlog 日志文件名
log-bin=mysql-bin-200

# 这个表示只同步某个库 (如果没有此项,表示同步所有的库)
binlog-do-db=xxxx

保存后,重启mysql

systemctl restart mysqld

进入mysql命令行 mysql -uroot -p你的密码

输入授权命令

需要注意账号问题:
如果使用新账号,那么在用新账号登录mysql时是一个全新的数据库,如下图
库里只有 informaton_schema表
在这里插入图片描述
如果使用默认账号root 则如下图所有的数据都存在,只不过远程连接的密码会被授权密码覆盖
如下图:使用root登录mysql主服务器所有表都在
在这里插入图片描述

GRANT REPLICATION SLAVE ON *.* to 'repl'@'%' identified by 'Admin123!'; 

意思是所有slave都可以通过账号repl和密码Admin123!来同步master的数据

然后查看master的状态:

show master status;

在这里插入图片描述

把file列和Position列记录下来,一会配置slave要用到

此时Master的配置已经搞定,登录一下从机(slave)

同理修改slave服务器的mysql配置 vim /etc/my.cnf 加入下面的配置,需要注意的是server-id不要和master一样

server-id=201  innodb_flush_log_at_trx_commit=2  sync_binlog=1  log-bin=mysql-bin-201

保存后重启服务 systemctl restart mysqld

进入mysql命令行 mysql -uroot -p你的密码

输入命令:

change master to master_host='39.106.228.179',master_user='repl' ,master_password='Admin123!', master_log_file='mysql-bin.000002' ,master_log_pos=154

命令说明:

master_host: 主机的ip

master_user : 主机授权的用户.

master_password : 主机授权时候填写的密码

master_log_file : 主机show master status;中的File

master_log_pos: 主机show master status;中的Position.

输入命令启动slave

start slave;可以查看slave的状态:

show slave status \G;  如下图则成功

在这里插入图片描述

然后我们就可以测试一下对master进行写入,看看salve是否可以同步数据了

跨主机备份

 使用下面的命令可以将host1上的sourceDb复制到host2的targetDb,前提是host2主机上已经创建targetDb数据库
mysqldump --host=host1 --opt sourceDb| mysql --host=host2 -C targetDb

当然了,mysql的读写分离主从配置并不是万能的,根据不同的应用场景选择不同的策略,MySQL的主从复制功能有一定的延迟性,如果对数据实时一致性的要求比较高的场景不推荐使用。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值