前言:MySQL是一个开放源码的小型关联式数据库管理系统,开发者为瑞典MySQL AB公司, 目前属于Oracle公司,MySQL被广泛地应用Internet上的中小型网站中。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库

对应目前主流的LAMP架构来说,Mysql更是得到各位IT运维、DBA的青睐,目前mysql已被orcacle收购,不过好消息是原来mysql创始人已独立出来自己重新开发了一个MariaDB,而且使用的人数越来越多。而且MariaDB兼容mysql所有的功能和相关参数。

Mysql常用的两大引擎有MyISAM和innoDB,那他们有什么明显的区别呢,什么场合使用什么引擎呢?

MyISAM类型的表强调的是性能,其执行数度比InnoDB类型更快,但不提供事务支持,如果执行大量的SELECT操作,MyISAM是更好的选择,支持表锁。

InnoDB提供事务支持事务,外部键等高级数据库功能,执行大量的INSERT或UPDATE,出于性能方面的考虑,应该使用InnoDB表,支持行锁。

    随着访问量的不断增加,Mysql数据库压力不断增加,需要对mysql进行优化和架构改造,可以使用高可用、主从复制、读写分离来、拆分库、拆分表进行优化。下面我们来学习MySQL主从复制高可用如何来实现。

  MySQL数据库主从复制原理

Mysql主从同步其实是一个异步复制的过程,要实现复制首先需要在master上开启bin-log日志功能,整个过程需要开启3个线程,分别是Master开启IO线程,slave开启IO线程和SQL线程。

a)   在从服务器执行slave start,从服务器上IO线程会通过授权的用户连接上master,并请求master从指定的文件和位置之后发送bin-log日志内容。

b)   Master服务器接收到来自slave服务器的IO线程的请求后,master服务器上的IO线程根据slave服务器发送的指定bin-log日志之后的内容,然后返回给slave端的IO线程。(返回的信息中除了bin-log日志内容外,还有本次返回日志内容后在master服务器端的新的binlog文件名以及在binlog中的下一个指定更新位置。)

c)   Slave的IO线程接收到信息后,将接收到的日志内容依次添加到Slave端的relay-log文件的最末端,并将读取到的Master端的 bin-log的文件名和位置记录到master-info文件中,以便在下一次读取的时候能够清楚的告诉Master“我需要从某个bin-log的哪个位置开始往后的日志内容,请发给我”;

Slave的Sql线程检测到relay-log中新增加了内容后,会马上解析relay-log的内容成为在Master端真实执行时候的那些可执行的内容,并在自身执行。

   正文,配置详解

 

        MySQL数据库主从配置

环境准备:192.168.33.10为master主服务器,192.168.33.11为slave从服务器。

在主和从服务器都安装mysql相关软件,命令如下:

yum install  -y  mysql mysql-devel mysql-server mysql-libs

安装完毕后,在Master修改vi /etc/my.cnf内容为如下:

[mysqld]  
 
datadir=/data/mysql  
 
socket=/var/lib/mysql/mysql.sock  
 
user=mysql 
 
# Disabling symbolic-links is recommended to prevent assorted security risks  
 
symbolic-links=0 
 
log-bin=mysql-bin  
 
server-id = 1 
 
auto_increment_offset=1    
 
auto_increment_increment=2
 
[mysqld_safe]  
 
log-error=/var/log/mysqld.log  
 
pid-file=/var/run/mysqld/mysqld.pid   
 
replicate-do-db =all


创建/data/mysql数据目录,mkdir –p /data/mysql ;chown –R mysqld:mysqld /data/mysql

启动mysql即可,/etc/init.d/mysqld  restart    

然后修改slave Mysql数据库my.cnf配置文件内容如下:

[mysqld]  
 
datadir=/data/mysql  
 
socket=/var/lib/mysql/mysql.sock  
 
user=mysql 
 
# Disabling symbolic-links is recommended to prevent assorted security risks  
 
symbolic-links=0 
 
log-bin=mysql-bin  
 
server-id = 2 
 
auto_increment_offset=2    
 
auto_increment_increment=2
 
[mysqld_safe]  
 
log-error=/var/log/mysqld.log  
 
pid-file=/var/run/mysqld/mysqld.pid  
 
master-host =192.168.33.10
 
master-user=tongbu 
 
master-pass=123456 
 
master-port =3306 
 
master-connect-retry=60 
 
replicate-do-db =all


 

在Master数据库服务器上设置权限,执行如下命令:

grant  replication  slave  on *.* to  'tongbu'@'%'  identified by  '123456';

在Master 数据库执行如下命令:

mysql> show master status;

+------------------+----------+--------------+------------------+

| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |

+------------------+----------+--------------+------------------+

| mysql-bin.000006 |       98 |              |                  |

+------------------+----------+--------------+------------------+

1 row in set (0.00 sec)

然后在slave服务器指定master IP和同步的pos点:

change master to

master_host='192.168.33.10',master_user='tongbu',master_password='123456',master_log_file='mysql-bin.000006',master_log_pos=98;

在slave启动slave start,并执行show slave status\G查看Mysql主从状态:

Slave_IO_Running: Yes

 Slave_SQL_Running: Yes两个状态为YES,代表slave已经启动两个线程,一个为IO线程,一个为 SQL线程。

    最后测试主从配置成功,,另外,主主配置的方法更简单就是在主从的基础上再从上也进行授权就可以实现主主同步了

    自此Mysql主从搭建完毕,现在有一个问题,如果master服务器down机了,如何快速恢复服务呢?

                                 可以通过两种方法:

第一种方法,如果程序连接的是master的IP,直接在slave服务器上添加master的IP即可。这个手动去操作,而且需要花费时间比较长,可能还会出现误操作的情况,不推荐。

第二种方法,可以使用keepalived、heartbeat作为HA检测软件,检查MySQL服务是否正常,不正常则自动切换到slave上,推荐使用。

                                      故障排查

     (1)修复状况为:Slave_IO_Runningyes, Slave_SQL_RunningNo的情况,且Last_Errno一般为1062, Last_Error含有对应错误号的错误信息

 slave stop;   SET GLOBAL SQL_SLAVE_SKIP_COUNTER = 1;   slave start;     show slave status\G        quit;

(2)修复状况为:Slave_IO_RunningNo, Slave_SQL_RunningNo的情况,且Last_Errno一般为0Last_Error为空

可能是操作人员关闭主从复制后没有开启,应直接执行:

 slave start;若复制仍有问题,请考虑其他修复slave方法

(3)若从机损坏特殊,可以使用

CHANGE MASTER TO MASTER_HOST='117.135.189.14', MASTER_USER='repluser1', MASTER_PASSWORD='repl.ljsy.net', Master_Port=3701, MASTER_LOG_FILE='mysql-bin.000018', MASTER_LOG_POS=5775885;完整语句恢复