Mysql主从数据库配置

这两天进行项目中经常出现大量的对数据库的读写操作,数据库压力颇大,便想着配置一下mysql的主从数据库,下面与大家分享整个配置步骤已及里面遇到的坑。

Mysql主从实验


首先介绍主从的概念
主 – 主机,负责对数据库的读写操作,数据类型主要是innordb 
从 – 从机,负责对数据库的读操作,数据库类型主要是myisam 
主从复制即是从机拷贝主机的数据,而用户对数据库的读操作只通过从机即可,因为myisam的的强大之处在于读操作,一个主机可以配置多个从机。

 

操作步骤


1.MYSQL主从配置


1.1 部署环境

主(master_mysql): 192.168.1.200     OS:CentOS 7.2
从(slave_mysql):   192.168.1.201      OS:CentOS 7.2


1.2 安装mysql

基本操作。。应该都会

好吧,还是贴一下

yum install mysql-server

要有两个服务器啊啊啊啊,两个都要安装啊啊啊啊……

1.3配置

1.3.1主配置

vim /etc/my.cnf
 ```
 ```
server-id=200  #设置主服务器的ID
innodb_flush_log_at_trx_commit=2  #操作系统崩溃或者系统断电的情况下,上一秒钟所有事务数据才可能丢失
sync_binlog=1  #开启binlog日志同步功能
log-bin=mysql-bin-200  #binlog日志文件名
binlog-do-db=xxxx  # 这个表示只同步某个库 (如果没有此项,表示同步所有的库)

1.3.2 配置完后,重启主库的mysql

service mysqld restart
mysql -uroot -p  ##登录mysql
mysql>grant replication slave on **.** to 'mark'@'192.168.1.201' identified by '123456';   ##授权给从数据库服务器192.168.1.201,用户名mark,密码123456
mysql>show master status ; ##查看主库的状态  
+------------------+----------+--------------+
| File             | Position | Binlog_Do_DB |
+------------------+----------+--------------+
| mysql-bin.000009 |     1805 | fwwb         |
+------------------+----------+--------------+


1.3.3 配置从库服务器

vim /etc/my.cnf

server-id=201
innodb_flush_log_at_trx_commit=2
sync_binlog=1
log-bin=mysql-bin-201

1.3.4 配置完后,重启从库的mysql

service mysqld restart
mysql -uroot -p
mysql> change master to  master_host='192.168.1.200', master_user='mark' ,master_password='123456', master_log_file='mysql-bin-200.000002' ,master_log_pos=1167;
mysql> start slave;  ##开启从库   (stop slave:关闭从库)
mysql> show slave status; ###Slave_IO_Running,Slave_SQL_Running 都为Yes的时候表示配置成功

1.4:验证主从 
可以在主库上的表里修改一个数据,看看从库里对应的地方有没有更新

对于大佬来说,这篇文章到这就没有意义了……

对我这种小白来说,这才是刚开始啊啊啊!!

2.配置中遇到的坑(水平不够导致的错误)

在配置完后,使用

show slave status;

命令查看从数据库状态,果不其然的……报错了;

Slave_IO_Running: No;

2.1 server_ids

仔细看了下错误信息,显示

master and slave have equal MySQL server ids;

字面上看,是serverids相同,改成不同的就好了。但是我在my.cnf里设置的完全就是两个id啊……

然后,百度了一下才发现,原来serverids跟配置文件里的server-id不一样,好吧原来是my.cnf的配置没起作用,然后我才想起来,主从数据库的配置是要写到

【mysqld】

标签下的,好吧,改了配置文件依旧报错。于是使用命令查看server_ids;

mysql> show variables like 'server_id'; 
+---------------+-------+ 
| Variable_name | Value | 
+---------------+-------+ 
| server_id | 1 | 
+---------------+-------+ 
1 row in set (0.00 sec) 

发现两个服务器server_id都是1,于是使用命令

mysql> set global server_id=2; 

将其中一个改成2,就好了。

2.2 日志文件

此时继续报错

Could not find first log file name in binary log index file

Master上查看binlog的信息:

mysql> show variables like 'log_bin%';
+---------------------------------+---------------------------------+
| Variable_name             | Value                  |
+---------------------------------+---------------------------------+
| log_bin                 | ON                    |
| log_bin_basename           | /data/logs/mysql-bin        |
| log_bin_index             | /data/logs/mysql-bin.index    |
| log_bin_trust_function_creators | ON                    |
| log_bin_use_v1_row_events     | OFF                   |
+---------------------------------+---------------------------------+


mysql>system more /data/logs/mysql-bin.index 
/data/logs/mysql-bin.000008

对比发现从数据库读的是mysql-bin.000001,于是使用命令

CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000008',MASTER_LOG_POS=0;

此处注意master_log_pos可设置为0,这样mysql会自动匹配

然后重新启动主从数据库

再次查看从库状态

Slave_IO_State: Waiting for master to send event
Slave_IO_Running: Yes
Slave_SQL_Running: Yes

此时slave_io_running和slave_sql_running 都是yes,在主数据库更新一条数据,从库同步更新完成,至此完成整个主从数据库配置过程。

需要注意的是有些操作需要先关闭主从同步,文中并未明确指出,读者操作时需依据自身情况调整命令的使用。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值