1.实验目的

mysql服务器作为生产环境中使用最广泛的数据库软件,以其开源性,稳定性而广泛使用,但同时由于数据存储,读写频率高,极易造成数据库出错,从而给企业造成不可挽回的损失,我们除了做好数据库的备份工作外,同时,还应该解决数据库服务器的单点故障问题。

2.搭建环境

两台 mysql 服务器

172.16.1.2     mysql   + keepalived

172.16.1.12   mysql  + keepalived

一台测试机

172.16.1.1

3.环境部署

一台 mysql 服务器 + keepalived

1)对于mysql源码安装或者yum 安装均可,此处不多讲。

2) 主MySQL配置

主MySQL安装时间同步器,yum  -y  install ntp

vim   /etc/ntpd.conf

添加

server 127.127.1.0
fudge 127.127.1.0 startum 8

启动service   ntpd  start

配置mysql目录下的 my.cnf文件

vim my.cnf

[mysqld]
log-slave-updates=true                            #开启从服务器的日志更新
server-id = 11                                          #主服务器的ID ,这个可以随便定,但是与从服务器要不同

log-bin=mysql-bin                                    #开启二进制日志

登录mysql,   mysql   -uroot   -p123456

创建myslave 账号,并授权可以复制

grant   replication slave   on  *.*  to  'myslave'@'172.16.1.12'     identified   by  '123456';

flush   privileges;

显示主服务的状态;

show   master  status;

记住file 及position位置的字符串,在配置从服务时候会用到。

至此,主 mysql 配置完成,重启service mysqld   restart

3)从mysql服务配置

MySQL安装时间同步器,yum  -y  install ntpdate

ntpdate  172.16.1.2      时间同步

配置mysql目录下的 my.cnf文件

在其中添加

[mysqld]

relay-log=relay-log-bin                                     # 传递日志,前缀为 relay-log-bin

relay-log-index=slave-relay-bin.index             # 传递日志的索引文件

log-bin=mysql-bin                                            #开启二进制日志

server-id = 12                                                  #服务器的ID ,这个可以随便定,但是与主服务器要不同

重启服务   service  mysqld restart

登录mysql,   mysql   -uroot   -p123456

change  master  to  master_host ='172.16.1.2',master_user='myslave',master_password='123456',master_log_file='此处为主服务show  master 命令显示的 file',master_log_pos='此处为主服务show  master 命令显示的 pos'';

此处 master_host ='172.16.1.2',为主mysql的ip

start   slave;                       #开启从服务

show slave status\G;         #显示从服务状态

如果

Slave_IO_Running: Yes
Slave_SQL_Running: Yes

两项为yes,则代表启动从服务成功。

如果Slave_IO_Running: No

可能的问题一是主服务和从服务的server-id,不能为重复;二是授权时一定要准确。grant   replication slave   on  *.*  to  'myslave'@'172.16.1.12'     identified   by  '123456';

此处172.16.1.12为从服务器的ip

4)以上两步实现了mysql主从复制,我们要实现主主,也就是两台mysql ,一台既是主,也是从,另一台既是主也是从,所以我们按照上面的配置在两台mysql上做相反的从主配置。

主mysql上,做从配置

配置mysql目录下的 my.cnf文件

在其中添加

[mysqld]

relay-log=relay-log-bin                                     # 传递日志,前缀为 relay-log-bin

relay-log-index=slave-relay-bin.index             # 传递日志的索引文件

log-bin=mysql-bin                                            #开启二进制日志

重启服务   service  mysqld restart

登录mysql,   mysql   -uroot   -p123456

change  master  to  master_host ='172.16.1.12',master_user='myslave',master_password='123456',master_log_file='此处为主服务show  master 命令显示的 file',master_log_pos='此处为主服务show  master 命令显示的 pos'';

此处的master_host ='172.16.1.12'  为从mysql服务器的ip

start   slave;                       #开启从服务

show slave status\G;         #显示从服务状态

如果

Slave_IO_Running: Yes Slave_SQL_Running: Yes

两项为yes,则代表启动从服务成功。

从mysql上,做主配置

配置mysql目录下的 my.cnf文件

vim my.cnf

[mysqld] log-slave-updates=true                            #开启从服务器的日志更新

登录mysql,   mysql   -uroot   -p123456

创建myslave 账号,并授权可以复制

grant   replication slave   on  *.*  to  'myslave'@'172.16.1.12'     identified   by  '123456';

