1、master上开启binlog日志,配置如下

一般mysql配置文件在目录/etc下,叫my.cnf (如果找不到的话也有可能在这些目录下:/etc/my.cnf,/etc/mysql/my.cnf,/usr/local/mysql/etc/my.cnf,~/.my.cnf)

[mysqld]

basedir=/usr/local/mysql

datadir=/data/mysqldata

socket=/tmp/mysql.sock

user=mysql

server-id=1

port=3306

server-id=1 #服务器id (主从必须不一样)

log-bin=mysql-bin #打开日志(主机需要打开),这个mysql-bin也可以自定义,这里也可以加上路径

#作为主机的配置

binlog-do-db=employees #要给从机同步的库

#binlog-do-db=

binlog-ignore-db=mysql #不给从机同步的库(多个写多行)

binlog-ignore-db=information_schema

binlog-ignore-db=performance_schema

binlog-ignore-db=sys

expire_logs_days=7 #自动清理 7 天前的log文件,可根据需要修改

[root@001 employees_db]# service mysqld restart #重启数据库

测试log_bin是否成功开启

mysql> show variables like '%log_bin%';

2、master的数据库中建立备份账号:backup为用户名,%表示任何远程地址,如下表示密码为1234的任何远程地址的backup都可以连接master主机

mysql> grant replication slave on *.* to 'backup'@'%' identified by '123456';

mysql> use mysql

mysql> select user,authentication_string,host from user;

3、拷贝数据

重启MySQL服务并设置读取锁定,读取锁定的意思是只能读取,不能更新,以便获得一个一致性的快照

mysql> show master status\G #

查看主服务器上当前的二进制日志名和偏移量值这里的file 和position 要和从上的一致

导出master(192.168.1.222)种的数据,然后导入slave 中

master:

[root@001 employees_db]# mysqldump -uroot -p123456 -hlocalhost employees > /opt/employees.bak

[root@001 employees_db]# yum install openssh-clients -y #(注:slave也需要安装)

slave:

[root@001 employees_db]# yum install openssh-clients -y

[root@001 ~]# scp /opt/employees.bak root@192.168.1.233:/opt/

root@192.168.1.233's password: #输入密码

employees.bak 100%

4、配置slave(192.168.1.233)

[root@002 ~]# vim /etc/my.cnf

[mysqld]

basedir=/usr/local/mysql #mysql路径

datadir=/data/mysqldata #mysql数据目录

socket=/tmp/mysql.sock

user=mysql

server_id=2 #MySQLid 后面2个从服务器需设置不同

port=3306

#加上以下参数可以避免更新不及时,SLAVE 重启后导致的主从复制出错。

read_only = 1

master_info_repository=TABLE

relay_log_info_repository=TABLE

#relay_log_recovery=1 #从机禁止写

#super_read_only=1 #从机禁止写

然后导入到mysql数据库中,slave上的employees数据库不存在则先创建,然后再导入

mysql> create database employees;

[root@002 ~]# mysql -uroot -p123456 -hlocalhost employees < /opt/employees.bak

[root@002 ~]# service mysqld restart

登录slave数据库,并做如下设置

[root@002 ~]# mysql -uroot -p123456

mysql> stop slave;

mysql> change master to

-> master_host='192.168.1.222', #master的ip

-> master_user='backup', #备份用户名

-> master_password='123456', #密码

-> master_log_file='mysql-bin.000002', #上面截图,且要与master的参数一致

-> master_log_pos=154; #上面截图,且要与master的参数一致

mysql> start slave;

查看slave从机的状态

mysql> show slave status \G

图中2个yes 代表设置成功

5、关闭掉主数据库的读取锁定,并测试

mysql> unlock tables;

在marster中创建一个新表再查看slave中是否有数据

master:

mysql> use employees;

mysql> create table test001(id int auto_increment primary key,name varchar(20) not null);

mysql> insert into test001 values(null,'will');

mysql> insert into test001 values(null,'jim');

mysql> insert into test001 values(null,'tom');

slave:

mysql> use employees;

mysql> show tables;

mysql> select * from test001;

测试2:重启关闭从数据库,主删除test001表,然后主从数据库都重启看是否正常

mysql> drop table test001;

