0

0

MySQL Master Slave 数据同步,集群

php中文网

php中文网

发布时间:2016-06-07 17:01:46

|

1137人浏览过

|

来源于php中文网

原创

最近学习了一下MySQL的集群,发现MySQL的集群有很多种方式,下面来介绍下学到的MySQL Master Slave配置MySQL Master Slave 字面上

最近学习了一下MySQL的集群,发现MySQL的集群有很多种方式,下面来介绍下学到的MySQL Master Slave配置

MySQL Master Slave 字面上理解,可以看出一个主和下属的关系,他们能做什么呢?我个人理解:当遇到高并发访问数据库的时候,可以让查询操作的SQL去访问Slave服务器,插入、修改、删除、可以在Master服务器来做,这样就可以减轻服务器的负担。

Slave 会根据Master 进行数据以二进制流的方式快速同步。

这两天在网上查了很多相关的配置,但都运行不了,,最后结合多种配置加上自己的理解终于成功了,太开心了!

下面我来说说我是怎么配置的吧! 争取让你按我的配置一次成功!我尽量详细。

我的机器是XP系统,安装的MySQL5.1.32-community-log,我的虚拟机里是Ubuntu10.10,MySQL5.1.49-1ubuntu8.1-log

Master :192.169.105.203 (XP系统)
Slave: 192.168.2.133(Linux系统)

1、XP系统中操作:
找到MySQL的安装目录,我的是:
D:\Program Files\MySQL\MySQL Server 5.1
修改D:\Program Files\MySQL\MySQL Server 5.1\my.ini文件,找到[mysqld] 在下面写:

server-id               = 1
log_bin                 = d:/mysql/mysql-test-bin.log
expire_logs_days        = 10
max_binlog_size         = 100M
binlog_format           =mixed
binlog_do_db = test_db

汉潮社区团购系统
汉潮社区团购系统

汉潮社区团购拼团系统以社区/农村/商业区基本单位,通过招募社区团长,通过微信群等社交工具进行开团销售,把相同一社区人群的日常所需商品交由平台+商家+团长+平台配送员集中管理运营的一种新型社区消费模式,为您提供一套完整的社区团购运营方案,帮助您快速构建运营管理体系,降低前期投入成本。系统从用户体验到供应链管理模块环环相扣,简单易懂,让您轻松玩转社区团购/拼团!安装步骤:一、配置数据库文件,修改数据库

下载

注意:d:/mysql/mysql-test-bin.log 这个目录需要自己建立,log_bin的意思是 将数据库的内容以二进制方式写到文件里(Slave会根据这个文件进行同步数据);
通常Master服务器都配置 server-id=1 这个数字最好和IP最后一组数字一致,但要小于32,这里配置为1。
binlog_do_db准许Slave同步的数据库,我这里要让写的是test_db用于测试的数据库(Slave里也要有相同的数据库和表结构,否则无法同步),如果有多个数据库可以多写几个binlog_do_db=**数据库名。
重启MySQL服务,net stop mysql 然后net start mysql

连接数据库 mysql -uroot -p123456

mysql> show master status;
+-----------------------+----------+--------------+------------------+
| File                  | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+-----------------------+----------+--------------+------------------+
| mysql-test-bin.000001 |      106 |              |                  |
+-----------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
         
这个就是生成的二进制文件的信息,Slave会根据这个同步数据。

设定 Replication Slave 权限
我们必须要在 Master Server 上做设定,让 Slave 具有可以从 Master Server 上 Copy 数据的权限(正式的说法为 Replication Slave Priviledges)
mysql> GRANT REPLICATION SLAVE ON *.* TO 'test_dbuser'@'192.168.2.133' IDENTIFIED BY '1234';
语句中的SLAVE是权限名,*.*是可访问任何数据库,test_dbuser是用户名,192.168.2.133是准许这个IP访问,1234是密码。
mysql> FLUSH PRIVILEGES; (使之生效)

