热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

MySQLMasterSlave数据同步,集群-mysql教程

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

最近学习了一下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

推荐阅读
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文详细介绍了如何在 Linux 平台上安装和配置 PostgreSQL 数据库。通过访问官方资源并遵循特定的操作步骤,用户可以在不同发行版(如 Ubuntu 和 Red Hat)上顺利完成 PostgreSQL 的安装。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 解决微信电脑版无法刷朋友圈问题:使用安卓远程投屏方案
    在工作期间想要浏览微信和朋友圈却不太方便?虽然微信电脑版目前不支持直接刷朋友圈,但通过远程投屏技术,可以轻松实现在电脑上操作安卓设备的功能。 ... [详细]
  • 本文详细介绍了VMware的多种认证选项,帮助你根据职业需求和个人技能选择最合适的认证路径,涵盖从基础到高级的不同层次认证。 ... [详细]
  • 本文由瀚高PG实验室撰写,详细介绍了如何在PostgreSQL中创建、管理和删除模式。文章涵盖了创建模式的基本命令、public模式的特性、权限设置以及通过角色对象简化操作的方法。 ... [详细]
  • 本文详细介绍了如何在Ubuntu系统中下载适用于Intel处理器的64位版本,涵盖了不同Linux发行版对64位架构的不同命名方式,并提供了具体的下载链接和步骤。 ... [详细]
  • 本文介绍如何通过更改软件源来提前体验Ubuntu 8.10,包括详细的配置步骤和相关注意事项。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 本文介绍如何通过SSH协议使用Xshell远程连接到Ubuntu系统。为了实现这一目标,需要确保Ubuntu系统已安装并配置好SSH服务器,并保证网络连通性。 ... [详细]
author-avatar
手机用户2702934045
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有