MySQL MySQL主从配置——一主一从

本文详细介绍了MySQL主从复制的配置步骤,包括主从服务器的设置、账户授权、日志配置等,并讨论了复制过程中可能遇到的延时问题。通过配置,实现了数据的异步、串行化同步。

  1. master将改变记录到二进制日志(binary log)。这些记录过程叫做二进制日志事件,binary log events;

  2. slave 将 master 的 binary log events 拷贝到它的中继日志(relay log) ;

  3. slave重做中继日志中的事件,将改变应用到自己的数据库中。MySQL复制是异步的且串行化的

slave会从master读取binlog来进行数据同步

复制的原则

  • 每个slave只有一个master

  • 每个slave只能有一个唯一的服务器ID

  • 每个master可以有多个salve

复制最大的问题

会造成延时问题。

配置过程

1.准备工作

主机:CentOS 7
虚拟机 IP:192.168.63.135
MySQL 5.5

从机:CentOS 7​​ ​​​​​虚拟机
IP:192.168.63.134
MySQL 5.5

 

2.关闭防火墙

 

3.master(主)修改my.cnf

vi /etc/my.cnf

1.【必须】主服务器唯一ID
server-id =1
2.【必须】启用二进制日志
log-bin=自己本地的路径/mysqlbin
3.【可选】启动错误日志
log-err=自己本地的路径/mysqlerr
4.【可选】根目录
basedir="自己本地路径"
5.【可选】临时目录
tmpdir="自己的本地路劲"
6.【可选】数据目录
datadir="自己本地路径/Data/"
7.read-only=0
主机,读写都可以
8.【可选】设置不要复制的数据库
binlog-lgnore-db=mysql
9.【可选】设置需要复制的数据
binlog-do-db=需要复制的主数据库名字

 这里我就修改了2、3

重启mysql服务器

service mysql restart

4.slave(从)修改my.cnf

vi /etc/my.cnf

【必须】从服务器唯一ID

【可选】启用二进制文

重启mysql服务器

service mysql restart

在主机上建立账户并授权slave

# 授权
GRANT REPLICATION SLAVE  ON*.* TO 'crt'@'从机器数据库IP'IDENTIFIED BY '123456';

# 刷新
flush privileges;

# 查询master的状态
show master status; 

# 记录下File和Position的值

# 执行完此步骤后不再执行主服务器MySQL,防止主服务器状态值变化

记录 File 及 Position 的值,下面配置会用到这个参数。

在从机上配置需要复制的主机

CHANGE MASTER TO MASTER_HOST='主机IP',MASTER_USER='crt',MASTER_PASSWORD='123456',MASTER_LOG_FILE='File名字',MASTER_LOG_POS=Position数字;

# 启动从服务器复制功能
start slave;

# 查看从机状态
show slave status\G
# 下面两个参数都是YES,则说明主从配置成功!
# Slave_IO_Running:Yes
# Slave_SQL_Running:Yes

测试

总结

MySQL 主从配置并不难,只要细心配置就可以。

注意:主机新建库、新建表、insert记录,从机复制,从库并不会复制主库的之前的数据。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值