本文前置条件:
有两台虚拟机,均装置mysql,并且能够近程拜访主机1的IP:192.168.56.1/24,设置了端口转发13306主机2的IP:192.168.188.1/24
本文指标:
配置mysql主从,主机1上的mysql为主库,主机2上的mysql为从库
mysql主服务器配置192.168.56.1
1.批改配置文件
vi /etc/my.cnf
在[mysqld]节下减少以下内容,而后保留退出
#服务id,集群内的mysql须要保障惟一server-id = 1# 开启mysql binlog性能log-bin = mysql-bin# binlog记录内容的形式,记录被操作的每一行binlog_format = ROW# 缩小记录日志的内容,只记录受影响的列binlog_row_image = minimal
2.批改mysql的uuid(主节点和从节点不统一就行)
vi /var/lib/mysql/auto.cnf
轻易批改一个数字,保留退出
3.重启mysql服务
service mysql restart
4.新建用于复制的账号
#登录mysqlmysql -u root -p#创立用户create user slave1 identified by 'slave1'#授予权限grant all privileges on *.* to [email protected]'%' identifield by 'slave1'#刷新FLUSH PRIVILEGES;
5.查看主mysql的信息
show master status\G
配置从服务的时候会用到File和Position
mysql从服务器配置
1.批改配置文件
感觉如同只有server-id是必须的,网上各个博客配置都不一样,然而都会有server-id
# 服务的惟一编号server-id = 2# 开启mysql binlog性能log-bin = mysql-bin# binlog记录内容的形式,记录被操作的每一行binlog_format = ROW# 缩小记录日志的内容,只记录受影响的列binlog_row_image = minimal
2.重启mysql服务
service mysql restart
3.登录
mysql -u root -p
4.设置master节点信息
对应的账号密码IP端口等信息要正确,
master_log_file是后面提到的File
master_log_pos是后面提到的position
change master to master_host='192.168.56.1',master_port=13306,master_user='slave1',master_password='slave1',master_log_file='mysql-bin.000001',master_log_pos=287;
5.启动从节点
start slave;
6.查看从节点状态
show slave status\G
IO过程和SQL过程都显示为YES就是启动胜利了
我遇到的问题
mysql的谬误日志在 /var/log/mysqld.log
遇到谬误能够去看一下这个文件内容
1.mysql开启近程连贯失败
参见这里
2.从节点开启失败,谬误日志中提醒Error_code: 2003
参见这里