RELATEED CONSULTING
相关咨询
选择下列产品马上在线沟通
服务时间:8:30-17:00
你可能遇到了下面的问题
关闭右侧工具栏

新闻中心

这里有您想知道的互联网营销解决方案
mysql主从怎么做的 mysql数据库做主从的工作过程

MySQL主从原理

系统优化:假如现在用户反映系统太卡

公司主营业务:成都网站设计、做网站、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联建站是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联建站推出莎车免费做网站回馈大家。

1:如果是请求太多,判断web服务器压力过大,增加前端的web服务器,做负载均衡

2:如果请求静态页面不卡了,但是请求动态数据还是卡,说明MySQL处理的请求太多了,在应用层增加缓存

3:如果请求激增,还是有大量的查询到MySQL,想办法处理MySQL ,在一个应用中,大量的消耗MySQL的还是查询,就可以把MySQL拆开,就像公路分道 公交车道,小轿车道,把MySQL做成主从

1,就算MYSQL拆成了多个,也必须分出主和从,所有的写操作都必须要在主MYSQL 上完成;

2,所有的从MYSQL的数据都来自于(同步于)主MYSQL;

3,既然涉及到同步,那一定有延迟;有延迟,就一定可能在读的时候产生脏数据;所以,能够在从MYSQL上进行的读操作,一定对实时性和脏数据有一定容忍度的数据;比如,登陆日志,后台报表,首页统计信息来源;文章;资讯;SNS消息;

4,[注意]:在MYSQL主从时,如果一个业务(service中的一个方法)中,如果既有R操作,又有W操作,因为W操作一定要在主MYSQL上,所以在一个事务中所有的数据来源都只能来自于一个MYSQL

1,要完成主从同步,就必须让在Master上执行的所有的DML和DDL能够正确的在Salve上再执行一遍;MYSQL选择使用文件来记录SQL;

2,要完成主从同步,第一个事情就是把在主服务器上的bin-log(二进制文件)打开,bin-log文件就可以记录在MYSQL上执行的所有的DML+DDL+TCL;

3,MYSQL使用被动注册的方式来让从MYSQL请求同步主MYSQL的binlog;原因:被动请求的方式,主的MYSQL不需要知道有哪些从的MYSQL,我额外添加/去掉从MYSQL服务器,对主MYSQL服务器的正常运行没有任何影响;

4,第二步,从MYSQL后台一个线程发送一个请求,到主服务器请求更新数据;最重要的数据(我这次请求,请求你bin-log的哪一行数据之后的数据)

5,第三步,主MYSQL后台一个线程接收到从MYSQL发送的请求,然后读取bin-log文件中指定的内容,并放在从MYSQL的请求响应中;

6,第四步,从MYSQL的请求带回同步的数据,然后写在从MYSQL中的relay-log(重做日志)中;relay-log中记录的就是从主MYSQL中请求回来的哪些SQL数据;

7,第五步,从MYSQL后台一个线程专门用于从relay-log中读取同步回来的SQL,并写入到从MYSQL中,完成同步;

8,MYSQL的主从同步是经过高度优化的,性能非常高;

mysql主从原理如何配置

1.在主数据库服务器为从服务器添加一个拥有权限访问主库的用户:

GRANT REPLICATION SLAVE ON *.* TO ' test'@'%' IDENTIFIED BY 'test';

(%表示允许所有IP,可设置指定从服务器IP)

添加用户后:

可在从服务器上用mysql -h127.0.0.1 -utest -ptest; 来测试是否有权限访问主数据库

2.在主据库配置文件加上:

#master config

server-id = 1

log-bin = mysql-bin

3.在从服务器数据库配置文件:

server-id = 2

master-host = 10.0.0.199

master-user = test

master-password = test

replicate-do-db = test

master-port = 3306

log-bin = mysql-bin

如果你的一切配置顺利

你在从服务器上输入命令:show slave status\G

成功情况:

Slave_IO_Running:yes

Slave_SQL_Running:yes

在主服务器上输入show master status

如何使用mysql 主从服务器

一. 准备服务器

准备两台主机,分别安装好Mysql (要相同版本),确定版本无误,确保mysql服务正常启动,确保两台主机处于同一个局域网中,确定好哪台做为主、备机器,假设A为主机,B为备机,假设:

A主机IP地址为:172.16.16.90 端口3306

B主机IP地址为: 172.16.99.98 端口3306

二. Mysql建立主-从服务器热备配置步骤

1. 创建同步用户

进入MySql操作界面,在主服务器上为从服务器建立一个连接帐户,该帐户必须授予REPLICATION SLAVE权限。

操作指令如下:

1) grant select,replication slave on *.* to 'replicate'@'172.16.99.98' identified by '1234567';

2) flush privileges;

2. 修改Mysql配置

如果上面的准备工作做好,就可以进行对Mysql配置文件进行修改了,首先找到主服务器Mysql安装文件所有在目录,找到my.ini文件用记事本打开。在[mysqld]下增加如下内容:

server-id = 1

log-bin=mysql-bin

binlog-do-db =test   #需要备份的数据库,多个写多行

binlog-ignore-db = mysql      #不需要备份的数据库,多个写多行

3. 重启mysql服务

修改完配置文件保存后,重启一下mysql服务。

