windows10 mysql主从复制配置
程序员文章站
2023-01-15 13:15:02
注意:mysql主从复制,主从版本要一致! 生手永远在学习的路上,为了学习mysql主从复制,实现读写分离,于是在本地安装多个mysql实例来进行验证。 也因此有了下面的笔记,一来自我总结一下经验,二来独乐乐不如众乐乐 下载安装包 https://dev.mysql.com/downloads/my ......
注意:mysql主从复制,主从版本要一致!
生手永远在学习的路上,为了学习mysql主从复制,实现读写分离,于是在本地安装多个mysql实例来进行验证。
也因此有了下面的笔记,一来自我总结一下经验,二来独乐乐不如众乐乐
下载安装包 ,解压,在此,我下载的是5.7.24版本
先来配置一下主服务:
1.在此目录下新建一个my.ini的mysql配置文件,同时新建data,logs文件夹
2.配置my.ini
port = 3305
basedir=c:\programdata\mysql\mysql-5.7.24-master-3305 #(mysql文件夹路径)
datadir=c:\programdata\mysql\mysql-5.7.24-master-3305\data #(data路径,存放日志文件)
log-bin=master-bin 数据库备份文件名称,可*取,生成后会带文件序列号,服务每重启一次就会产生一个新文件
server-id = 1
binlog-do-db=test 表示需要备份的数据库为test
binlog-ignore-db=mysql 表示不需要备份的数据库为mysql
如果两个都不设的话,从服务器会复制主服务器的全部数据库 (本人就是此设置)
log-bin=mysql-bin 表示开启二进制日志,并把二进制日志前缀改为mysql-bin
3.dos-->cmd,进入bin目录
(1)进行初始化服务:mysqld --initialize --console,会在控制台打印初始化信息,此时data目录下也会生成一些初始化文件,并且控制台会打印出初始化的密码
(2)安装:mysqld --install mysqlmaster,mysqlmaster是服务名,自己看心情取,看到service successfully installed就表示服务安装成功
这时候,在任务管理器可以看到mysqlmaster这个服务,只不过还是未启动状态。
(3)启动服务:net start mysqlmaster(也可以在任务管理器的服务里面启动)
4.修改密码,需要加上端口号连接数据库,否则访问的是默认3306端口的数据库
mysql -uroot -p3305 -p
5.修改账号密码:
切换数据库,用户信息在mysql库的user表了里:use mysql
更新密码:update user set authentication_string=password("root") where user="root";--password()是mysql的一个加密函数
刷新账户信息:flush privileges;
然后运行mysql -uroot -proot就可以用root用户名和root密码登陆了
看看当前初始化的数据库:show databases;
启动主服务器后,可继续在dos界面或者用sqlyog连接工具在mysql中创建新用户授权,也可用直接root用户,在此我选择新建个人用户。
create user 'liuliuyan'@'%' identified by '123456';
给新用户配置主从复制的权限:
grant replication slave on *.* to 'liuliuyan'@'%' identified by '123456';
注:
@后面的ip地址为允许连接的客户端的ip地址,如果改为 ‘%’,就表示客户端没有ip地址的限制
然后查看主服务master的状态: (每重启一次mysql服务,mysql-bin的日志就会新建一个,所以重启主服务,从服务必须先停止再重新配置后启动)
7.查看主库的当前状态
show master status;
注:
请记住这个file和position,file是同步给从库的数据库文件,到时候授权给从库时要用
二、从库安装和配置
1.从主库拷贝一份解压文件并复制一份主库的my.ini文件过来修改配置
[mysqld]
port = 3308
basedir=c:\programdata\mysql\mysql-5.7.24-slave-3308
datadir=c:\programdata\mysql\mysql-5.7.24-slave-3308\data
log-bin=master-bin
server-id = 2
replicate-do-db=test #同步某库
#同步某表用 replicate-wild-do-table
replicate-wild-do-table =test.test
replicate-wild-do-table =test.test1
replicate-wild-do-table =test.test2
2.保存后像操作主库一样进行初始化,安装,启动等操作
3.启动从库后执行如下命令指定主库
change master to master_host='localhost',master_user='liuliuyan',master_password='123456',master_port=3305,master_log_file='master-bin.000003',master_log_pos=1245;
参数详解:
master_host: 主服务器的ip
master_user: 主服务器上新创建的用户名
master_password: 用户的密码
master_port: 主服务器的端口,如果未曾修改,默认即可。
master_log_file: 主服务器二进制日志文件的名称,填写查看主服务器的master状态时显示的file的值
4.启动从服务的slave复制功能:
start slave;
5.查从服务器的slave状态
show slave status \g;
如果 slave_io_running 和 slave_sql_running 的值都为 yes,则说明主从复制的所有配置已成功,即从服务器已经可以自动与主服务器的数据库数据实现同步了。
三、两个状态是ok就主从配置好了,接下来各位可以测试一下,我的测试成功了,在主库创建库,创建表后,从库都能同步到。perfect!
推荐阅读
-
mysql互为主从(双主)配置
-
CentOS7下mysql 8.0.16 安装配置方法图文教程
-
Windows环境下的MYSQL5.7配置文件定位图文分析
-
win10下mysql 8.0.16 winx64安装配置方法图文教程
-
mysql 8.0.16 压缩包安装配置方法图文教程
-
Windows10 mysql 8.0.12 非安装版配置启动方法
-
Windows10下mysql 8.0.16 安装配置方法图文教程
-
mysql 8.0.16 winx64.zip安装配置方法图文教程
-
windows下mysql 8.0.16 安装配置方法图文教程
-
mysql 5.7.11 zip安装配置方法图文教程