flush   privileges;

显示主服务的状态;

show   master  status;

记住file 及position位置的字符串,在配置从服务时候会用到。

至此,两台MySQL服务器的分别配置了主从,即一台既是主又是从,另一台既是从也是主。

5)mysql主主复制测试

mysql  -uroot  -p123456 任意登录一台mysql服务器,

create  database  test  default  character  set  utf8;

create  table  test;

到另一台MySQL上show   databases;  show   tables;

显示了数据库和数据表都已建好,可以看到已经同步成功

6)配置keepalived,实现高可用

在主mysql服务器配置

yum  -y install  keepalived

cp  /etc/keepalived/keepalived.conf    /etc/keepalived/keepalived.conf.bak

vim  /etc/keepalived.conf

vrrp_instance VI_1 {                                         #实例1
    state MASTER                                             #状态为主
    interface ens33                                            #绑定网卡
    virtual_router_id 11                                      #   id 号,主从一致
    priority 100                                                   #优先级为100
    advert_int 1
    #nopreempt                                                  #非抢占模式
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {                                         #虚拟ip地址
        172.16.1.199
    }
}
virtual_server 172.16.1.199 3306  {                 
     delay_loop 2                                                  #间隔2秒检查真实服务器状态 
     lb_algo wrr                                                     #LVS   arithmetic
     lb_kind DR                                                     #LVS model
     persistence_timeout 60                                  #k
     protocol TCP 
     real_server 172.16.1.2 3306  {                        #真实服务器 ,也就是主mysql服务器
         weight 3 
         #notify_down /usr/local/mysql/bin/mysql.sh  # 可执行脚本路径 
         TCP_CHECK { 
             connect_timeout 10    #timeout
             nb_get_retry 3       #conect times to try to connect
             delay_before_retry 3   #interval of retry
             connect_port 3306    # check mysql port
         }
     } 
}

启动服务,service  keepalived  start

在从mysql服务器上配置

yum  -y install  keepalived

cp  /etc/keepalived/keepalived.conf    /etc/keepalived/keepalived.conf.bak

vim  /etc/keepalived.conf

本处只写与主mysql服务器不同处

#备用服务器上为SLAVE
    state SLAVE
    #绑定vip的网卡为ens33,根据自己服务器网卡
    interface ens33
    virtual_router_id 11                     #与主服务器  id号码一样
    #备用服务器上为90
    priority 90                                   #优先级比主mysql服务器小
}
virtual_server 172.16.1.199 3306 {  
     real_server 172.16.1.12 3306 {               #真实服务器 ,也就是从mysql服务器
}

其他与主mysql服务器上配置文件相同

启动服务,service  keepalived  start

可以在主mysql服务器上看到一个VIP地址,172.16.1.199

4.测试

停止主mysql服务器上的keepalived服务,  service  keepalived  stop

同时查看另一台的从mysql  的ip,ip a

可以看到有一vip ,172.16.1.199

我们在测试机172.16.1.1上登录从mysql ,    mysql   -uroot   -p123456  -P 3306   -h  172.16.1.12

登录成功,我们做一个 插入数据实验

use test;

insert into  test   values();

到两台的数据库下查看,select   *  from  test;

数据同步成功。

启动  主mysql服务器上的keepalived服务,  service  keepalived  start

停止从mysql服务器上的keepalived服务,  service  keepalived  stop

查看另一台的主mysql  的ip,ip a

可以看到有一vip ,172.16.1.199

做同样的操作 insert into  test   values();

到两台的数据库下查看,select   *  from  test;

数据同步成功,从而实现两台mysql数据库服务器的高可用及主主数据同步。

mysql5.6主主复制及keepalived 高可用的更多相关文章

  1. Mysql双主热备+LVS+Keepalived高可用部署实施手册

    MySQL复制能够保证数据的冗余的同时可以做读写分离来分担系统压力,如果是主主复制还可以很好的避免主节点的单点故障.然而MySQL主主复制存在一些问题无法满足我们的实际需要:未提供统一访问入口来实现负 ...

  2. Mysql双主热备+LVS+Keepalived高可用操作记录

    MySQL复制能够保证数据的冗余的同时可以做读写分离来分担系统压力,如果是主主复制还可以很好的避免主节点的单点故障.然而MySQL主主复制存在一些问题无法满足我们的实际需要:未提供统一访问入口来实现负 ...

  3. mysql主主、mysql-proxy读写分离、keepalived高可用完美组合

    配置mysql主主复制 服务器A:172.16.100.9 服务器B:172.16.100.10 首先在服务器A和服务器B上各安装好单机版mysql5.7,安装好后,再继续下面的操作. 在服务器A和服 ...

  4. nginx+keepalived高可用及双主模式

    高可用有2中方式. 1.Nginx+keepalived 主从配置 这种方案,使用一个vip地址,前端使用2台机器,一台做主,一台做备,但同时只有一台机器工作,另一台备份机器在主机器不出现故障的时候, ...

  5. LVS+Keepalived 高可用环境部署记录(主主和主从模式)

    之前的文章介绍了LVS负载均衡-基础知识梳理, 下面记录下LVS+Keepalived高可用环境部署梳理(主主和主从模式)的操作流程: 一.LVS+Keepalived主从热备的高可用环境部署 1)环 ...

  6. Nginx+keepalived(高可用主备模式)

    Nginx+keepalived(高可用主备模式) 环境:centos6.7 准备:两台服务器(虚拟机).两台应用(Tomcat).Nginx.keepalived server1:192.168.2 ...

  7. Nginx+keepalived(高可用双主模式)

    Nginx+keepalived(高可用双主模式) tips:前面已经介绍了nginx+keepalived高可用主从模式,今天补充下高可用的双主模式,均可以作为主机使用 server1:192.16 ...

  8. nginx+keepalived高可用及双主模式【h】

    高可用有2中方式. 1.Nginx+keepalived 主从配置 这种方案,使用一个vip地址,前端使用2台机器,一台做主,一台做备,但同时只有一台机器工作,另一台备份机器在主机器不出现故障的时候, ...

  9. MySQL主主模式+Keepalived高可用

    今天闲来无事,打算搭建一个MySQL的高可用架构,采用的是MySQL的主主结构,再外加Keepalived,对外统一提供虚IP.先来说说背景吧,现在的项目为了高可用性,都是避免单节点的存在的,比如,我 ...

