MySQL生产环境一主一从搭建

mysql主从同步的原理:
1.首先master将数据更新记录到二进制日志文件
2.从slave start开始,slave通过I/O线程向master请求二进制日志文件指定位置之后的内容
3.master接收到slave的io请求之后,就会从相应的位置点开始,给slave传日志
4.slave接收到日志后,会写入本地的中继日志中
5.slave通过sql线程读取中继日志的内容,在数据库中执行相应的操作,到此为止,master和slave上的数据一致,之后slave服务器进入等待状态,等待master的后续更新

基本构建思路
1.配置主服务器
1.1 启用binlog日志
1.2 进行授权用户
1.3 查看当前使用的日志
2.配置从服务器
2.1 设置server_id
2.2指定主库信息(change命令)
2.3.客户端连接主服务测试,查看主从是否同步.
#############################
适用于master服务器的各种选项
binlog_do_db=name #master对哪个库记日志
binlog_ignore_db=name #master对哪个库不记日志
适用于slave服务器
log_slave_updates #记录从库更新,允许链式复制
master.info #主库信息
relay-log.info #中继日志信息
主机名-relay-bin.xxxxxx #中继日志
主机名-relay-bin.index #索引文件
#############################
50主库服务
1.启动binlog日志
vim /etc/my.cnf
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
plugin-dir=/usr/lib64/mysql/plugin
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

server-id=1
log-bin=mysql-bin
plugin-load=“rpl_semi_sync_master=semisync_master.so;rpl_semi_sync_slave=semisync_slave.so”
bind-address=0.0.0.0
default-storage-engine=innodb
innodb_file_per_table
collation-server = utf8_general_ci
character-set-server=utf8
init-connect=‘SET NAMES utf8’
innodb_flush_log_at_trx_commit=1
sync_binlog=1
rpl-semi-sync-master-enabled=1
rpl_semi_sync_master_timeout=3000
innodb_buffer_pool_load_at_startup=1
innodb_buffer_pool_load_now=1
sql-mode=“STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION”

2.重启服务
]# systemctl restart mysqld
3.主库授权给从库
mysql>grant replication slave on . to repluser@"%" identified by “123456”;
mysql>flush privileges;
mysql>show master status; #查看日志信

51从库服务
1.指定server_id
vim /etc/my.cnf
[mysqld]
#basic config
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
bind-address=0.0.0.0
character-set-server=utf8
default-storage-engine=innodb
innodb_file_per_table
collation-server = utf8_general_ci
init-connect = ‘SET NAMES utf8’
innodb_flush_log_at_trx_commit=1
#semi sync config for master and slave
server-id=2
log-bin=mysql-bin
sync_binlog=1
plugin-dir=/usr/lib64/mysql/plugin
plugin-load=“rpl_semi_sync_master=semisync_master.so;rpl_semi_sync_slave=semisync_slave.so”
rpl_semi_sync_slave_enabled=1
#rpl_semi_sync_master_timout=3000

sql-mode=“STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION”

2.重启服务
systenctl restart mysqld
3.进入数据库指定主库信息
mysql> change master to
-> master_host=“192.168.4.50”,master_user=“repluser”,
-> master_password=“123456”,
-> master_log_file=“master50.000001”,
-> master_log_pos=441;
mysql> start slave;
mysql> show slave status\G;
若报错查看具体报错信息

主从同步测试
在主机上创建库与表 查看从库上面是否有新建的库与表

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值