Mysql镜像机制配置过程
主服务器:   192.168.0.25
从服务器:   192.168.0.26
MYSQL版本:mysql-5.0.22.tar.gz
安装日期:2010年5月14日
 
 
一、镜像机制简单介绍
镜像机制是一种能够让运行在不同计算机上的两个或多个Mysql 服务器保持同步变化的机制。不同的数据库系统采用了不同的方法来建立镜像机制。mysql目前只支持“主-从”镜像关系,这种镜像关系的特点是:只有一台主控系统(可读/可写),所有的数据修改操作都必须在这台系统系统上进行,有一台或多台从属系统(只读),他们有着与主控系统完全一样的数据,主控系统在经过一个短暂的延迟后也将发生在他们身上;
 
主从镜像关系中的数据同步是通过主控系统的二进制日志文件实现的,主控系统把自己执行过的 SQL命令记载到自己的二进制日志文件中里,从属系统则通过从主控系统的二进制文件读出SQL命令并加以执行的办法来同步他们自己的数据库;MYSQL镜像机制不要求主控和从属系统必须使用同一种操作系统
 
1)、镜像机制的优点
 
1)、安全;
2)、速度;
 
2)、镜像机制的局限性和不足:
 
1)、Mysql目前只支持“主-从”镜像关系,从属系统只能用来完成数据库查询操作(只读);目前在主控系统发生故障时,mysql的镜像机制还不能把一台从属系统自动切换为新的主控系统;也就是说mysql镜像机制目前只能保障查询操作不会因为主控系统发生故障而无法执行,数据的修改操作还得不到这样的保证,对无缝镜像关系预计在5.1版本中实现;
2)、主从版本最好相同,一般来说从属系统的版本不低于主控系统;
 
 
二、配置过程
第一步配置主服务器
 
1)、首先在主从安装MYSQL;
2)、在主服务器上进入mysql,在命令行下执行
mysql>grant replication slave on *.* to 'slave'@'192.168.0.26' identified by '123456';

mysql> flush privileges;

3)、配置/etc/my.cnf配置文件,修改配置文件中如下内容,如果没有添加上去:

log-bin=mysqlmaster
    
#启动二进制日志系统,绝对应该为日志文件明确的起一个名字(这里我们用mysqlmaster),这是因为没有这么做,mysql服务器将自动使用hostname-bin作为其二进制日志文件的名字,此后万一这台计算机的主机名改变,镜像机制将无法正常工作;
 
binlog-do-db=lianhua
    
需要同步的数据库名
binlog-ignore-db=mysql
 
binlog-ignore-db=test
    
不需要同步的数据库名避免同步mysql用户配置,以免不必要的麻烦
 
server-id = 1
    
机数据库ID 标示为主,该部分还应有一个server-id=Master_id选项,其中master_id必须为1到232–1之间的一个正整数值
 
 
             
4)、停止数据库,并将本地需要同步数据库打包拷贝到从数据库上
#service mysqld stop                  
#cd /usr/local/mysql/var                
#tar -cvf lianhua.tar lianhua           
#scp lianhua.tar root@192.168.0.25:/usr/local/mysql   
[root@node1 ~]#Service mysqld start      
 
第二步、配置从服务器
1)、停止数据库
#service mysqld stop
 
2)、配置slave服务器/etc/my.cnf文件
    
server-id       = 2
    
从服务器ID号,不要和主ID相同
master-connect-retry =60
    
断点重新连接时间
replicate-ignore-db = mysql
replicate-ignore-db = test
    
不需要同步的数据库名
replicate-do-db = lianhua
    
同步数据库名
 
3)、装载主服务器数据库并启动数据库
[root@dnsslave var]# tar -xvf lianhua.tar
[root@dnsslave var]# service mysqld start
Starting MySQL                                             [确定]
 
 
第三步
 
1)、在主服务器上进入mysql的命令行
用下面的命令查看
[root@dns log]# mysql -u root -p
Enter password:
 
mysql> show master status;          #显示(不同主机结果不同)
 
+--------------------+----------+--------------+------------------+
| File               | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+--------------------+----------+--------------+------------------+
| mysqlmaster.000002 |       98 | lianhua      | mysql,test       |
+--------------------+----------+--------------+------------------+
1 row in set (0.02 sec)
 
2)、在从服务器上执行MYSQL命令行如下:
mysql> slave stop;       
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> change master to
    ->master_host = ‘192.168.0.25’,
->master_user = ‘slave’,
->master_password = ‘123456’,
    -> master_log_file = 'mysqlmaster.000002',
    -> master_log_pos = 98;
Query OK, 0 rows affected (0.01 sec)
mysql>slave start;                    
mysql> show slave status\G;
用show slave status\G;看一下从服务器的同步情况

关于后面红线的错误提示,咨询过属正常现象,我还是不大明白,还望指教;
 
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
如果都是yes,那代表已经在同步
 
第四步:测试
1)、在主服务器
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| lianhua            |
| mysql              |
| test               |
+--------------------+
4 rows in set (0.00 sec)
 
mysql> use lianhua;
Database changed
 
mysql> create table sanguo (id INT,name char(10));
Query OK, 0 rows affected (0.03 sec)
 
mysql> show tables;
+-------------------+
| Tables_in_lianhua |
+-------------------+
| sanguo            |
+-------------------+
1 row in set (0.00 sec)
#用navicat连接创建数据内容;
 
mysql> select * from sanguo;
+------+--------+
| id   | name   |
+------+--------+
|    1 | 刘备   |
|    2 | 关羽   |
|    3 | 张飞   |
|    4 | 赵云   |
+------+--------+
4 rows in set (0.00 sec)
 
 
2)、在从服务器上登录
 
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| lianhua            |
| mysql              |
| test               |
+--------------------+
4 rows in set (0.00 sec)
 
