1、创建用户并设置远程访问授权

1). A上添加: //ip地址为B的ip地址,用于B访问
  # grant replication slave,replication client,reload,super on *.* to 'sync_user'@'192.168.2.220' identified by '' with grant option;  

2). B上添加://ip地址为A的ip地址,用于A访问 
  # grant replication slave,replication client,reload,super on *.* to 'sync_user'@'192.168.2.67' identified by '' with grant option;
3). 执行命令更新数据库使用户生效。
  # flush privileges; 

2、确保mysql对外部ip开放

1). 确认一下3306是否对外开放,MySQL默认状态下是不开放对外访问功能的。查看的办法如下:

  ~# netstat -an | grep
  tcp 127.0.0.1: 0.0.0.0:* LISTEN   从上面可以看出,mysql的3306端口只是监听本地的连接,这样就阻碍了外部IP对该数据库的访问,修改的办法其实很简单,进入到mysql的配置文件所在目录(/etc/mysql/my.cnf(默认),有的是在/etc/my.cnf)下,找到文件中的如下内容:   # Instead of skip-networking the default is now to listen only on
  # localhost which is more compatible and is not less secure.   bind-address = 127.0.0.1   将bind-address注释掉,或者改成你想要使用的客户端主机IP。
  这样mysql的远程访问端口就算开启了
  ~# netstat -an | grep 3306
  tcp        0      0 0.0.0.0:3306            0.0.0.0:*               LISTEN 2). 关闭防火墙
  # service iptables stop

3. 创建同步测试表

create database testsync;
use testsync; create table t_user (
id int primary key auto_increment,
username varchar(),
age int
);

4. 配置A B的mysql(查看my.cnf位置 mysql --help | grep my.cnf)

# vi /etc/my.cnf

在[mysqld]下添加如下字段:

#两台机器的server-id不能相同
server-id =
log-bin=mysql-bin
binlog_format=mixed
replicate-do-db=testsync
replicate-ignore-db=mysql,information_schema,performance_schema

5. 重启并进入mysql

0). 查看主机状态
  # show master status;
+-------------------+----------+--------------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+-------------------+----------+--------------------+------------------+-------------------+
| mysqld-bin. | | happy,ipaddressmgr | | |
+-------------------+----------+--------------------+------------------+-------------------+
row in set (0.00 sec)

1). 设置主机信息
  # change master to master_host='192.168.2.220',master_user='sync_user',master_password='',master_log_file='mysql-bin.000005',master_log_pos=68113; 2). 启动slave
  # start slave; 3). 查看是否启动成功
  # show processlist;
+----+-------------+-------------------------+------+-------------+------+-----------------------------------------------------------------------------+------------------+
| Id | User | Host | db | Command | Time | State | Info |
+----+-------------+-------------------------+------+-------------+------+-----------------------------------------------------------------------------+------------------+
| | system user | | NULL | Connect | | Waiting for master to send event | NULL |
| | system user | | NULL | Connect | | Slave has read all relay log; waiting for the slave I/O thread to update it | NULL |
| | sync_user | pc.local: | NULL | Binlog Dump | | Master has sent all binlog to slave; waiting for binlog to be updated | NULL |
| | root | localhost | NULL | Query | | NULL | show processlist |
+----+-------------+-------------------------+------+-------------+------+-----------------------------------------------------------------------------+------------------+

4). 查看slave上的master状态
  #show master status; 5). 查看slave状态
  # show slave status\G;

6. 以上便实现主从备份,如果想要双主,只需要在另一台mysql上,执行步骤4, 5即可。

错误处理:

101027 16:50:58 [Note] Slave I/O thread: connected to master 'xxx@xxxxxx:3306',replication started in log 'xxx-bin.000001' at position 1440046 
101027 16:50:58 [ERROR] Error reading packet from server: Could not find first log file name in binary log index file ( server_errno=1236) 
101027 16:50:58 [ERROR] Slave I/O: Got fatal error 1236 from master when reading data from binary log: 'Could not find first log file name in binary log index file', Error_code: 1236 
101027 16:50:58 [Note] Slave I/O thread exiting, read up to log 'xxx-bin.000001', position 1440046 Slave_IO_Running: No
Slave_SQL_Running: Yes

原因:master_log_file或者master_log_pos配置错误 或者 权限错误
按照正常流程解决,应该是:
stop slave;
CHANGE MASTER TO MASTER_HOST='xxx',MASTER_USER='xx',MASTER_PASSWORD='xx',MASTER_PORT=,MASTER_LOG_FILE='xxx-bin.000001',MASTER_LOG_POS=;
start slave; 问题依然存在, 后来经过以下步骤解决,不过有点困惑:
、重启主库
2、stop slave;
、给从库重新授权
、执行以下命令 reset slave; start slave;

