目前在局域网两台电脑实现mysql主从复制的测试,走了一些坑,写一些经验总结。
1.环境准备:局域网的两台windows电脑,mysql5.7安装包。下载地址:https://dev.mysql.com/downloads/installer/。
1.安装:我用的是默认安装:路径会存在C:\Program Files\MySQL\MySQL Server 5.7,安装完成后,在C:\ProgramData\MySQL\MySQL Server 5.7路径下会存在一个my.ini的文件。programData路径默认隐藏,可以在“查看”中勾选“隐藏的项目”。安装完成后在path路径加入环境变量:“C:\Program Files\MySQL\MySQL Server 5.7\bin”。
2.查看两台电脑局域网ip:测试的电脑:我的是192.168.1.101(master),192.168.1.103(slave)。
3.修改master的myini配置文件
3.1 my.ini存在于C:\ProgramData\MySQL\MySQL Server 5.7路径下。在 [mysqld] 标签的最下面,添加如下代码:
binlog-do-db用于指定需要同步的数据库,binlog-ignore-db指定不需要同步的数据库,如果这两个参数都不设置,则从服务器会复制主服务器的所有数据库。
注意:此步骤修改,需要管理员权限,然后用notepad++打开,notepad++可能会修改文件编码格式,导致后续service不能重新启动,还有就是notepad++所还可能会将文件头部的注释去掉然后添加一个., 一定要仔细甄别。默认的编码格式应为utf-8,所以先建议备份一份my.ini文件。
4.创建连接master的用户名和密码.管理员模式打开cmd,切换到C:\Program Files\MySQL\MySQL Server 5.7\bin目录下
4.1 创建用户:create user 'root'@'192.168.1.103' identified by '123456'; 其中root是用于slave连接master的账户,192.168.1.103是slave的ip,123456是创建连接的密码。可以设为自己的
4.2授予权限:grant replication slave on *.* to '