4. 查看主服务器状态

进入A服务器Mysql 客户端输入命令

1)Show master STATUS;

2)返回结果如下:

注意看里面的参数,特别前面两个File和Position,在从服务器(Slave)配置主从关系会有用到的。

5. 从服务器Slave配置修改配置文件

因为这里面是以主-从方式实现mysql双机热备的,所以在从服务器就不用在建立同步帐户了,直接打开配置文件my.ini进行修改即可,道理还是同修改主服务器上的一样,只不过需要修改的参数不一样。

如下:

[mysqld]

server-id = 2

log-bin=mysql-bin

replicate-do-db = test

replicate-ignore-db =mysql

6. 重启mysql服务

修改完配置文件保存后,重启一下mysql服务。

7. 配置从服务器

先停止slave服务线程,这个是很重要的,如果不这样做会造成下面操作不成功,再用change mster 语句指定同步位置,操作如下:

1) stop slave;

2) change master to master_host='172.16.16.90',

master_user='replicate',master_password='1234567',master_port=3306,

master_log_file='mysql-bin.000001',master_log_pos=98;

3) start slave

4) show slave status

查看下面两项值均为Yes,即表示设置从服务器成功。

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

如何设计mysql 的主从关系

MySQL主从关系设置

一,概要

1.这个文档主要实现的是MYSQL主从备份(主机数据库任何修改,备份机器都会有实现)

2.但是有个问题,就是如果对备份机器数据库进行操作,可能会导致连接失败。

二,准备工作

1.可以是多台主机和从机,在这里我只用一台主机和从机为例讲解主从关系配置。2.主机IP:192.168.0.100(例子)从机IP:192.168.0.101(例子)3.主机和从机的IP地址必须是一个网段的。

4.MySQL版本:mysql-5.5.15-win32.msi安装路径:D:\MySQL\(例子)5.其他相关软件:

①.MySQL管理客户端:Navicat8forMySQL(Windows)。

②.编辑工具:Notepad++(建议用此编辑工具修改MySQL配置文件,点击此链接进入下载

页面)

三,配置主机【master】(IP:192.168.0.100)

1.在命令行窗口中执行:netstopmysql关闭mysql服务。

2.在mysql安装路径下找到配置文件my.ini文件(Linux下是文件my.cnf),一般都在MySQL安装目录下,本实验中在D:\MySQL\下。记得先备份以下原来的配置文件。并用Notepad++打开。然后在文件末尾加入下面的代码:

server-id=1#配一个唯一的ID编号

log-bin=NEW_NAME#指定日志类型

binlog-do-db=bojinv2#设置要进行主从复制的数据库名,同时也要在从机

【Slave】上设定(同步多个另起一行输入这行代码)

Binlog-ignore-db=mysql#设置不要进行主从复制的数据库名,同时也要在

【Slave】上设定(不同步多个另起一行输入这行代码

即可。)

3.在系统管理命令窗口输入:netstartmysql按回车启动mysql服务

4.在MySQL5.5CommandLineClient命令窗口(路径:开始菜单》程序》MySQL下),

输入数据库密码:******回车,如下图所示:

然后输入:grantreplicationslaveon*.*toslaveuser@从机IP(例:192.168.1.101)identifiedby'从机数据库密码(例:123456)'回车后如下图所示:

var cpro_psid ="u2572954"; var cpro_pswidth =966; var cpro_psheight =120;

出现这样的提示后,继续输入:flushprivileges;按回车,如下图所示:

出现这样的提示后,继续输入:showmasterstatus;按回车,如下图所示:

记住出现的表格中的File列和Position的值。

5.在系统管理命令窗口输入:netstopmysql按回车关闭mysql服务

6.进入MySQL管理客户端:Navicat8forMySQL(Windows)。点击菜单栏用户,右侧显示你

刚才创建slaveuser@192.168.1.101的用户,选中该用户。点击编辑用户链接。弹出窗口,再

选择权限,将所有权限都选上保存,这样主机就配置好了。重启一下MySQL服务。

四,配置从机【slave】(Ip:192.168.1.101)

1.在命令行窗口中执行:netstopmysql关闭mysql服务。

2.在mysql安装路径下找到配置文件my.ini文件(Linux下是文件my.cnf),一般都

在MySQL安装目录下,本实验中在D:\MySQL\下。记得先备份以下

原来的配置文件。并用Notepad++打开。然后在文件末尾加入下面的代

码:

server-id=2#配一个唯一的ID编号,不能与主机和其他的从机相同

replicate-do-db=bojinv2#设置要进行主从复制的数据库名,数据库名与主机

相同

replicate-ignore-db=mysql#设置不要进行主从复制的数据库名,数据库名与

主机相同

别忘了保存修改后的文件。

3.在系统管理命令窗口输入:netstartmysql按回车启动mysql服务

4.在MySQL5.5CommandLineClient命令窗口(路径:开始菜单》程序》MySQL下),

输入数据库密码,按回车成功登录数据库。5.登录成功后,在该命令窗口输入:

Changemastertomaster_host='主机IP(192.168.1.100)',master_user='


名称栏目:mysql主从怎么做的 mysql数据库做主从的工作过程
本文URL:http://scyingshan.cn/article/dogjdps.html