首先要明白为什么要用 mysql 的主从复制:

1–在从服务器可以执行查询工作 (即我们常说的读功能),降低主服务器压力;(主库写,从库读,降压)

2–在从主服务器进行备份,避免备份期间影响主服务器服务;(确保数据安全)

3–当主服务器出现问题时,可以切换到从服务器。(提升性能)

来说一下主从复制的实现原理

mysql 复制过程分为三步(如上图所示):

1.mster 将改变记录到二进制日志 (binary log) 当中 这些记录过程叫做二进制日志事件 binary log events;

2.slave 将 master 的 binary log events 拷贝到它的中继日志 (relay log) 当中;

3.slave 重做中继日志中的事件 将改变应用到自己的数据库当中 mysql 复制是异步的且串行化的 3.slave 重做中继日志中的事件 将改变应用到自己的数据库当中 mysql 复制是异步的且串行化的

复制的最大问题:

从主机复制数据达到从机可能会有延时!

都说 master 主机和 slave 从机的 mysql 版本号要一致 我就没一致

master 主机上是 5.6 slave 从机上是 5.7 一样搞

拿过来一台服务器你不得先找 mysql 吗?mysql 在哪里 配置文件在哪里?

执行命令:

which mysql

/usr/bin/mysql --verbose --help | grep -A 1 'Default options'

结果如图所示:

先去找 /etc/my.cnf 再去找 /etc/mysql/my.cnf 然后就是后边

我的是在 /etc/my.cnf

修改 my.cnf 配置文件如下:

重启 mysql 服务器执行命令:

service mysqld restart;

解释:

server-id=1 // 复制组中的每台服务器都要配置唯一的 Server ID,取值范围是 1 到 (232)−1,你自己决定取值

log-bin=master-bin // 日志文件名以 “master-bin” 作为前缀

binlog-do-db=finance_online // 要同步的 finance_online 数据库

如要同步多个数据库,就多加几个 replicate-db-db = 数据库名

binlog-ignore-db=mysql // 要忽略的数据库

read-only // 主机 读写都可以 (必须)

登录上 mysql 然后执行:

show master status;

结果如下:

记住里面的 File 和 Position 的值 待会会用到!

在主数据中创建一个同步账号(可不创建使用现有的),如果仅仅为了主从复制创建账号,只需要授予 REPLICATION SLAVE 权限

创建一个账号,账号:zcfz 密码: 123456

这个账号是专门用来搞主从复制用的哈

上述 主服务器配置完成

slave 从服务器配置开始:

重启 mysql 服务器:

service mysqld restart;

进入到 slave 从机的 mysql 命令行执行命令:

stop slave;

CHANGE MASTER TO MASTER_HOST='10.10.20.120',

MASTER_USER='zcfz',

MASTER_PASSWORD='123456',

MASTER_LOG_FILE='master-bin.000005',

MASTER_LOG_POS=3878614;

解释:

MASTER_HOST 就是 master 主服务器的 ip

MASTER_USER 就是 master 主服务器里面的专门复制复制的用户 zcfz

MASTER_PASSWORD 就是 zcfz 账户的密码

MASTER_LOG_FILE 就是我们上边让您保存的 file 对应的值

MASTER_LOG_POS 就是我们上边让您保存的 Position 的值

然后执行命令:

show slave status\G

结果如图所示:

wating for master to send evnet 说明已经在待命状态了

另外必须注意的是 slave_io_runing 以及 slave_sql_runing 都同时必须为 yes 才行!!!

截止到此刻说明主从复制的道路打通了!

然后执行命令:

start slave;

验证阶段:

执行命令创建数据库:

CREATE DATABASE finance_online DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

这个时候 master 和 slave 上都有了数据库

然后你再导入数据到 master 主机上的 finance_online 那么 slave 从机上也就有了然后你再导入数据到 master 主机上的 finance_online 那么 slave 从机上也就有了

另外如果你不想复制这个库了 想换一个

那么去修改 master 主机上的 my.cnf 当中的 binlog-do-db=tprbac 然后重启 mysql 服务

然后 show master status 看看 file 和 positon

然后再去 linux 服务器上停止 slave 在 mysql 当中执行 stop slave;

然后再执行:

CHANGE MASTER TO MASTER_HOST=’10.10.20.120’,

MASTER_USER=’zcfz’,

MASTER_PASSWORD=’123456’,

MASTER_LOG_FILE=‘你看到的 file’,

MASTER_LOG_POS = 你看到的 positon;

然后在 start slave;

就完事了!

这样就会主从复制你想要复制的数据库了!!!

