热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

配置MariaDB+Keepalived双主高可用数据库集群负载均衡

利用keepalived构建高可用MySQL-HA,保证两台MySQL数据的一致性,然后用keepalived实现虚拟VIP,通过keepalived自带的服务监控功能来实现MySQL故障时自动切换。硬件拓扑如下:VIP:192.168.1.200mysql1:192.168.1.201mysql2:192.168.1

利用keepalived构建高可用MySQL-HA,保证两台MySQL数据的一致性,然后用keepalived实现虚拟VIP,通过keepalived自带的服务监控功能来实现MySQL故障时自动切换。

硬件拓扑如下:

VIP:192.168.1.200

mysql1:192.168.1.201

mysql2:192.168.1.202

操作系统:CentOS release 6.3(32位)

MySQL版本:MariaDB 5.5.31 Stable

下载地址(64位请下载64版本):https://downloads.mariadb.org/f/mariadb-5.5.31/kvm-tarbake-jaunty-x86/mariadb-5.5.31.tar.gz/from/http:/mirrors.scie.in/mariadb

Keepalived版本:Version 1.2.7

下载地址:http://www.keepalived.org/software/keepalived-1.2.7.tar.gz

一、配置Centos运行环境:

执行:

rpm -qa|grep mysql

rpm -e mysql

yum -y remove mysql-server mysql

yum -y remove php-mysql

移除系统自带的mysql

yum -y install yum-fastestmirror

yum -y update

更新系统软件;

rm -rf /etc/localtime

ln -s /usr/share/zoneinfo/Asia/Shanghai /etc/localtime

yum install -y ntp

ntpdate -d cn.pool.ntp.org

date

设置时区并同步系统时间

#Disable SeLinux

if [ -s /etc/selinux/config ]; then

sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config

fi

ldconfig

关闭安全增强

cat >>/etc/security/limits.conf<

* soft nproc 65535

* hard nproc 65535

* soft nofile 65535

* hard nofile 65535

eof

cat >>/etc/sysctl.conf<

fs.file-max=65535

eof

修改文件句柄的最大数量

安装一些必备软件

yum -y install gcc gcc-c++ gcc-g77 ncurses-devel bison libaio-devel cmake libnl* libpopt* popt-static openssl-devel

二、安装maridDB:

1、下载相关软件源码包

[root@localhost down]# wget https://downloads.mariadb.org/f/mariadb-5.5.31/kvm-tarbake-jaunty-x86/mariadb-5.5.31.tar.gz/from/http:/mirrors.scie.in/mariadb

2、配置编译器,提高性能

CFLAGS="-O3"

CXX=gcc

CXXFLAGS="-O3 -felide-constructors -fno-exceptions -fno-rtti"

3、开始安装mariadb

添加mysql用户和用户组

[root@localhost down]# groupadd mysql

[root@localhost down]# useradd -s /sbin/nologin -M -g mysql mysql

解压mariadb

[root@localhost down]# tar -zxvf mariadb-5.5.31

[root@localhost down]# cd mariadb-5.5.31

安装到/usr/local/mariamysql目录:

[root@localhost down]# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mariamysql -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_FEDERATED_STORAGE_ENGINE=1  -DENABLED_LOCAL_INFILE=1 -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci   -DWITH_DEBUG=0 -DBUILD_COnFIG=mysql_release -DFEATURE_SET=community -DWITH_EMBEDDED_SERVER=OFF && make && make install

复制配置文件到/etc/my.cnf

[root@localhost down]# cp /usr/local/mariamysql/support-files/my-huge.cnf /etc/my.cnf

设置mariamysql为系统服务

[root@localhost down]# cp /usr/local/mariamysql/support-files/mysql.server /etc/init.d/mariamysql

初始化mariaDB数据库:

[root@localhost down]# /usr/local/mariamysql/scripts/mysql_install_db --basedir=/usr/local/mariamysql/ --datadir=/usr/local/mariamysql/data/ --user=mysql

至此mariaDB安装完成。

三、keepalived安装:

 

1、下载源码包:

wget http://www.keepalived.org/software/keepalived-1.2.7.tar.gz

 

2、安装:

[root@localhost down]# tar -zxvf keepalived-1.2.7.tar.gz

[root@localhost down]# cd keepalived-1.2.7

 

[root@localhost keepalived-1.2.7]#  ./configure --prefix=/usr/local/keepalived

安装到/usr/local/keepalived目录下;

至此keepalived安装完毕。

四、分别在201和202两台机器上都重复二,三安装好mariaDB和keepalived。

五、配置201数据库服务器:

1、设置mariaDB数据库配置文件:

[root@localhost /]# vi /etc/my.cnf 

确保/etc/my.cnf中有如下参数,没有的话需手工添加,并重启mysql服务。

[mysqld]
log-bin=mysql-bin 

