博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql 主从配置
阅读量:6845 次
发布时间:2019-06-26

本文共 3517 字,大约阅读时间需要 11 分钟。

教程开始:

一、安装MySQL

说明:在两台MySQL服务器192.168.21.169和192.168.21.168上分别进行如下操作,安装MySQL 5.5.22

二、配置MySQL主服务器(192.168.21.169)

#进入MySQL控制台
mysql -uroot -p
#建立数据库osyunweidb
create database osyunweidb;
#创建用户osyunweiuser
insert into mysql.user(Host,User,Password) values('localhost','osyunweiuser',password('123456'));

#建立MySQL主从数据库同步用户osyunweidbbak密码123456

#刷新系统授权表

flush privileges;

#授权用户osyunweidbbak只能从192.168.21.168这个IP访问主服务器192.168.21.169上面的数据库,并且只具有数据库备份的权限

grant replication slave on *.* to 'osyunweidbbak'@'192.168.21.168' identified by '123456' with grant option;

三、把MySQL主服务器192.168.21.169中的数据库osyunweidb导入到MySQL从服务器192.168.21.168中

1、导出数据库osyunweidb

#在MySQL主服务器进行操作,导出数据库osyunweidb到/home/osyunweidbbak.sql

mysqldump -u root -p osyunweidb > /home/osyunweidbbak.sql 
备注:在导出之前可以先进入MySQL控制台执行下面命令

#数据库只读锁定命令,防止导出数据库的时候有数据写入

flush tables with read lock;
#解除锁定
unlock tables;

2、导入数据库到MySQL从服务器

#进入从服务器MySQL控制台
mysql -u root -p
#创建数据库
create database osyunweidb;
#进入数据库
use osyunweidb
#导入备份文件到数据库
source /home/osyunweidbbak.sql
#测试在从服务器上登录到主服务器
mysql -u osyunweidbbak -h 192.168.21.169 -p

四、配置MySQL主服务器的my.cnf文件

#编辑配置文件,在[mysqld]部分添加下面内容
vi /etc/my.cnf
#设置服务器id,为1表示主服务器,注意:如果原来的配置文件中已经有这一行,就不用再添加了
server-id=1
#启动MySQ二进制日志系统,注意:如果原来的配置文件中已经有这一行,就不用再添加了
log_bin=mysql-bin
#需要同步的数据库名,如果有多个数据库,可重复此参数,每个数据库一行
binlog-do-db=osyunweidb
#不同步mysql系统数据库
binlog-ignore-db=mysql
#重启MySQL
service mysqld restart
#进入mysql控制台
mysql -u root -p

show master status; 查看主服务器,出现以下类似信息

+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000019 | 7131 | osyunweidb | mysql |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
注意:这里记住File的值:mysql-bin.000019和Position的值:7131,后面会用到

五、配置MySQL从服务器的my.cnf文件

#编辑配置文件,在[mysqld]部分添加下面内容
vi /etc/my.cnf
#配置文件中已经有一行server-id=1,修改其值为2,表示为从数据库
server-id=2
#启动MySQ二进制日志系统,注意:如果原来的配置文件中已经有这一行,就不用再添加了
log-bin=mysql-bin
#需要同步的数据库名,如果有多个数据库,可重复此参数,每个数据库一行
replicate-do-db=osyunweidb
#不同步mysql系统数据库
replicate-ignore-db=mysql
#保存退出
:x
#重启MySQL
service mysqld restart

注意:MySQL 5.1.7版本之后,已经不支持把master配置属性写入my.cnf配置文件中了,只需要把同步的数据库和要忽略的数据库写入即可。

#进入MySQL控制台
mysql -u root -p
#停止slave同步进程
slave stop;
#执行同步语句
change master to master_host='192.168.21.169',master_user='osyunweidbbak',master_password='123456',master_log_file='mysql-bin.000019' ,master_log_pos=7131;
#开启slave同步进程
slave start;
#查看slave同步信息,出现以下内容
SHOW SLAVE STATUS;
*************************** 1. row ***************************
  Slave_IO_State: Waiting for master to send event
  Master_Host: 192.168.21.169
  Master_User: osyunweidbbak
  Master_Port: 3306
  Connect_Retry: 60
  Master_Log_File: mysql-bin.000019
  Read_Master_Log_Pos: 7131
  Relay_Log_File: MySQLSlave-relay-bin.000002
  Relay_Log_Pos: 253
  Relay_Master_Log_File: mysql-bin.000019
  Slave_IO_Running: Yes
  Slave_SQL_Running: Yes
  Replicate_Do_DB: osyunweidb
  Replicate_Ignore_DB: mysql
  Replicate_Do_Table:
  Replicate_Ignore_Table:
1 row in set (0.00 sec)

注意查看:

Slave_IO_Running: Yes
Slave_SQL_Running: Yes
以上这两个参数的值为Yes,即说明配置成功!

六、测试MySQL主从服务器双机热备是否成功

1、进入MySQL主服务器
#进入主服务器MySQL控制台
mysql -u root -p
#进入数据库
use osyunweidb
#创建test表
CREATE TABLE test ( id int not null primary key,name char(20) );

2、进入MySQL从服务器

#进入MySQL控制台
mysql -u root -p
#进入数据库
use osyunweidb
#查看osyunweidb表结构,会看到有一个新建的表test,表示数据库同步成功
show tables;

至此,MySQL数据库配置主从服务器实现双机热备实例教程完成

转载于:https://www.cnblogs.com/george-sun/p/4877630.html

你可能感兴趣的文章
Python 黑帽编程 2.2 数值类型
查看>>
Android持续集成:Jenkins+Gradle+360加固+多渠道打包
查看>>
基于CoreGraphics的3D渲染方案
查看>>
基于VUE的服务器端渲染(SSR)
查看>>
『中级篇』Docker compose 部署一个复杂的应用(41)
查看>>
『中级篇』容器的端口映射(28)
查看>>
初识 RabbitMQ
查看>>
华山论剑之浅谈iOS的生产线 工厂模式
查看>>
入门福利——Swift4 完整项目源码,简单但是全面!
查看>>
Flutter布局之标题
查看>>
“互联网+医疗健康”的南坡与北坡
查看>>
完美解决setInterval在浏览器切换时加速的问题
查看>>
Less代码规范
查看>>
Java注解入门
查看>>
js可枚举属性的遍历
查看>>
django2中自定义过滤器
查看>>
element ScrollBar滚动组件源码深入分析
查看>>
PHP开发面试常问问题合集
查看>>
【Android】RxJava的使用(一)基本用法
查看>>
什么是以太坊
查看>>