Mysql数据库优化一:集群(读写分离)之主从服务器的安装与配置

  Mysql数据库的集群(读写分离),说白了就是将读操作和写操作分开在不同的服务器上实现,以达到提高效率的目的。

      大致原理如下:

        数据库中的所有操作都是有日志记录的(前提是要打开这个日志记录功能)

        1.master,主服务器(进行写操作的服务器)的所有记录都保存到二进制日志(binary log)中,这些记录叫做二进制日志事件(binary log events);

        2.slave,从服务器(进行读操作的服务器)将mater的binart log拷贝到自己的中继日志(relay log),然后根据中继日志对自己的数据进行修改;

        3.将读的请求发给slave,写的请求发给master,这样就实现了读写分离。技术选型 myproxy

      实现过程:

      一,设置主服务器,并开启日志;

         1),找到自己的mysql的配置文件,我的系统是win764位,mysql安装在C盘下面,具体位置请看下图 ,

          

    2),修改my.ini的配置。这里的服务器是主服务器,必须打开mysql的日志操作记录,注意:修改配置需要权限,如果没有权限请鼠标右键属性后为自己的账户配置权限。

    修改port端口号:默认为3306,我在这里修改为3388,作为主服务器之用。

    添加图中红色方框的圈起来的部分,#后面是注释部分,可以不写。

      log="这里是日志存放的路径地址和文件名" ,如图中所示,我的日志存在mysql的ini的同级目录,名字叫mysql.log,mysql.log是操作日志,可以通过文本软件打开后查看进行了什么操作;

      log-bin=mysql-bin  的意思是开启二进制日志,从服务器通过拷贝这个日志到自己的日志中,然后再进行数据的更新,才能实现主从服务器数据的一致;

      server-id=1   就是为该服务器配置一个服务器id,要确保其他服务器没有占用该id,我在这里设置的为1,从服务器设置为10;

    3),配置修改完成后保存,重启服务就可以了,然后为从服务器创建一个账户,以便从服务器来链接主服务器读取数据。

      

    注意:开启和关闭服务都要使用管理员权限打开cmd后进行操作,不然是是会失败的;还有,mysql服务的名字也许不一样,可以通过在查看服务来确认。

      

    

    服务重启完成后,创建从服务器的账户:

        

  

        参数说明:

*.*  :表示对所有表的所有操作

sirius:slave连接master使用的账号

IDENTIFIED BY ‘admin‘ :slave连接master使用的密码

192.168.77.128:slave IP

        执行成功后,可以到创建的账户是存在的

    4),查询主服务器的状态,记录 File  和 Position的值,在从服务器端使用;

    

  图没有截好,这里的File是mysql-bin.0000003,这个数字如果是第一次开启二进制日志那么就是1,如果不是就是其他数字;

主服务器端的配置暂时记录到这,从服务器的配置之后更新····················

时间: 2024-10-09 00:30:48

Mysql数据库优化一:集群(读写分离)之主从服务器的安装与配置的相关文章

浅谈高性能数据库集群——读写分离

本文主要介绍高性能数据库集群读写分离相关理论,基本架构,涉及的复杂度问题以及常见解决方案. 1 读写分离概述 基本架构图: 2 适用场景 读写分离不是银弹,并不是一有性能问题就上读写分离,而是应该先优化,例如优化慢查询,调整不合理的业务逻辑,引入缓存查询等只有确定系统没有优化空间后才考虑读写分离集群 3 引入的系统复杂度问题 问题一 主从复制延迟 问题二 分配机制 如何将读写操作区分开来,然后访问不同的数据库服务器? 解决方案1 客户端程序代码封装实现 基本架构图 业界开源实现 Sharding

Mysql高级集群-读写分离Amoeba

一.环境介绍Master-IP:10.0.0.201Slave- IP:10.0.0.202Amobea-IP:10.0.0.203 二.安装JDK# mkdir /Amoeba# tar -xvf jdk-7u40-linux-x64.tar.gz -C /Amoeba/# vim /etc/profileJAVA_HOME=/Amoeba/jdk1.7.0_40export JAVA_HOME PATH=$JAVA_HOME/bin:$PATHexport PATH CLASSPATH=.:

MySQL集群读写分离的自定义实现

基于MySQL Router可以实现高可用,读写分离,负载均衡之类的,MySQL Router可以说是非常轻量级的一个中间件了.看了一下MySQL Router的原理,其实并不复杂,原理也并不难理解,其实就是一个类似于VIP的代理功能,其中一个MySQL Router有两个端口号,分别是对读和写的转发.至于选择哪个端口号,需要在申请连接的时候自定义选择,换句话说就是在生成连接字符串的时候,要指明是读操作还是写操作,然后由MySQL Router转发到具体的服务器上. 引用这里的话说就是:一般来说

十四、linux-MySQL的数据库集群读写分离及高可用性、备份等

一.数据库集群及高可用性 二. 三.mysql实现读写分离 mysql实现读写分离有多种方式: 1)代码语言(php\python\java等)层面实现读写分离,找开发进行实现. 2)通过软件工具实现读写分离,例如amoeba软件 amoeba软件既可以实现负载均衡,也可以实现读写分离,就是进行服务器端压力的分离. 原文地址:https://www.cnblogs.com/dangjingwei/p/11567368.html

Mysql集群读写分离(Amoeba)

实验环境 Master.Amoeba--IP:192.168.1.5 Slave---IP:192.168.1.10 安装JDK JDK下载地址:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html [[email protected] ~]# mkdir /usr/local/JDF [[email protected] ~]# tar -xvf jdk-8u101-linux-x

使用Mycat实现MySQL的分库分表、读写分离、主从切换

Mycat及MySQL实例部署情况:Mycat:IP:10.20.8.57,Port:3310/3311MySQL :db1-M1,IP:10.20.8.126,Port:3306db1-M2,IP:10.20.8.126,Port:3307db2-M1,IP:10.25.80.7,Port:3307架构图如下: 配置Mycatserver.xml: <!DOCTYPE mycat:server SYSTEM "server.dtd"> <mycat:server x

使用drbd结合corosync实现mysql的高可用集群服务

DRBD:Distributed Replicated Block Dvice 分布式复制块设备,它可以将两个主机的硬盘或者分区做成镜像设备,类似于RAID1的原理,只不过它会将主节点的数据主动通过网络同步到从节点做成镜像,当主节点发生故障,让从节点成为主节点,因为是镜像设备,所以数据不会丢失.corosync在这里的作用就是将drbd通过pacemaker做成高可用服务的资源,以便于主从节点间的自动切换.drbd由于使用各节点之间自身的硬盘设备,因此对于需要共享存储的场景不失为一种节约成本的解

JAVAEE——宜立方商城13:Mycat数据库分片、主从复制、读写分离、100%Linux中成功安装Mysql的方法

1 海量数据的存储问题 如今随着互联网的发展,数据的量级也是撑指数的增长,从GB到TB到PB.对数据的各种操作也是愈加的困难,传统的关系性数据库已经无法满足快速查询与插入数据的需求.这个时候NoSQL的出现暂时解决了这一危机.它通过降低数据的安全性,减少对事务的支持,减少对复杂查询的支持,来获取性能上的提升. 但是,在有些场合NoSQL一些折衷是无法满足使用场景的,就比如有些使用场景是绝对要有事务与安全指标的.这个时候NoSQL肯定是无法满足的,所以还是需要使用关系性数据库.如果使用关系型数据库

Mysql读写分离与主从数据库设置方案

Mysql读写分离与主从数据库设置方案 亿仁网 18-10-0711:31 Mysql无非四个功能:增,删,改,读.而将增删改和读分离操作.这样有利于提高系统性能.下面是非常直观的操作: 1.配置: 两台服务器同配置的mysql如mysql5.7 PS:如果条件有限,一台也可以,只需要安装两个mysql服务(不同端口如3306,3307),只是这就有点违背效率初衷了 2.代码: 1.一般直接在代码层将mysql操作类的读写如update,insert与select * from进行路由分离.使之