--------------------------
2、下面是在Ubuntu下的操作,配置Slave:
MySQL的安装我就不多说了,apt-get install mysql ……
先说明一下我的MySQL的路径:
/etc/init.d/mysql 下是启动和停止服务
/var/log/mysql/ 记录日志,相当于我在前面XP系统里建立的d:/mysql/mysql-test-bin.log位置
/var/lib/mysql/ 存放数据库。MySQL配置文件:/etc/mysql/my.cnf ,其中指定了数据文件存放路径,
datadir = /var/lib/mysql
如果你创建了一个名为 test 的数据库,那么这个数据库的数据会存放到 /var/lib/mysql/test 目录下。

Slave Server配置:
修改MySQL配置文件:/etc/mysql/my.cnf
找到[mysqld] 在下面加入:
server-id               = 2
replicate-do-db  =test_db
log_bin                 =/var/log/mysql/mysql-bin.log
relay_log               =/var/log/mysql/mysql-relay-bin.log
master-connect-retry =1
expire_logs_days        = 10
max_binlog_size         = 100M
#binlog_do_db           = test
#binlog_ignore_db       = include_database_name
binlog_format           = mixed

下面说明一下:
server-id=2就是个编号,如果有多个Slave服务器,就依次向后排,3、5、6……
replicate-do-db=test_db是配置我要到Master服务器同步的数据库,我这里配置的是test_db数据库。
master-connect-retry=1 是1秒钟同步一次,这个数值可根据不同需要配置。

linux

相关专题

更多
excel制作动态图表教程
excel制作动态图表教程

本专题整合了excel制作动态图表相关教程,阅读专题下面的文章了解更多详细教程。

20

2025.12.29

freeok看剧入口合集
freeok看剧入口合集

本专题整合了freeok看剧入口网址,阅读下面的文章了解更多网址。

65

2025.12.29

俄罗斯搜索引擎Yandex最新官方入口网址
俄罗斯搜索引擎Yandex最新官方入口网址

Yandex官方入口网址是https://yandex.com;用户可通过网页端直连或移动端浏览器直接访问,无需登录即可使用搜索、图片、新闻、地图等全部基础功能,并支持多语种检索与静态资源精准筛选。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

197

2025.12.29

python中def的用法大全
python中def的用法大全

def关键字用于在Python中定义函数。其基本语法包括函数名、参数列表、文档字符串和返回值。使用def可以定义无参数、单参数、多参数、默认参数和可变参数的函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

16

2025.12.29

python改成中文版教程大全
python改成中文版教程大全

Python界面可通过以下方法改为中文版:修改系统语言环境:更改系统语言为“中文(简体)”。使用 IDE 修改:在 PyCharm 等 IDE 中更改语言设置为“中文”。使用 IDLE 修改:在 IDLE 中修改语言为“Chinese”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

16

2025.12.29

C++的Top K问题怎么解决
C++的Top K问题怎么解决

TopK问题可通过优先队列、partial_sort和nth_element解决:优先队列维护大小为K的堆,适合流式数据;partial_sort对前K个元素排序,适用于需有序结果且K较小的场景;nth_element基于快速选择,平均时间复杂度O(n),效率最高但不保证前K内部有序。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

12

2025.12.29

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

134

2025.12.29

抖音网页版入口在哪(最新版)
抖音网页版入口在哪(最新版)

抖音网页版可通过官网https://www.douyin.com进入,打开浏览器输入网址后,可选择扫码或账号登录,登录后同步移动端数据,未登录仅可浏览部分推荐内容。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

63

2025.12.29

快手直播回放在哪看教程
快手直播回放在哪看教程

快手直播回放需主播开启功能才可观看,主要通过三种路径查看:一是从“我”主页进入“关注”标签再进主播主页的“直播”分类;二是通过“历史记录”中的“直播”标签页找回;三是进入“个人信息查阅与下载”里的“直播回放”选项。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

18

2025.12.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 0.6万人学习

Node.js 教程
Node.js 教程

共57课时 | 7.6万人学习

CSS3 教程
CSS3 教程

共18课时 | 4.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号