MySQL集群系列1:2台机器搭建双主集群
先配置静态IP
配置my.cnf
先关闭防火墙
2台机器除了server-id不同之外,配置项基本一样(把a改为b)。
在[mysqld]部分添加如下:
#add log-bin=master-a-bin server-id=1 relay-log=master-a-relay-bin log_slave_updates=1
sync_binlog=1
#add
配置项说明
两台MySQL均要开启binlog日志功能
两台MySQL的server-ID不能一样,需将其中一台修改为2
log_slave_updates表示slave将复制事件写进自己的二进制日志
sync_binlog=1。每进行1次事务提交之后,MySQL将进行一次fsync之类的磁盘同步指令来将binlog_cache中的数据强制写入磁盘。
修改配置后重启mysqld
service mysqld restart
其它配置项:待查
1.主服务器A(123.1.1.123)创建用户并清空日志
grant replication slave on *.* to 'root'@'%' identified by 'pwd'; flush privileges;
为了安全,最好将“%”改为具体的IP地址(如123.1.1.124),使该帐户只能在指定的从服务器上使用。
flush tables with read lock; 备份数据前先锁表,保证数据一致性
show binary logs; reset master; show binary logs; unlock tables;
记录下 FILE 及 Position 的值,在后面进行从服务器操作的时候需要用到。
从服务器B清空日志
show binary logs; reset master; show binary logs;
从服务器通过change master to命令修改设置
change master to master_host='123.1.1.123',
master_user='root', master_password='pwd',
master_port=3306, master_log_file='master-a-bin.000001',master_log_pos=106;
以上全部复制后修改并粘贴 show slave status \G;
在输出的信息中:
Slave_IO_Running: No Slave_SQL_Running: No
需要使其值为Yes
start slave; show slave status \G;
错误:
Last_IO_Error: error connecting to master 'root@123.1.1.123:3306'mysql -h 10.24.54.18 -ureplication -pERROR 1130 (HY000): Host '123.103.58.124' is not allowed to connect to this MySQL serverERROR 1045 (28000): Access denied for user 'root'@'123.103.58.124' (using password: YES)最后发现是密码不对。
2.设置从服务器B
在“从机”B上设置复制帐号
grant replication slave on *.* to 'root'@'%' identified by 'pwd';
flush privileges;
清空“从机”日志:
show binary logs; reset master; show binary logs;
在原主服务器A上通过change master to命令修改设置,可以全部复制并粘贴:
change master to master_host='123.103.*.124',
master_user='root', master_password='pwd', master_port=3306, master_log_file='master-b-bin.000001', master_log_pos=106;
先
show slave status \G;
看看
Slave_IO_Running: No Slave_SQL_Running: No
需要使其值为Yes
start slave; show slave status \G;
应该有
Slave_IO_Running: Yes Slave_SQL_Running: Yes
设置完后重启:service mysqld restart
=============================完==================
如果数据不匹配
测试
show databases; create database a1; use a1; create table t1(id int auto_increment primary key,name varchar(30)); insert into t1(name) values('appBox1');
可以发现数据库已同步,但2台皆可写。
下一节将实现读写分离。
MySQL集群系列1:2台机器搭建双主集群的更多相关文章
- MySQL集群系列2:通过keepalived实现双主集群读写分离
在上一节基础上,通过添加keepalived实现读写分离. 首先关闭防火墙 安装keepalived keepalived 2台机器都要安装 rpm .el6.x86_64/ 注意上面要替换成你的内核 ...
- 六台机器搭建RedisCluster分布式集群
原文:六台机器搭建RedisCluster分布式集群 版权声明:m_nanle_xiaobudiu https://blog.csdn.net/m_nanle_xiaobudiu/article/de ...
- centos 7 两台机器搭建三主三从 redis 集群
参考自:https://linux.cn/article-6719-1.htmlhttp://blog.csdn.net/xu470438000/article/details/42971091 ## ...
- 集群中配置多台机器之间 SSH 免密码登录
集群中配置多台机器之间 SSH 免密码登录 问题描述 由于现在项目大多数由传统的单台机器部署,慢慢转变成多机器的集群化部署. 但是,这就涉及到机器间的 SSH 免密码互通问题. 当集群机器比较多的时候 ...
- RocketMQ学习笔记(16)----RocketMQ搭建双主双从(异步复制)集群
1. 修改RocketMQ默认启动端口 由于只有两台机器,部署双主双从需要四个节点,所以只能修改rocketmq的默认启动端口,从官网下载rocketmq的source文件,解压后使用idea打开,全 ...
- RocketMQ学习笔记(4)----RocketMQ搭建双Master集群
前面已经学习了RockeMQ的四种集群方式,接下来就来搭建一个双Master(2m)的集群环境. 1. 双Master服务器环境 序号 ip 用户名 密码 角色 模式 (1) 47.105.145.1 ...
- 解决mysql跟php不在同一台机器上,编译安装php服务报错问题:configure: error: Cannot find MySQL header files under /application/mysql.
在编译安装php服务时报错: configure: error: Cannot find MySQL header files under /application/mysql. Note that ...
- 基于Mysql 5.7 GTID 搭建双主Keepalived 高可用
实验环境 CentOS 6.9 MySQL 5.7.18 Keepalived v1.2.13 拓扑图 10.180.2.161 M1 10.180.2.162 M2 10.180.2.200 VIP ...
- 读懂在单台机器上创建RabbitMQ集群
在优锐课java中了解有关在单台计算机上安装集群以及如何向集群添加更多节点的更多信息,码了很多专业的相关知识, 分享给大家参考学习. 如果你在单台计算机上设置群集时遇到问题,那么以下文章可能会帮助回答 ...
随机推荐
- 如何使用 awk 输出文本中的字段和列
首先我们要知道,awk 能够自动将输入的行,分隔为若干字段.每一个字段就是一组字符,它们和其他的字段由一个内部字段分隔符分隔开来. 如果你熟悉 Unix/Linux 或者懂得 bash shell 编 ...
- 省市区县三级联动JAVA+MySQL+JQuery
场景介绍: 由于项目要求,需要做一个进件(新增)功能,而该功能里要用到车品牌.车系.车型的联动查询,也就是经典的三级联动. 大体思路如下: 进入页面,会把所有的车品牌(第一级)在后台查询出来,放到缓存 ...
- SQL PL/SQL语法手册
SQL PL/SQL语法手册 目 录 第一部分 SQL语法部分 3 一. CREATE TABLE 语句 3 二. CREATE SEQUENCE语句 5 三. CREATE VIEW语句 6 ...
- location.href
location.href用法 CreateTime--2018年2月22日15:22:02 Author:Marydon 1.在当前页面打开URL页面 // 方式一 window.locatio ...
- javascript Date日期类
四.Date日期类 迁移时间:2017年5月27日18:43:02 Author:Marydon (一)对日期进行格式化(日期转字符串) 自定义Date日期类的format()格式化方法 方式一: ...
- php抽象类和接口的异同【转】
1. 相同点: (1) 两者都是抽象类,都不能实例化. (2) interface 实现类及 abstract class 的子类都必须要实现已经声明的抽象方法. 2. 不同点: ...
- Python-常用字符串转换实例
当字符串是:'\u4e2d\u56fd' >>>s=['\u4e2d\u56fd','\u6e05\u534e\u5927\u5b66']>>>str=s[0].d ...
- 采集Snoopy.class.php
<?php /************************************************* Snoopy - the PHP net client Author: Mont ...
- WPF SL 属性生成器
在开发WPF 和SL应用的时候通用会用到MVVM模式,每次写到类属性的时候要不断的写属性更新时通知方法,写多了就嫌烦,就手写了个属性生成工具,在属性更新的时候添加了更新通知方法. 工具中支持自定义类对 ...
- sql server使用sql插入中文字符串乱码问题
在插入语句前加N就行了 sb.Append(string.Format("update chapter set [content]=N'{0}' where Id ={1} ;", ...