文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

​MySQL数据库5.6.16.主从复制如何搭建及配置

2024-04-02 19:55

关注

下面一起来了解下MySQL数据库5.6.16.主从复制如何搭建及配置,相信大家看完肯定会受益匪浅,文字在精不在多,希望MySQL数据库5.6.16.主从复制如何搭建及配置这篇短内容是你想要的。

MySQL数据库5.6.16.主从复制

1.环境:

基于虚拟机,所以直接克隆一台同样的虚拟机操作

从库:

[root@slave ~]# ifconfig eth0|awk -F '[ :]+''NR==2{print $4}';ifconfig eth2|awk -F '[ :]+' 'NR==2{print $4}'

192.168.56.42

172.16.1.42

/etc/init.d/iptables stop

或者:

Vim /etc/sysconfig/iptable

-A INPUT -m state --state NEW -m tcp -p tcp --dport3306 -j ACCEPT

主库:要记录bin_log,

[root@master ~]# cat -n /etc/my.cnf|sed -n '41p'

    41     log_bin = /home/mysql/data/binlog/mysql-bin

保证server_id数值和主库的不一样。

[root@slave ~]# cat -n /etc/my.cnf|sed -n '11p'

    11     server_id = 101

注意:云服务器的主机名不要随意变动,否则导致MySQL服务重新启动会报错,必须杀当前的MySQL掉进程,然后再restart启动MySQL服务

mysql 5.6的复制引入了uuid的概念,各个复制结构中的server_uuid得保证不一样,但是查看到直接copy  data文件夹后server_uuid是相同的,show variables like ‘%server_uuid%’;

同时要保证主从数据库的auto.cnf中数值不一样,同时必须保证两台主从的机器的防火墙都必须是关闭的。

修改两台云服务器上的文件/data/mysql/data/auto.cnf然后重启数据库服务就ok了

负责会报错:1593

Last_IO_Error: Fatal error: The slave I/O threadstops because master and slave have equal MySQL server UUIDs; these UUIDs mustbe different for replication to work.

以及报错:2003原因是防火墙没有关闭。Change  master 时密码输入错误导致。

 Last_IO_Error: error connecting to master 'rep@172.16.1.41:3306' -retry-time: 60  retries: 1

提示:必须保证两台的云服务器的时间是一致的,要适时更新时间并且写入定时任务

Crontab -l

###time sync###by wujianwei at 2016-5-19

*/5 * * * * /usr/sbin/ntpdatentp1.aliyun.com &>/dev/null

搭建一主多从数据库时报错:

在从库操操作:

mysql> start slave;

ERROR 1201 (HY000): Could not initialize masterinfo structure; more error messages can be found in the MySQL error log

mysql> show slave status\G

  Last_Errno:1872

                  Last_Error: Slave failed to initialize relay log info structure from therepository

在一台主机上增加一个slave,启动的时候报

[ERROR] Slave SQL: Slave failed toinitialize relay log info structure from the repository, Error_code: 1872

原因:检查my.cnf,原来没指定relay_log,mysql默认产生的relay_log名被该server上的另一个mysql slave占用了。

原因是:从库的my.cnf配置文件中没有加入参数

relay_log=/data/mysql/data/relay-log/mysql-relay-bin

1.stop slave;

2. reset slave;

mysql>reset slave

3.mysql>change master to

4.start slave

2.主从环境搭建配置步奏:

1.master主库操作:

/etc/init.d/iptables stop

或者:

vim /etc/sysconfig/iptable

-A INPUT -m state --state NEW -m tcp -p tcp --dport3306 -j ACCEPT

echo "log_bin =/home/mysql/data/binlog/mysql-bin" /etc/my.cnf

sed -i 's#server_id = 100#server_id = 1#g'/etc/my.cnf

mkdir /home/mysql/data/binlog/ -p

chown mysql.mysql /home/mysql/data/binlog

mysql -uroot -p123456 -e "grant replicationslave on *.* to rep@'172.16.1.%' identified by '111111'; flush privileges "

mysqldump -uroot -p123456 -B -A -F -R -x--master-data=1  --events|gzip>/backup/rep_$(date +%F).sql.gz

mysqldump -uroot -p123456 -B -A -F -R -x--master-data=1  --events|gzip>/backup/rep_$(date +%F).sql.gz

  mysql-uroot -p123456 -e "show master status;"

scp -rp -P22 /backup/rep_2016-08-18.sql.gz root@172.16.1.42:/backup/

2从库操作:mysql-5.6s1

vim /etc/sysconfig/iptables

-A INPUT -m state --state NEW -m tcp -p tcp--dport 3306 -j ACCEPT

sed -i 's#server_id = 100#server_id = 2#g' /etc/my.cnf

gzip -d /backup/rep_2016-08-18.sql.gz

mysql -uroot -p123456 </backup/rep_2016-08-18.sql

mysql -uroot -p123456 -e "CHANGE MASTERTO MASTER_HOST='172.16.1.41',MASTER_PORT=3306,MASTER_USER='rep',MASTER_PASSWORD='111111';startslave;show slave status\G" |grep -i "yes"

3.一组多从数据库配置mysql-5.6s2

vim /etc/sysconfig/iptables

-A INPUT -m state --state NEW -m tcp -p tcp--dport 3306 -j ACCEPT

sed -i 's#server_id = 100#server_id = 3#g'/etc/my.cnf

vim /data/mysql/data/auto.cnf

/etc/init.d/mysqld restart

gzip -d rep_2016-08-18.sql.gz

mysql -uroot -p123456 </backup/rep_2016-08-18.sql

mysql -uroot -p123456 -e "showdatabases;"

mysql -uroot -p123456 -e "CHANGE MASTERTO MASTER_HOST='172.16.1.41',MASTER_PORT=3306,MASTER_USER='rep',MASTER_PASSWORD='111111';startslave;show slave status\G" |grep -i "yes"

1.演示:

Master:

mysql -uroot -p123456 -e "create databasewjw05"

mysql> use wjw01;

mysql> CREATE table `t1` (`id` bigint(12) NOTNULL auto_increment,`name` varchar(12) NOT NULL,PRIMARY KEY (`id`) );

mysql> INSERT INTO t1(name) values('oldboy');

slave:

mysql -uroot -p123456 -e "showdatabases"|grep wjw05

mysql -uroot -p123456 -e "showdatabases"|grep wjw05

mysql -uroot -p123456 -e "desc wjw01.t1"

mysql -uroot -p123456 -e "select * fromwjw01.t1"

看完MySQL数据库5.6.16.主从复制如何搭建及配置这篇文章后,很多读者朋友肯定会想要了解更多的相关内容,如需获取更多的行业信息,可以关注我们的数据库栏目。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