摘要

  一、MySQL Replication

      介绍MySQL Replication的基本概念,摘自于Mysql官网

  二、Replication Configuration

     2.1 Basic Steps in Configuration

      

一、MySQL Replication

1. What is Replicaiton?

  For the purposes of this article we define "Replication" as the duplication of data to one or more locations.

  These can be co-located within a data center, or geographically distributed.

  Replication enables a database to copy or duplicate changes from one physical location or system to another.

  note:

    •  Replication is relatively good for scaling reads, which you can direct to a slave, but it's not a good way to scale writes unless you design it right
    •  Attaching many slaves to a master simple causes the writes to be done, once on each slave
    •  Replication is also wasteful with more than a few slaves, because it essentially duplicated a lot of data needlessly.

  

2. Problems Solved by Replication

    note:MySQL's replication is usually not very bandwidth-intensive, and you can stop and start it at will

  • Load balancing: Distribute read queries across serveral servers, which works very wll for read-intensive applications.
  • Backups
  • High availability and failover
  • Testing MySQL upgrades

3. Replication: Master-Slave

概念简要说明:

Binary log: Binary log (二进制日志) is a Set of files :

  •  Contains all writes and schema changes
  •  != REDO/Transaction log
  •  Rotated when full (Set max_binlog_size)
  •  Incrementing numbers (defaults, mysql-bin.000001,0000002,0000003...)
  •  Relay Logs are alo binary logs
  •  With 2 Formats: Statement Based(SBR), Row based(RBR, since mysql5.1)

Relay log: 中继日志

Binlog Dump Thread:

  To send the binary logcontens to the slave.

  A master that has multiple slaves "attached" to it creates one binlog dump thread for each currently connected slave, "with each slave having its own I/O and SQL threads."

Slave I/O Thread:

  A START SLAVE statement creates an I/O thread, which connects to the master and asks it to send the updates recorded in its binary logs

Slave SQL Thread:

  To read the relay logs that were written by the slave I/0 thread and executes the updates contained in the relay logs

  If using multi-threaded slaves, mutiple SQL threads will be created on the slave.

4. Replication Modes and Data Consistency

  • Asynchronous Replication:  By default, MySQL is asynchronus.

    Updates are committed to the database on the master and than relayed(重播,转发) to the slave where they are also applied.

  The master does not wait for the slave to receive the update, and so is able to continue processing further write operations without as it waits for acknowledgement from the slave.

  

  • Semi-Synchronous Replication

    Using semi-synchronous replication, a commit is returned to the client only when a slave has received the update, or a timeout occurs.

    Therrfore it is assured that the data exists on the master and at least one slave (note that the slave will have received the update but not necessarily applied it when a commit is returned to the master).

5. MySQL Replication workflow

二、Replication Configuration

2.1 Basic Steps in Replication

step1: Configure one server to be a master

step2: Configure one server to be a slave

step3: Connect the slave to the master

(1) Configure one server to be a master

 To configure a server so that it can act as master, ensure the server has an active binary log and a unique server ID.

  The Server ID is used to distinguish two servers from each other.

  To set up the binary log and Server ID, you have to take the server down and add the log-bin,log-bin-index and server-id options to the my.cnf configuration file.

notes:

  1. It is not necessary to give a name in the log-bin option, The default value is hostname-bin;

  2. It is a good idea to create a name that is unique server and not tied to the machine the server is running on, since it can be confusing to work with a series of binlog files that suddenly change name midstream;

  3. Each server is identified by a unique server ID;

(2) Creating Replication Accounts

  Must create a user account on the master and give it the proper privileges, so the I/O thread can connect as  that user and read the master's binary log

  

(3) Configuration the Slave

  server ID also

   you may also want to consider adding the names of relay log and the relay log index files to the my.cnf file using the options relay-log and relay-log-index

 

(4) Connecting the Master and Slave

Final step: directing the slave to the master so that it knows where to replicate

 It also lets you point the slave at a different master  in the future, without stopping the server.

(5) Monitoring Replication

(6) Watching Replication in Action

Event_type:

  This is the type of the event.

Server_id:

  This is the server ID of the server that created the event

Log_name;

  The name of the file that stores the event

Pos:

  This is the position of the file where the event starts; that is, it's the first byte of the event/

End_log_pos:

  This gives the position in the file where the event ends and the next event starts

Info:
  This is human-readable text with information about the event.