#启动二进制文件
server-id=1 

#服务器ID

设置完毕启动mariaDB服务器

[root@localhost /]# service mariamysql start

2、登录mysql,然后在增加一个账号专门用于同步,如下:

[root@localhost /]# /usr/local/mariamysql/bin/mysql -uroot -p  #初始密码为空到Enter password:处直接回车即可

MariaDB [(none)]> grant replication slave on *.* to 'backup'@'192.168.1.202' identified by 'backup'; flush privileges;

显示master状态:

MariaDB [(none)]> show master status;

记录下File和Position然后在202上面设置从201同步。

六、配置202数据库服务器:

[root@localhost /]# vi /etc/my.cnf 

确保/etc/my.cnf中有如下参数,没有的话需手工添加,并重启mysql服务。

[mysqld]
log-bin=mysql-bin 

#启动二进制文件
server-id=10(此处要设置的跟201不同)

#服务器ID

设置完毕启动mariaDB服务器。

[root@localhost /]# service mariamysql start

登录数据库:

[root@localhost /]# /usr/local/mariamysql/bin/mysql -uroot -p 

输入:

MariaDB [(none)]> change master to master_host='192.168.1.201',master_user='backup',master_password='backup',master_log_file='mysql-bin.000010',master_log_pos=245;

注意:245对应上面在201上面记下的Position,mysql-bin.000010对应201上面记录的File

执行成功后,输入命令显示从库状态:

MariaDB [(none)]> show slave status \G;

Slave_IO_Running: Yes            

Slave_SQL_Running: Yes

两项都显示Yes时说明从201同步数据成功。

至此201为主202为从的主从架构数据设置成功!

七、设置201和202互为主从:

 

1、202机器上增加一个帐号专门用于同步数据:

MariaDB [(none)]> grant replication slave on *.* to 'backup'@'192.168.1.201' identified by 'backup'; flush privileges;

2、显示202做为主库时的状态:

MariaDB [(none)]> show master status;

3、在201数据库服务器上:

MariaDB [(none)]> change master to master_host='192.168.1.202',master_user='backup',master_password='backup',master_log_file='mysql-bin.000005',master_log_pos=5005;

注意:5005对应上面在202上面记下的Position,mysql-bin.000005对应202上面记录的File

显示状态:

MariaDB [(none)]> show slave status \G;

Slave_IO_Running: Yes            

Slave_SQL_Running: Yes

两项都显示Yes时说明从202同步数据成功。

至此201、202互为主从设置成功!

可以试试在这两台服务器上任何一台增加一个数据库,并建个表,增加一些数据看看,互为主从同步的状态是否成功!

首先在201上面:

MariaDB [(none)]> create database mysqltest;

MariaDB [(none)]> use mysqltest;

MariaDB [mysqltest]> create table user(id int(5),name char(10));

MariaDB [mysqltest]> insert into user values (00001,'zhangsan');

在202上面验证一下:

MariaDB [(none)]> use mysqltest;

MariaDB [mysqltest]> select * from user;

会发现201上面的数据已经自动同步到202上面了

同样在202上面:

MariaDB [mysqltest]> insert into user values (00002,'wander');

在201上面验证一下:

MariaDB [mysqltest]> select * from user;

互为主从结构设置完毕

注意:如果同步不成功,首先要确保服务器3306端口打开的。

centos可以用service iptables stop关闭防火墙。

八、利用keepalived实现高可用

 

keepalived实现虚拟IP,通过keepalived自带的服务监控功能来实现MySQL故障时自动切换;

1、keepalived设置:

201服务器上面,编辑keeplaived.conf配置文件:

[root@localhost /]# vi /usr/local/keepalived/etc/keepalived/keepalived.conf

配置文件内容如下:

! Configuration File for keepalived

global_defs {
   router_id mysql-ha
}

vrrp_instance VI_1 {
    state BACKUP
    interface eth0
    virtual_router_id 201
    priority 100 #优先级,高优先级竞选为master
    advert_int 1 
    nopreempt #设置为不抢占 注:这个配置只能设置在backup主机上,而且这个主机优先级要比另外一台高,另一台不要设置这个选项
    authentication {
        auth_type PASS
        auth_pass 123456
    }
    virtual_ipaddress {
        192.168.1.200
    }
}

virtual_server 192.168.1.200 3306 {
    delay_loop 2
    lb_algo rr
    lb_kind DR
    persistence_timeout 60
    protocol TCP
    real_server 192.168.1.201 3306 {
        weight 1
        notify_down /usr/local/keepalived/etc/keepalived/mysql.sh
        TCP_CHECK {
connect_port 3306
connect_timeout 3
nb_get_retry 2
delay_before_retry 1
        }
    }
}
~                

          

编辑mysql服务停止后的切换脚本:mysql.sh

