怎么在MySQL数据库中配置主从

59次阅读
没有评论

共计 1566 个字符,预计需要花费 4 分钟才能阅读完成。

自动写代码机器人,免费开通

怎么在 MySQL 数据库中配置主从?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面丸趣 TV 小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

1. 主设置(master)

修改 mysql 配置文件,一般在 /etc/mysql/my.conf

server-id=1 // 设置 mysql 的 id 标识
log-bin=/var/lib/mysql/mysql-bin //log-bin 的日志文件,主从备份就是用这个日志记录来实现的
#binlog-do-db=mysql1 # 需要备份的数据库名,如果备份多个数据库,重复设置这个选项   即可
#binlog-ignore-db=mysql2 # 不需要备份的数据库名,如果备份多个数据库,重复设置这   个选项即可
#log-slave-updates=1 # 这个参数当从库又作为其他从库的主库时一定要加上,否则不会给更新的记录写到 binglog 里二进制文件里
#slave-skip-errors=1 # 是跳过错误,继续执行复制操作 (可选)

在主 mysql 中增加 2 个用来同步的账号

mysql grant replication slave on *.* to  sync-1 @ %  identified by  123456 
mysql grant replication slave on *.* to  sync-2 @ %  identified by  123456

重启 msql

mysql show master status; // 可以查看主 mysql 状态 

2. 从设置(slave)

修改 mysql 配置文件 my.conf,两个从节点配置方式都一样。

server-id=2
#log-bin=/var/lib/mysql/mysql-bi // 从 mysql 可以不用设置日志文件 

在从 mysql 中增加命令参数,master_log_file 和 master_log_pos 可以在 master mysql 中用 show master status 查询到

mysql change master to master_host= 192.168.145.222 ,master_user= sync-1 ,master_password= 123456 ,master_log_file= mysql-bin.000001 ,master_log_pos=308; 
mysql start slave // 启动
mysql show slave status\G // 查询状态,Slave_IO_Running  和 Slave_IO_Running 都为 yes 表示成功 

3. 设置中的出现的问题

Last_Errno: 1146

设置出从的时候,我的主 mysql 已经有一张表了,当时创建表的 binlog 二进制日志就没有记录,从 mysql 无法写入数据,这时候只有手动导入数据库文件到从 mysql 中;原因是网上教程都是全新安装的主 msql 和从 mysql,不存在已有数据的问题。

Last_Errno: 1062
Error  Duplicate entry  xxxxx  for key  PRIMARY  on query

主键冲突,这个问题比较复杂,应该是有表的设置不对,这个问题后来在 Stack Overflow 上找到了解决办法

# on slave
mysql  stop slave;
mysql  flush privileges;
# on master rest master
mysql  reset master;
# on slave;
mysql  reset slave;
mysql  start slave;

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注丸趣 TV 行业资讯频道,感谢您对丸趣 TV 的支持。

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计1566字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)