MySQL Replicationation基础的更多相关文章

  1. mysql使用基础 sql语句(一)

    csdn博文地址:mysql使用基础 sql语句(一)  点击进入 命令行输入mysql -u root -p,回车再输入密码,进入mysql. 终端命令以分号作为一条语句的结束,可分为多行输入,只需 ...

  2. mysql数据库基础的简单操作指南

    最近在学习mysql,本文是做的关于mysql学习的笔记,跟大家分享一下,希望对大家学习mysql知识有所助益.mysql现在几乎已经成了网站建设的主流数据库,很多php网站系统都采用了mysql数据 ...

  3. Mysql索引基础

    Mysql索引基础 基本概念: 索引是一种特殊的数据库结构,可以用来快速查询数据库表中的特定记录.索引是提高数据库性能的重要方式.索引创建在表上,是对数据库表中一列或多列的值进行排序的一种结构.可以提 ...

  4. MySQL Replicationation进阶

    摘要 上一篇: MySQL Replication 基础  下一篇 MySQL Replication-MHA 一.主主复制 二.半同步复制 三.复制过滤器 四.总结 五.切分 待续 一.主主复制 M ...

  5. MySQL数据库基础

    MySQL数据库基础 本文的所有操作是基于CMD环境,MySQL通过在命令行中输入SQL语句对数据库进行操作.配置问题可参考<打通MySQL的操作权限>中的内容,该文算是针对前期的环境配置 ...

  6. Mysql数据库基础学习笔记

    Mysql数据库基础学习笔记 1.mysql查看当前登录的账户名以及数据库 一.单表查询 1.创建数据库yuzly,创建表fruits 创建表 ) ) ,) NOT NULL,PRIMARY KEY( ...

  7. 2.Mysql SQL基础

    2.Mysql SQL基础2.1 SQL简介 SQL(Structure Query Language)是结构化查询语言.2.2 SQL使用入门 2.2.1 SQL分类 SQL分为DDL.DML(DQ ...

  8. 【笔记】MySQL的基础学习(二)

    [笔记]MySQL的基础学习(二) MySQL 老男孩  一 视图 视图其实就是给表起个别名 1.创建视图 格式:CREATE VIEW 视图名称 AS SQL语句 CREATE VIEW v1 AS ...

  9. 【笔记】MySQL的基础学习

    [笔记]MySQL的基础学习 老男孩 MySQL  一 安装与配置 1 下载安装 官网:http://dev.mysql.com/downloads/mysql/ 下载相应版本的压缩包 解压压缩包至任 ...

随机推荐

  1. Discuz! X3.2重置管理员账号

    主要是使用了Tools急诊箱.先看一下Tools急诊箱的主要功能: 多种模式在线安装Discuz!,或者重装 重置管理员账号:将把您指定的会员设置为管理员 关闭功能:一键关闭/打开 [站点|插件]的操 ...

  2. [转]奇异值分解(We Recommend a Singular Value Decomposition)

    原文作者:David Austin原文链接: http://www.ams.org/samplings/feature-column/fcarc-svd译者:richardsun(孙振龙) 在这篇文章 ...

  3. Ansible Filter

    没啥好说的. 自己看吧 http://docs.ansible.com/ansible/playbooks_filters.html

  4. 【android错误】bitmap size exceeds 32bits

    使用图片缩放时遇到这么个问题: java.lang.IllegalArgumentException: bitmap size exceeds 32bits 后来一行行查代码,发现原来是 scale ...

  5. WinForms 实现气泡提示窗口(转载)

    [实例说明] 气泡提示因为他的美观又好被大多数用户所接收,用户所喜爱的就是程序员要实现的. 本实例实现了任务栏气泡提示,运行本实例,效果图如下所示: 单击提示.气泡提示就会显示,单击“关闭”气泡又会消 ...

  6. 一个简单sql注入的poc

    最近在提高自己编程能力,拿一些实用的小工具练下.该脚本为python语言,主要涉及模块urllib,re. 功能:验证CmsEasy5.5爆账号密码 实验用源码:http://pan.baidu.co ...

  7. Java:注解(Annotation)自定义注解入门

    转载地址:http://www.cnblogs.com/peida/archive/2013/04/24/3036689.html 要深入学习注解,我们就必须能定义自己的注解,并使用注解,在定义自己的 ...

  8. github本地库及clone常用命令

    新建本地库 1. cd d: 2. mkdir git 3. cd git 4. git init 5. git remote add  origin git@github.com:swportal/ ...

  9. asp 301代码

    <% if request.ServerVariables("HTTP_HOST")="ksfmjy.com" then Response.Status= ...

  10. JAVA17.1.12流程学习,潜心学习,少说多做,脚踏实地,一心一意。