`
tw5566
  • 浏览: 448651 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

(转)mysql 主从数据库配置(windows)

 
阅读更多

系统环境:Windows 2003
       MYSQL版本 5.1.38
1:主服务器main
IP地址:192.168.1.101
2:从服务器companion
IP地址:192.168.1.102

1、首先停止主服务器Mysql服务,备份数据库到从服务器确保主从服务器数据库数据一样。后启动MYSQL服务。


2、在主服务器Mysql数据库上创建一个备份用户
命令如下:

Java代码  收藏代码
  1. GRANT REPLICATION SLAVE,RELOAD,SUPER ON *.* to hao@'192.168.1.102' IDENTIFIED BY '123'  

建立一个帐户hao,并且只能允许从192.168.1.102这个地址上来登陆,密码是123。赋予权限:REPLICATION SLAVE,RELOAD,SUPER(同时赋予需要同步的数据库全部权限)

 

在2号服务器: companion上做连接测试: mysql -h 192.168.1.101 -u backup -p  输入密码123测试连接登陆。

 

 

3、对A服务器的配置进行修改,打开mysql/my.ini文件,在[mysqld]下面添加如下内容:

Java代码  收藏代码
  1. server-id=1 #主数据库ID  
  2. log-bin=D:\mysqllog\log-bin.log #二进制变更日志  
  3. binlog-do-db=mytest #需要同步的数据库名  
  4. binlog-ignore-db=mysql #不需要同步的数据库名  
  5. binlog-ignore-db=test #不需要同步的数据库名复制代码  

 

 

 4、重启A服务器,从现在起,它将把客户堆有关数据库的修改记载到二进制变更日志里去。

 

5、对B服务器的配置进行修改,打开mysql/my.ini文件,在[mysqld]下面添加如下内容:

Java代码  收藏代码
  1. server-id=2 #从服务器B的ID值。注意不能和主服务器的ID值相同  
  2. master-host=192.168.1.101 #主服务器的IP地址  
  3. log-bin=D:\mysqllog\log-bin.log #二进制变更日志  
  4. master-user=backup #从服务器连接主服务器的帐号  
  5. master-password=123 #从服务器连接主服务器的帐号密码  
  6. master-port=3306 #主服务器端口  
  7. master-connect-retry=60 #同步时间间隔为60秒  
  8. ######以下内容为可选  
  9. replicate-do-db=mytest #需要同步的数据库  
  10. binlog-ignore-db=mysql #不需要同步的数据库  

 

6、重启从服务器B。至此所有设置全部完成。更新A中的数据,B中也会立刻进行同步更新。

 

检测是否同步与排错可用以下命令查看:
1、在slave从服务器B上 输入:show slave status\G
主要查看:
Slave_IO_Running: Yes (#注:如果这个为NO,可重新修改my.ini 中相关slave的配置信息,重新启动查看 slave的状态还是显示未修改的数据,应为 第一次是读取my.ini,之后就会在mysql/下生成一个master.info 的文件,因此第二次就不会读取my.ini 的内容,而是读取master.info中的内容,为此要想使重新修改的my.ini生效的话,删除master.info文件 ,重起mysql既可解决。如果不能解决则可能是彼此之间的通讯问题或其它)
Slave_SQL_Running: Yes (#注:如果这里为NO,很有可能是因为你的A库和B库的数据库不一致造成的。停止主从服务器MYSQL服务后删除A库中所有log-bin.log文件和B库所有的relay_log文件 并重启AB服务器即可解决)
Seconds_Behind_Master是否为0,0就是已经同步

2、在master主服务器A上输入show processlist\G
mysql> show processlist\G
*************************** 1. row ***************************
     Id: 2
   User: backup
   Host: 192.168.1.102:3341
     db: NULL
Command: Binlog Dump
   Time: 849
  State: Has sent all binlog to slave; waiting for binlog to be updated
   Info: NULL
*************************** 2. row ***************************

如果出现Command: Binlog Dump,则说明配置成功.

# stop slave    #停止同步
# start slave    #开始同步,从日志终止的位置开始更新。
# SET SQL_LOG_BIN=0|1 #主机端运行,需要super权限,用来开停日志,随意开停,会造成主机从机数据不一致,造成错误
# SET GLOBAL SQL_SLAVE_SKIP_COUNTER=n # 客户端运行,用来跳过几个事件,只有当同步进程出现错误而停止的时候才可以执行。
# RESET MASTER #主机端运行,清除所有的日志,这条命令就是原来的FLUSH MASTER
# RESET SLAVE   #从机运行,清除日志同步位置标志,并重新生成master.info
虽然重新生成了master.info,但是并不起用,最好,将从机的mysql进程重启一下,
# LOAD TABLE tblname FROM MASTER #从机运行,从主机端重读指定的表的数据,每次只能读取一个,受timeout时间限制,需要调整timeout时间。执行这个命令需要同步账号有 reload和super权限。以及对相应的库有select权限。如果表比较大,要增加net_read_timeout 和net_write_timeout的值
# LOAD DATA FROM MASTER #从机执行,从主机端重新读入所有的数据。执行这个命令需要同步账号有reload和super权限。以及对相应的库有select权限。如果表比较大,要增加net_read_timeout 和net_write_timeout的值
# CHANGE MASTER TO master_def_list #在线改变一些主机设置,多个用逗号间隔,比如
CHANGE MASTER TO
MASTER_HOST='master2.mycompany.com',
MASTER_USER='replication',
MASTER_PASSWORD='bigs3cret'
# MASTER_POS_WAIT()#从机运行
# SHOW MASTER STATUS#主机运行,看日志导出信息
# SHOW SLAVE HOSTS#主机运行,看连入的从机的情况。
# SHOW SLAVE STATUS(slave)
# SHOW MASTER LOGS(master)
# SHOW BINLOG EVENTS [ IN 'logname' ] [ FROM pos ] [ LIMIT [offset,] rows ]
# PURGE [MASTER] LOGS TO 'logname' ; PURGE [MASTER] LOGS BEFORE 'date'

参考检测方法:
在A执行
mysql> show master status\G
*************************** 1. row ***************************
            File: log-bin.000002
        Position: 106
    Binlog_Do_DB: mytest
Binlog_Ignore_DB: mysql,test
1 row in set (0.00 sec)
在B执行
mysql> show slave status\G
*************************** 1. row ***************************
             Slave_IO_State: Waiting for master to send event
                Master_Host: 192.168.1.101
                Master_User: backup
                Master_Port: 3306
              Connect_Retry: 60
            Master_Log_File: log-bin.000002
        Read_Master_Log_Pos: 106
             Relay_Log_File: weige-relay-bin.000005
              Relay_Log_Pos: 659
      Relay_Master_Log_File: log-bin.000002
           Slave_IO_Running: Yes
          Slave_SQL_Running: Yes
            Replicate_Do_DB: mytest
        Replicate_Ignore_DB: mysql,test
         Replicate_Do_Table:
     Replicate_Ignore_Table:
    Replicate_Wild_Do_Table:
Replicate_Wild_Ignore_Table:
                 Last_Errno: 0
                 Last_Error:
               Skip_Counter: 0
        Exec_Master_Log_Pos: 524
            Relay_Log_Space: 659
            Until_Condition: None
             Until_Log_File:
              Until_Log_Pos: 0
         Master_SSL_Allowed: No
         Master_SSL_CA_File:
         Master_SSL_CA_Path:
            Master_SSL_Cert:
          Master_SSL_Cipher:
             Master_SSL_Key:
      Seconds_Behind_Master: 0
1 row in set (0.00 sec)

分享到:
评论

相关推荐

    windows下mysql数据库主从配置教程

    windows下配置mysql数据库主从的详细过程,具体内容如下 所用到工具: Mysql、Navicat Premium; 主库设置: 一.设置my.ini 文件; 1.在安装目录下找到my.ini 文件: 默认路径:C:\Program Files\MySQL\MySQL ...

    解读mysql主从配置及其原理分析

    在windows下配置的,后面会在Linux下配置进行测试,需要配置mysql数据库同步的朋友可以参考下

    windows下MySql配置主从

    最近用到的,配置 主从数据库,亲自使用成功的文档分享给大家,希望有帮助。

    MySql主从配置实践过程记录

    在Windows下通过MySql提供的主从复制技术实现数据库主从同步机制,文档中详细记录我在项目中配置的实践过程

    MySQL5.7主从复制(Win10)及mybatis相关配置

    详细介绍了mysql5.7在win10下的主从配置,及添加slave节点 也附上了mybatis下的配置,主数据写,从数据库读,从数据库根据请求数平均分配的查询,达到简单的负载均衡

    windows主从同步

    mysql数据库windows下mysql主从同步备份步骤 haha_yong2人评论2507人阅读2010-04-29 11:13:54 windows下mysql主从同步备份步骤 A:主服务器 IP地址:192.168.1.124 B:从服务器 IP地址:192.168.1.125 前提:设置...

    详解windows下mysql的主从同步

    主从数据库操作准备: 两台电脑,都安装好mysql 5.5及以上版本,最好两台电脑都安装同一版本数据库,且能单独正常使用 记住两台电脑的ip地址: 以我家里电脑为例: 主数据库:192.168.0.102 从数据库:192.168.0....

    小记一次mysql主从配置解决方案

    今天研究了个开源项目,数据库是mysql的,其中的脚本数据需要备份,由于本人的机器时mac pro,而且mac下的数据库连接工具都不怎么好用,就想着如何利用windows下的数据库连接工具使用,并做相关备份,另外windows...

    MySQL主从同步、读写分离配置步骤

    为了避免不必要的麻烦,主从服务器MySQL版本尽量保持一致; 环境:192.168.0.1 (Master) 192.168.0.2 (Slave) MySQL Version:Ver 14.14 Distrib 5.1.48, for pc-linux-gnu (i686) using readline 5.1 1、登录...

    mysql_home-to-client.rar_Home Home_c# mysql_mysql 5.5

    Mysql windows下 主从数据库配置,数据库版本mysql 5.5,包括测试程序和步骤

    winserver 2016实现mysql数据库主从配置

    主库Mysql版本:mysql-5.7.20-winx64 从库Mysql版本:mysql-5.7.20-winx64 主库的ip地址:192.168.11.132 从库的ip地址:192.168.11.134 主库的端口:3306 从库的端口:3306 注:主库和从库版本可以一致也可以不...

    Windows下MySQL主从复制的配置方法

    MySQL主从复制允许将来自一个数据库(主数据库)的数据复制到一个或多个数据库(从数据库)。 主数据库一般是实时的业务数据写入和更新操作,从数据库常用的读取为主。 主从复制过程: 1、主服务器上面的任何修改...

    windows环境下mysql数据库的主从同步备份步骤(单向同步)

    windows下mysql双向同步备份实现方法以下的文章主要讲述的是在windows环境下实现MySQL数据库的主从同步备份的正确操作方案,我在一些相关的网站看见关于windows环境下实现MySQL数据库的主从同步备份的操作步骤描述,...

    MySql数据库同步复制

    该功能可以实现两个数据库同步,主从模式,互相备份模式的功能。 数据库同步复制功能的设置都在mysql的设置文件中体现。mysql的配置文件(windows下为my.ini,Unix/Linux下为my.cnf)

    解读mysql主从配置及其原理分析(Master-Slave)

    在windows下配置的,后面会在Linux下配置进行测试,需要配置mysql数据库同步的朋友可以参考下。

    MYSQL5.6.33数据库主从(Master/Slave)同步安装与配置详解(Master-Linux Slave-windows7)

    主要为大家详细介绍了MYSQL5.6.33数据库主从(Master/Slave)同步安装与配置,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

    Mysql 数据库双机热备的配置方法

    要想实现双机的热备首先要了解主从数据库服务器的版本的需求。要实现热备mysql的版本都要高于3.2,还有一个基本的原则就是作为从数据库的数据库版本可以高于主服务器数据库的版本,但是不可以低于主服务器的数据库...

Global site tag (gtag.js) - Google Analytics