mysql 命令行 主从复制_MySQL 的主从复制(高级篇)相关推荐

  1. mysql 命令行访问_Mysql 命令行模式访问操作mysql数据库操作

    使用环境 在cmd模式下输入 mysql --version (查看mysql安装的版本). 完整的命令可以通过mysql --help来获取. 本测试使用的Mysql版本是mysql5, 本测试使用 ...

  2. mysql命令行语句_MySql命令行命令和SQL语句

    一.常用mysql命令行命令 1.启动MYSQL服务 net start mysql 停止MYSQL服务 net stop mysql 2.netstat -na|findstr 3306 查看被监听 ...

  3. mysql命令行安装教程_MySQL命令行教程

    mysql命令行安装教程 1. MySQL简介 在之前的教程中 ,我讨论了有关MySQL服务器的安装以及MySQL数据库使用入门的问题. 在本文中,我们将详细讨论如何使用MySQL命令行执行各种操作, ...

  4. mysql 命令行 结束编辑_MySql命令行执行多行命令编辑时非常有用的命令

    在MySql命令行下进行多行命令编辑是很正常的一个操作,但有的时候,我们在执行多行命令编辑的时候,难免会有各种失误,一旦到此时,我们往往不得其法,其实了解一下MySql命令行的一些参数和提示的信息将会 ...

  5. mysql客户端指令_mysql command line client(mysql命令行客户端)

    mysql command line client(mysql命令行客户端) (2010-03-24 09:18:38) 标签: 文化 分类: 数据库 1.输入密码:****** 2.ues mysq ...

  6. mysql的调用有哪三种方式_MySQL数据库之mysql命令行中执行sql的几种方式总结

    本文主要向大家介绍了MySQL数据库之mysql命令行中执行sql的几种方式总结 ,通过具体的内容向大家展现,希望对大家学习MySQL数据库有所帮助. 1.直接输入sql执行 MySQL> se ...

  7. mysql命令行批量添加数据_mysql命令行批量插入100条数据命令

    先介绍一个关键字的使用: delimiter 定好结束符为"$$",(定义的时候需要加上一个空格) 然后最后又定义为";", MYSQL的默认结束符为" ...

  8. Command mysql 中文,MySQL Command Line[mysql命令行常用命令]_MySQL

    bitsCN.com MySql下载地址:www.mysql.org 第一招.mysql服务的启动和停止 net stop mysql net start mysql 第二招.登陆mysql mysq ...

  9. mysql的命令行常用命令_MySQL Command Line[mysql命令行常用命令]

    MySQL Command Line[mysql命令行常用命令] (2012-04-25 16:51:59) 标签: it 第一招.mysql服务的启动和停止 net stop mysql net s ...

最新文章

  1. 番外:Spring MVC环境搭建和Mybatis配置避坑篇
  2. python中gil锁和线程锁_Python线程——GIL锁、线程锁(互斥锁)、递归锁(RLock)...
  3. 树的高度从零还是一开始数_数据结构与算法之1——树与二叉树
  4. 采集文件到kafka
  5. TFS自定义开发中的反射应用
  6. 单片机如何使用振动传感器801s_振动传感器如何跟踪测量机器的健康状况
  7. 8.5-Day1T1--Asm.Def 谈笑风生
  8. Chrome即将封杀Google Earth、Google Talk等插件
  9. mysql InnoDB引擎支持hash索引吗
  10. 为类型库(Type Library)生成帮助文件
  11. 鸿蒙系统能玩魔兽世界吗,苹果M1可以玩魔兽世界吗 M1芯片能玩魔兽吗
  12. Conda虚拟环境更新pip方法
  13. 计算机主板不认硬盘怎么回事,主板sata接口不认硬盘怎么办
  14. 在线全网音乐搭建源码_支持下载
  15. CMOS模拟集成电路设计 吴金 学习记录1
  16. 华为鸿蒙操作a股,来了!华为“鸿蒙” 这一次它会给A股带来哪些惊喜
  17. “Hacker_R_US”因炸弹威胁和DDoS勒索被判8年监禁
  18. 今日收获 2018/4/22
  19. 最先提出计算机程序存储原理概念的是( ),计算机考试选择题
  20. buff系统 游戏中_请问BUFF状态

热门文章

  1. python3 字符串方法
  2. nyoj--79--导弹拦截(动态规划)
  3. css定位:相对定位
  4. 项目开发--高级功能汇总
  5. 一道算法题跟大家分享
  6. C# 淘宝商品微信返利助手开发-(六)返利助手开发(4)如何通过淘口令解析的出来的地址获得返利信息
  7. linux java 进程jvm 挂起,【jvm】jconsole远程linux上的java进程
  8. 超级好用 将html字符串,转化为纯文本
  9. sqlserver获得到当前游标中存在的数据行数
  10. beetl 时间输出格式化