MySQL 5.7的安装及主从复制(主从同步)的更多相关文章

  1. MySQL 5.7.18的安装及主从复制(主从同步)

    MySQL 5.7.18的安装与主从复制 IP 计算机名 角色 192.168.1.222 001 master 192.168.1.233 002 slave CentOS 6.9安装mysql5. ...

  2. centos 7 SVN安装脚本搭建主从同步灵活切换

    svn 脚本下载 http://opensource.wandisco.com/subversion_installer_1.9.sh 2019-Aug-20 12:20:4810.1Kapplica ...

  3. mysql实现主从复制/主从同步

    业务场景 小公司业务代码存于一个服务器上,而这个服务器有的时候回宕机,导致业务停顿,造成影响.这个时候 就需要做高可用 两个ngix+两个tomcat+两个mysql实现高可用,避免单点问题.中间使用 ...

  4. mysql主从同步+mycat读写分离+.NET程序连接mycat代理

    背景 最近新项目需要用到mysql数据库,并且由于数据量大的原因,故打算采用1主1从(主数据库负责增.删.改操作:从数据库负责查操作)的数据库架构,在实现主从之后还要实现读写分离的代理,在网上搜寻了很 ...

  5. mycat数据库集群系列之mysql主从同步设置

    最近在梳理数据库集群的相关操作,现在花点时间整理一下关于mysql数据库集群的操作总结,恰好你又在看这一块,供一份参考.本次系列终结大概包括以下内容:多数据库安装.mycat部署安装.数据库之读写分离 ...

  6. [svc]打通mysql主从同步

    MySQL数据库设置主从同步 主从同步的特点: 逻辑的 异步的 主从同步的作用 1.备份 2.读写分离 主从同步的步骤 准备环境 1, mysql版本一致 5.5以上 2, 主从数据库一致 主库mas ...

  7. MySQL Replication 详解MySQL数据库设置主从同步的方法

    MySQL同步的流程大致如下:  1.主服务器(master)将变更事件(更新.删除.表结构改变等等)写入二进制日志(master log). 2.从服务器(slave)的IO线程从主服务器(binl ...

  8. MySQL 主从同步失败,数据表修复

    问题描述: 接到报警称一台 MySQL 从库同步失败.登录服务器查看错误日志信息如下: Last_Error: Error 'Incorrect key file for table './bfcc/ ...

  9. MySQL数据库设置主从同步

    MySQL主从同步的机制: MySQL同步的流程大致如下: 1.主服务器(master)将变更事件(更新.删除.表结构改变等等)写入二进制日志(master log). 2.从服务器(slave)的I ...

随机推荐

  1. 运行程序,解读this指向---case1

    一.分析代码执行结果 var length = 10; function fn() { console.log(this.length); } var obj = { length: 5, metho ...

  2. 10.16 NOIP模拟赛

    目录 2018.10.16 NOIP模拟赛 A 购物shop B 期望exp(DP 期望 按位计算) C 魔法迷宫maze(状压 暴力) 考试代码 C 2018.10.16 NOIP模拟赛 时间:2h ...

  3. If you sleep now,you will have a dream. If you study now,you will achieve your dream.

    If you sleep now,you will have a dream. If you study now,you will achieve your dream. 我开始思考,What's m ...

  4. 15个优秀的开源项目,让你轻松应对Android开发

    一.huabanDemo-android 应用material design版的花瓣网App 项目地址 https://github.com/LiCola/huabanDemo 二.创建视差效果引导页 ...

  5. 使用 IntraWeb (34) - TIWAJAXNotifier

    在异步事件中, 可以通过 TIWAJAXNotifier 发出一个通知(通过其 Notify 方法), 该通知会激发其 OnNotify 事件. 这一般用在: 当一个异步事件完成后, 立即处理随后的事 ...

  6. NDArray自动求导

    NDArray可以很方便的求解导数,比如下面的例子:(代码主要参考自https://zh.gluon.ai/chapter_crashcourse/autograd.html) 用代码实现如下: im ...

  7. Android开源项目SlidingMenu学习(二)

    前一篇SlidingMenu学习(一)文章中了解了导入SlidingMenu到我们项目经常出现的问题,下面我们正式学习. 先看一个效果: 看到两幅图片的差别了吗,左边的一栏时可以滑动的,可以隐藏掉,现 ...

  8. html5调用手机陀螺仪实现方向辨识

    获取移动设备的陀螺仪,需要知道陀螺仪包含什么. 我们可以让document监听deviceorientation 来获取相关的数据,里面包括3个值 alpha.beta和gamma. 这三个值分别代表 ...

  9. 微软BI SSIS 2012 ETL 控件与案例精讲课程学习方式与面试准备详解

    开篇介绍 微软BI SSIS 2012 ETL 控件与案例精讲 (http://www.hellobi.com/course/21) 课程从2014年9月开始准备,到2014年12月在 天善BI学院  ...

  10. puppet应用案例