mysql 主从,双主同步的更多相关文章

  1. Docker Mysql数据库双主同步配置方法

    一.背景 可先查看第一篇<Docker Mysql数据库主从同步配置方法>介绍 二.具体操作 1.创建目录(~/test/mysql_test1): --mysql --mone --da ...

  2. MySQL热机双备之双主同步复制配置

    此配置方案来源于csdn前辈博客,奈何找不到出处了,抱拳!!! 1.  MySQL同步机制概述 MySQL支持单向.异步复制,复制过程中一台服务器充当主服务器,一台或多台服务器充当从服务器,双主同步要 ...

  3. MySQL 5.7双主同步部分表

    参考:http://www.jb51.net/article/122892.htm?pc 前言: 我们要配置双主同步的mysql服务器. 暂时叫做,mysql1和mysql2吧. 一  mysql的配 ...

  4. Mysql+Keepalived双主热备高可用操作记录

    我们通常说的双机热备是指两台机器都在运行,但并不是两台机器都同时在提供服务.当提供服务的一台出现故障的时候,另外一台会马上自动接管并且提供服务,而且切换的时间非常短.MySQL双主复制,即互为Mast ...

  5. 学一点 MYSQL 双机异地热备份—-MYSQL主从,主主备份原理及实践

    简单介绍mysql双机,多机异地热备简单原理实战. 双机热备的概念简单说一下,就是要保持两个数据库的状态自动同步.对任何一个数据库的操作都自动应用到另外一个数据库,始终保持两个数据库数据一致. 这样做 ...

  6. otter双主同步安装与配置

    otter是阿里的开源数据同步项目,资源地址就不用说了哈,网上找,阿里云论坛关于单方向同步的配置已经很清楚了,理论上说,双主同步也不复杂,但是毕竟 是数据库,比较重要,配置双主的时候,总觉得心里没底, ...

  7. Apache+lvs高可用+keepalive(主从+双主模型)

    Apache+lvs高可用+keepalive(主从+双主模型)     keepalive实验准备环境: httpd-2.2.15-39.el6.centos.x86_64 keepalived-1 ...

  8. 生产环境中mysql+keepalive双主模式,keepalive守护进程实现双主切换提供数据库服务

    mysql+keepalive实现浮动地址自动切换,由于keepalive无自带健康检查功能,所以必须自动编写健康检查守护进程(监控DB1和DB2数据库的监控状态,来保证浮动地址双机自动切换.) 一, ...

  9. Centos 7 下安装LDAP 双主同步

    Centos 7 下安装LDAP 双主同步 标签(空格分隔): LDAP 安装说明: 从OpenLDAP2.4.23版本开始所有配置数据都保存在slapd.d目录下的cn=config文件夹中,不再使 ...

  10. MySQL keepalived 双主.md

    MySQL keepalived 双主搭建 环境说明 系统 IP 主机名 mysql keepalived VIP CentOS 6.8 192.168.197.61 C6-node1 5.6.36 ...

随机推荐

  1. 【POJ】3268 Silver Cow Party

    题目链接:http://poj.org/problem?id=3268 题意 :有N头奶牛,M条单向路.X奶牛开party,其他奶牛要去它那里.每头奶牛去完X那里还要返回.去回都是走的最短路.现在问这 ...

  2. 2018湘潭大学程序设计竞赛【C】

    题目链接:https://www.nowcoder.com/acm/contest/105/C 题意:给你几个矩形的左上角和右下角的坐标,让你算有几个矩形相交. 题解: 每次都暴力标记一下炸弹区域里的 ...

  3. ES6 学习 -- Class

    Class的基本语法(1)// 定义类class Point { test() { console.log("hello test"); }}通过 new 定义好的类即可生成一个类 ...

  4. SVN Cannot merge into a working copy that has local modifications

    我尝试了 主支,分支都提交,但是依然无法合并. 最终,我在服务器上将分支删除,然后主支在拷贝过去. 一,打开服务器资源 二,删除分支 三,拷贝主支到分支 四,刷新分支,就能看到了. 然后在分支项目中, ...

  5. mysql连接超时的问题处理

    1. 内网 ts 连接mysql 有时候会连接失败, 原因是 连接超时, 当时所有服务器一起启动,抢占资源,导致连接超过10s. 现在增加一次连接机会, 增加一些日志. 2. 并且对mysql 全局参 ...

  6. mysql-connetor-c 自动创建数据库、数据库表的命令

    1.首先连接MySQL默认的数据库mysql // 参数说明: // strIP: MySQL数据库的IP地址 // nPort: MySQL数据库的端口号 // strDBName: 要连接的数据库 ...

  7. Python全栈开发:django网络框架(一)

    Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM.模型绑定.模板引擎.缓存.Session等诸多功能. ...

  8. 用Jquery写返回顶部代码

    <!DOCTYPE html><html><head><meta charset="utf-8" /><title>jq ...

  9. 数据库MySQL--联合查询

    应用场景:当要查询的结果来自多个表,且多个表没有直接的连接关系,但查询的信息一致时 语法: 查询语句1 union(all) 查询语句2 union(all) ..... 注:多条查询语句的查询列数要 ...

  10. Git 如何使用ssh上传或者同步/下载项目到github

    上传本地代码及更新代码到GitHub教程 上传本地代码 第一步:去github上创建自己的Repository,创建页面如下图所示: 红框为新建的仓库的https地址 第二步: echo " ...