文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL中如何实现主从复制与读写分离

2024-04-02 19:55

关注

MySQL中如何实现主从复制与读写分离,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

1,mysql的配置

CentOS 5.x,6.0编译安装Nginx1.2.3+MySQL5.5.15+PHP5.3.6

我是再这个环境下做测试的,我是配置了1台。利用VMware Workstation拷贝出来多台服务器的,所以环境绝对一样。

2,场景描述

主数据库服务器:192.168.10.130
从数据库服务器:192.168.10.131

3,配置主服务器

修改从服务器的配置文件,my.cnf 不一定路径和我一样哦,注意修改

vi etc/my.cnf

确定 server-id = 1,并确保这个ID没有被别的MySQL服务所使用。

启动mysql服务(192.168.10.130)

/etc/init.d/mysqld  start

通过命令行登录管理MySQL服务器

mysql -uroot -p

授权给从数据库服务器192.168.10.131

mysql> GRANT REPLICATION SLAVE ON *.* to 'rep1'@'192.168.10.131' identified by '123';

查询主数据库状态

Mysql> show master status;

+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000005 | 261 | | |
+------------------+----------+--------------+------------------+

记录下 FILE (mysql-bin.000005) 及 Position(261) 的值,在后面进行从服务器操作的时候需要用到。

4,配置从服务器

修改从服务器的配置文件,my.cnf 不一定路径和我一样哦,注意修改

vi etc/my.cnf

将 server-id = 1修改为 server-id = 2,并确保这个ID没有被别的MySQL服务所使用。

启动mysql服务

/opt/mysql/init.d/mysql start

通过命令行登录管理MySQL服务器

mysql -uroot -p

执行同步SQL语句

mysql> change master to
master_host=’192.168.10.130’,
master_user=’rep1’,
master_password=’123’,
master_log_file=’mysql-bin.000005’,
master_log_pos=261;

注意上面的数据要和主服务器一样,否则同步会失败!
 

正确执行后启动Slave同步进程

mysql> start slave;

主从同步检查

mysql> show slave status\G

其中Slave_IO_Running 与 Slave_SQL_Running 的值都必须为YES,才表明状态正常。

如果不是,请检查上面是否那一步骤有问题!可以留言给我。。。如果都YES 可以进入下一步操作

5,第一次同步主从服务器数据

锁定主服务器mysql:

mysql> FLUSH TABLES WITH READ LOCK;

锁定从服务器mysql:

mysql> FLUSH TABLES WITH READ LOCK;

将主服务器的数据文件(整个/opt/mysql/data目录)复制到从服务器,建议通过tar归档压缩后再传到从服务器解压覆盖。

开启主服务器mysql:

mysql> UNLOCK TABLES;

开启从服务器mysql:

mysql> UNLOCK TABLES;

6,测试是否同步

在主服务器上操作:

 mysql> create database first_db;
 mysql> use first_db;
 mysql> create table first_tb(id int(3),name char(10));
 mysql> INSERT INTO `first_tb` VALUES ('1', '1');

在从服务器上查看....

mysql> show databases;

=============================
+--------------------+
| Database |
+--------------------+
| information_schema |
| first_db |
| mysql |
| performance_schema |
| test |
+--------------------+
5 rows in set (0.01 sec)
=============================

看完上述内容,你们掌握MySQL中如何实现主从复制与读写分离的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

阅读原文内容投诉

免责声明:

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

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

软考中级精品资料免费领

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

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

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

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

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

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

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