本文前置条件:

有两台虚拟机,均安装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.新建用于复制的账号


#登录mysql
mysql -u root -p
#创建用户
create user slave1 identified by 'slave1'
#授予权限
grant all privileges on *.*  to slave1@'%' identified by 'slave1'
#刷新
FLUSH PRIVILEGES;

5.查看主mysql的信息

show master status\G

配置从服务的时候会用到File和Position
image.png

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

image.png
IO进程和SQL进程都显示为YES就是启动成功了

我遇到的问题

mysql的错误日志在 /var/log/mysqld.log
遇到错误可以去看一下这个文件内容

1.mysql开启远程连接失败
参见这里
2.从节点开启失败,错误日志中提示Error_code: 2003
参见这里


等风来
39 声望5 粉丝