随机推荐

  1. Oracle 通过undo块查看事务信息

    数据库版本:Oracle 11.2.0.3 RAC 实验目的:通过undo块查看Oracle事务信息 实验细节:1 开始一个事务SQL> select * from t1; ID NAME--- ...

  2. TP5.0:引入view视图中公共的模版文件

    1.实例:如后台admin模块,公用一个header.html和footer.hml 2.目录结构: 3.视图页面的使用方式: <!--添加header页面数据-->{include fi ...

  3. x64 分页机制——虚拟地址到物理地址寻址

    原博客:http://www.cnblogs.com/lanrenxinxin/p/4735027.html 详细的理论讲解都在上面 下面说的是通过windbg手动进行寻址,深入理解 x64: 实践: ...

  4. March 24 2017 Week 12 Friday

    Our lives are brief, that is why it's important to search for meaning. 人生短暂,所以才要寻找它的意义. What can we ...

  5. 不同系统里同一Customizing activity的显示差异分析

    比如SAP HANA Live Reporting这个Customizing Activity,在System AG3里不可见,但是在另一个系统QHD里却能使用.比较下列两张图的差异. 一种可能的原因 ...

  6. 百度地图JavaScript开发入门先知

    最近项目紧急开发了一些百度地图的功能,觉得百度地图实数强大!于是今天不忙总结一下,看到不错的文章先转载. 文章出处:https://www.opengps.cn/Blog/View.aspx?id=1 ...

  7. Jmeter入门9 __digest函数 jmeter字符串连接与登录串加密应用

     登录请求中加密串是由多个子串连接,再加密之后传输. 参数连接:${var1}${var2}${var3} 加密函数:__digest    (函数助手里如果没有该函数,请下载最新版本的jmeter5 ...

  8. chpasswd

    功能说明:从标准输入中读取一定格式的用户名.密码来批量更新用户的密码,其格式为 “用户名:密码”. 参数选项:-e 默认格式是明文密码,使用-e参数则需要加密的密码.

  9. 2017.9.12 初入HTML -----学习总结(二)

    接上:..... (4)标记可分为: 4.1单标记:(单标记仅单独使用就可以表达完整的意思) 基本语法:<标记名称/> 例如:<br/>实现换行的功能.<hr/>实 ...

  10. ueditor图片上传,网络连接错误的解决方案

    错误产生的原因是ueditor/net目录中的Uploader.cs在网站发布之后就没有了,重新上传这个文件,问题就解决了