mysql 5.5 主从参数_MySQL-5.5.33主从复制

搭建主从同步需要在两个电脑上分别安装 MySQL ,我这里安装的是 CentOS6.7 64位,MySQL-5.5.33。

两台的操作是一样的,要求能够登陆 mysql 数据库即可。

主从地址如下:

master:192.168.133.128

slave:192.168.133.132

ifconfig eth0 | grep "inet addr" | awk '{print $2}' | cut -d: -f2

1ba8507236a7e5c2373921eb7c6c6b93.png

5eaf21a3fcf0b9b8a3de44996e0a346f.png

环境介绍:

cat  /etc/redhat-release

uname -a

7dce486f61a95ba1f4c4d29749defdb0.png

配置主库的 my.cnf 文件,为了方便操作过滤掉开头是 #,$  的行

cat /etc/my.cnf | grep -v ^# | grep -v ^$ > tmp.log

cat tmp.log > /etc/my.cnf

160488263bbe9c2c77868f5dc4146eda.png

编辑 /etc/my.cnf 文件

server-id       = 1

log-bin=mysql-bin

#max_binlog_size=500M

#binlog-do-db=test

#binlog-ignore-db=test1

skip-name-resolve

lower_case_table_names=1

b12a6d01fe5f8720c182b1e4fa2e9823.png

以上参数介绍:

server-id       = 1  #表示服务器ID,可以自定义,在主从中是唯一的且必须为数字

log-bin=mysql-bin      #表示启用mysql二进制日志,必须要启动,否则主从不会生效

#max_binlog_size=500M   #表示每个binlog文件最大500M,但一条记录不会写在两个日志中,所以日志有时会超500M

#binlog-do-db=test    #表示要同步的数据库名字,如果是多个数据库,在多加一行就可以

#binlog-ignore-db=test1   #表示不需要同步的数据库名字,如果是多个数据库,在多加一行就可以

skip-name-resolve      #忽略主机名的方式访问

lower_case_table_names=1     #忽略数据库表名大小写

如果将 binlog-do-db=test ,binlog-ignore-db=test1   不写或是注释则表示为同步所有数据库,我这里就是同步所有数据库

修改过 my.cnf 文件后需要重启 mysql 服务

/etc/init.d/mysqld restart

b792c89748901ddc019e1adb8fb3c102.png

登陆主库,并创建一个账号并授权,专门用于主从同步

创建账号之后别忘记刷新权限

grant replication slave on *.* to yuci@'%' identified by '123456';

flush privileges;

66f5e5ff67def17c5774fbe240e942a9.png

检查自己刚才的操作

select user,host from mysql.user;

show grants for yuci@'%';

6012b819f226244aa83756dc1d5e54ba.png

进行锁表,锁表后将只能读取不能创建或插入任何信息

flush table with read lock;

b354bc0210f1ff161938af55eac6a4cc.png

查看 binlog 的文件名以及 pos 位置节点

show master status;

30439274577099969359e94e4274c4c0.png

在从库上用刚才创建的用户登陆主库,测试两台数据库是否连接通常

mysql -uyuci -p123456 -h192.168.133.128

b4a8625f3f65150c5404557968252936.png

新开一个远程界面,连接主库并将导出数据库。(保证之前的 mysql 登陆界面不要退出)

在将新导出的 test.sql 文件通过 scp 传给从库

mysqldump -uroot -p123456 --events -A -B > /root/test.sql

scp test.sql root@192.168.133.132:/root

yes

bd321e63e05356e9aa0612e434faf118.png

回到主库,解锁

unlock tables;

dd7ed24ea52359bbb18aa0047be426a6.png

在从库上将刚才的 test.sql 文件导入到数据库

mysql -uroot -p123456 < /root/test.sql

6d39a7fd6d20933192d720ea45a67f9a.png

编辑从库上 my.cnf 文件,将 server-id 修改为 2

vim /etc/my.cnf

server-id       = 2

76fb1584d560fe7378968df351a4c79e.png

修改了 my.cnf 文件,需要重启 mysql

/etc/init.d/mysqld restart

1cc04e673ad15270deca58d44e227b42.png

登陆 mysql 配置从库的同步参数

CHANGE MASTER TO

MASTER_HOST='192.168.133.128',

MASTER_PORT=3306,

MASTER_USER='yuci',

MASTER_PASSWORD='123456',

MASTER_LOG_FILE='mysql-bin.000001',

MASTER_LOG_POS=107;

b50019e6222097bb5820c38ea7ed7404.png

以上参数配置

CHANGE MASTER TO

MASTER_HOST='192.168.133.128',            #表示主库的IP

MASTER_PORT=3306,          #表示主库的端口

MASTER_USER='yuci',        #表示主库上允许同步的用户

MASTER_PASSWORD='123456',     #表示同步用户的密码

MASTER_LOG_FILE='mysql-bin.000001',         #表示从哪个binlog文件开始同步

MASTER_LOG_POS=107;       #表示从binglong文件的哪个pos节点位置开始同步

在从库上执行 start slave 操作,IO连接

start slave;

81479de6c204a1cd9960d12fa414c2af.png

查看当前的状态,关键有以下几个内容

show slave status\G;

95b8f2f40d47430846d314e07bcea13d.png

关键查看以下参数

Slave_IO_State: Waiting for master to send event

Slave_IO_Running: Yes           #主从之间的网络

Slave_SQL_Running: Yes        #主从之间的数据

Seconds_Behind_Master: 0     #从库落后主库的秒数

在主库中创建一个数据库,测试主从是否同步

create database haha;

5d431ec59b39d256449eac9237b2644c.png

在主库中查看

show databases;

c69ea8172b653f6819ac97f4cd5ae844.png

在从库中查看,主从同步成功

show databases;

c7e9dd17924023b7e04b195a9572f221.png

zhao

本文转自   mlwzby   51CTO博客,原文链接:http://blog.51cto.com/aby028/1892939

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值