mysql> use lianhua;
Database changed
mysql> show tables;
+-------------------+
| Tables_in_lianhua |
+-------------------+
| sanguo            |
+-------------------+
1 row in set (0.00 sec)
 
mysql> select * from sanguo;
+------+--------+
| id   | name   |
+------+--------+
|    1 | 刘备   |
|    2 | 关羽   |
|    3 | 张飞   |
|    4 | 赵云   |
+------+--------+
4 rows in set (0.00 sec)
 
mysql>
连个表都是一样的。

[转]mysql主从同步的更多相关文章

  1. zabbix3.0.4监控mysql主从同步

    zabbix3.0.4监控mysql主从同步 1.监控mysql主从同步原理: 执行一个命令 mysql -u zabbix -pzabbix -e 'show slave status\G' 我们在 ...

  2. MySQL主从同步几个文件

    MySQL主从同步:   M锁表 M导出S导入 M解锁 M建同步帐号 S获取点位:产生master.info S开启同步   3306: mysql-bin.0000x mysql-bin.index ...

  3. 监控mysql主从同步状态脚本

    监控mysql主从同步状态脚本 示例一: cat check_mysql_health #!/bin/sh slave_is=($(mysql -S /tmp/mysql3307.sock -uroo ...

  4. Linux下MySQL主从同步配置

    Centos6.5 MySQL主从同步 MySQL版本5.6.25 主服务器:centos6.5 IP:192.168.1.101 从服务器:centos6.5 IP:192.168.1.102 一. ...

  5. Mysql主从同步(复制)

    目录: mysql主从同步定义      主从同步机制 配置主从同步      配置主服务器      配置从服务器 使用主从同步来备份      使用mysqldump来备份      备份原始文件 ...

  6. MySQL主从同步原理 部署【转】

    一.主从的作用:1.可以当做一种备份方式2.用来实现读写分离,缓解一个数据库的压力二.MySQL主从备份原理master 上提供binlog ,slave 通过 I/O线程从 master拿取 bin ...

  7. shell脚本修复MySQL主从同步

    发布:thebaby   来源:net     [大 中 小] 分享一例shell脚本,用于修改mysql的主从同步问题,有需要的朋友参考下吧. 一个可以修改mysql主从同步的shell脚本. 例子 ...

  8. nagios 实现Mysql 主从同步状态的监控

    一.系统环境 主机名 IP nagios 192.168.15.111 mysql_s 192.168.15.21 二.操作步骤 2.1 mysql_s端的配置 2.1.1 编写check_mysql ...

  9. mysql 主从同步出问题,重新修复从库 - web架构研究

    mysql 主从同步出问题,重新修复从库 - web架构研究     mysql 主从同步出问题,重新修复从库    0     昨天由于操作失误,在从库上执行一堆sql之后,导致主从同步错误,并且已 ...

  10. mysql主从同步配置(windows环境)

    mysql主从同步配置(mysql5.5,windows环境)   A主机(作为主服务器)环境:windows8.mysql5.5 ip:192.168.1.100(自己填) B主机(作为从服务器,由 ...

随机推荐

  1. P1064 金明的预算方案 (分组背包稍稍变形)

    题目描述 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间金明自己专用的很宽敞的房间.更让他高兴的是,妈妈昨天对他说:“你的房间需要购买哪些物品,怎么布置,你说了算,只要不超过NN元钱就行”. ...

  2. thinkphp ajax调用demo

    http://files.cnblogs.com/files/jxkshu/tp_ckgd.rar

  3. SpringBoot项目框架下ThreadPoolExecutor线程池+Queue缓冲队列实现高并发中进行下单业务

    主要是自己在项目中(中小型项目) 有支付下单业务(只是办理VIP,没有涉及到商品库存),目前用户量还没有上来,目前没有出现问题,但是想到如果用户量变大,下单并发量变大,可能会出现一系列的问题,趁着空闲 ...

  4. python 调用redis

    #!/usr/bin/env python #_*_ coding:UTF-8 _*_ import redis import pickle #普通连接 ''' db="db1" ...

  5. Dubbo入门到精通学习笔记(十一):Dubbo服务启动依赖检查、Dubbo负载均衡策略、Dubbo线程模型(结合Linux线程数限制配置的实战分享)

    文章目录 Dubbo服务启动依赖检查 Dubbo负载均衡策略 Dubbo线程模型(结合Linux线程数限制配置的实战分享) 实战经验分享( ** 属用性能调优**): Dubbo服务启动依赖检查 Du ...

  6. 网络数据包最大长度 MTU 分片 转发https://blog.csdn.net/singular2611/article/details/52513406

    1.数据链路层对数据帧的长度都有一个限制,也就是链路层所能承受的最大数据长度,这个值称为最大传输单元,即MTU.以以太网为例,这个值通常是1500字节. 2.对于IP数据包来讲,也有一个长度,在IP包 ...

  7. jQuery 加载事件

    1. jquery加载事件实现 ① $(document).ready(function处理); ② $().ready(function处理); ③ $(function处理);  对第一种加载的封 ...

  8. 4.2.1 Vector bit-select and part-select addressing

    Frm:IEEE Std 1364™-2001, IEEE Standard Verilog® Hardware Description Language Bit-selects extract a ...

  9. qemu通过命令行直接引导linux内核启动

    qemu -kernel vmlinuz-3.14.0 -hda img_custom -append root=/dev/sda1

  10. Linux用户空间内存区域的匿名映射

    1 在调用mmap系统调用时,可以指定的标志(flag)参数: 1: #define MAP_SHARED 0x01 /* Share changes */ 2: #define MAP_PRIVAT ...