[root@localhost /]# vi /usr/local/keepalived/etc/keepalived/mysql.sh

内容如下:

#!/bin/bash
pkill keepalived

2、启动201上面的keepalived

[root@localhost /]# /usr/local/keepalived/sbin/keepalived -f /usr/local/keepalived/etc/keepalived/keepalived.conf -D

查看:

启动成功后会有三个keepalived进程

此是在任一局域机器上面ping 192.168.1.200发现已经可以ping通,并且用192.168.1.200这个IP也能够连接到数据库服务器。

3、在202机器上面重复1、2步骤;

配置keepalived.conf文件的时候注意要把 

real_server 192.168.1.201 3306改为 real_server 192.168.1.202 3306

virtual_router_id 201 改为virtual_router_id 202

priority 100改为priority 90

去掉nopreempt 

至此MariaDB+Keepalived双主高可用配置MySQL-HA设置完毕。

可以试着把201上面的mariaDB停止 

[root@localhost /]# service mariamysql stop;

会发现连接192.168.1.200还是可以连接上去的,keepalived会自动切换到202的服务器上面去。这样,当一台数据库服务器发生故障时,另一台服务器可以立即切换过来,保证高可用。


推荐阅读
  • centos 7.0 lnmp成功安装过程(很乱)
    下载nginx[rootlocalhostsrc]#wgethttp:nginx.orgdownloadnginx-1.7.9.tar.gz--2015-01-2412:55:2 ... [详细]
  • 本文介绍了数据库体系的基础知识,涵盖关系型数据库(如MySQL)和非关系型数据库(如MongoDB)的基本操作及高级功能。通过三个阶段的学习路径——基础、优化和部署,帮助读者全面掌握数据库的使用和管理。 ... [详细]
  • 在使用 PHP 通过 SSL 安全连接到 MySQLi 数据库服务器时,遇到了一些技术难题。我的环境包括一个 Web 服务器和一个数据库服务器,两者均使用 OpenSSL 生成了证书。尽管证书内容一致,但在尝试从 Web 服务器使用 `mysql` 命令进行连接时,仍然遇到了问题。为了确保连接的安全性和稳定性,需要进一步检查证书配置和 PHP 的 SSL 设置,以排除潜在的配置错误或兼容性问题。 ... [详细]
  • 本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ... [详细]
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • 嵌入式开发环境搭建与文件传输指南
    本文详细介绍了如何为嵌入式应用开发搭建必要的软硬件环境,并提供了通过串口和网线两种方式将文件传输到开发板的具体步骤。适合Linux开发初学者参考。 ... [详细]
  • Symfony是一个功能强大的PHP框架,以其依赖注入(DI)特性著称。许多流行的PHP框架如Drupal和Laravel的核心组件都基于Symfony构建。本文将详细介绍Symfony的安装方法及其基本使用。 ... [详细]
  • 本文详细介绍了如何在云服务器上配置Nginx、Tomcat、JDK和MySQL。涵盖从下载、安装到配置的完整步骤,帮助读者快速搭建Java Web开发环境。 ... [详细]
  • 主调|大侠_重温C++ ... [详细]
  • CentOS 7.6环境下Prometheus与Grafana的集成部署指南
    本文旨在提供一套详细的步骤,指导读者如何在CentOS 7.6操作系统上成功安装和配置Prometheus 2.17.1及Grafana 6.7.2-1,实现高效的数据监控与可视化。 ... [详细]
  • 在 Ubuntu 22.04 LTS 上部署 Jira 敏捷项目管理工具
    Jira 敏捷项目管理工具专为软件开发团队设计,旨在以高效、有序的方式管理项目、问题和任务。该工具提供了灵活且可定制的工作流程,能够根据项目需求进行调整。本文将详细介绍如何在 Ubuntu 22.04 LTS 上安装和配置 Jira。 ... [详细]
  • MySQL 8.0 MGR 自动化部署与配置:DBA 和开源工具的高效解决方案
    MySQL 8.0 MGR 自动化部署与配置:DBA 和开源工具的高效解决方案 ... [详细]
  • 如何利用Apache与Nginx高效实现动静态内容分离
    如何利用Apache与Nginx高效实现动静态内容分离 ... [详细]
  • 如何在Linux系统上部署MySQL 5.7.28
    本文详细介绍了在Linux系统上部署MySQL 5.7.28的具体步骤。通过官方下载页面获取最新安装包后,按照提供的指南进行配置和安装。文章内容实用性强,适合初学者和有经验的管理员参考。 ... [详细]
  • 在编译BSP包过程中,遇到了一个与 'gets' 函数相关的编译错误。该问题通常发生在较新的编译环境中,由于 'gets' 函数已被弃用并视为安全漏洞。本文将详细介绍如何通过修改源代码和配置文件来解决这一问题。 ... [详细]
author-avatar
mobiledu2502889415
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有