基于heartbeatV2版本的ha-gui工具对httpd做高可用集群(2)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介:

    书接上文http://wangfeng7399.blog.51cto.com/3518031/1397530,本文对MariaDB和LVS做高可用集群

一、对MariaDB做高可用集群

   1.环境规划

   我们通过192.168.1.231对外提供MariaDB提供服务,两个客户端的ip地址分别为192.168.1.200和192.168.1.201,在192.168.1.204上提供了nfs服务为两台数据库提供共享存储

   2.准备共享目录

1
/data  192.168 . 1.0 / 24 (rw,no_root_squash)

   3.在创建用户使其能够uid相同  

1
2
[root@php ~]# groupadd -r -g  306  mysql
[root@php ~]# useradd -r -g mysql -u  306  mysql

   4.数据库初始化

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
[root@node1 mysql]# groupadd -r -g  306  mysql
[root@node1 mysql]# useradd -r -g mysql -u  306  mysql
[root@node1 ~]# mount -t nfs  192.168 . 1.202 :/data /mydata
[root@node1 ~]# mkdir /mydata/{data,log}
[root@node1 mysql]# chown mysql.mysql /mydata/ -R
[root@node1 ~]# tar xf mariadb- 10.0 . 10 -linux-x86_64.tar.gz -C /usr/local/
[root@node1 ~]# cd /usr/local/
[root@node1 local]# ln -s mariadb- 10.0 . 10 -linux-x86_64 mysql
[root@node1 local]# cd mysql/
[root@node1 mysql]# chown mysql.root * -R
[root@node1 mysql]# cp support-files/my-large.cnf /etc/my.cnf
并修改配置文件
thread_concurrency =  4
datadir=/mydata/data
log-bin=/mydata/logs/mysql-bin
innodb_file_per_table = ON
[root@node1 mysql]# cp support-files/mysql.server /etc/init.d/mysqld
[root@node1 mysql]# chmod +x /etc/init.d/mysqld
初始化数据库
[root@node1 mysql]# scripts/mysql_install_db --user=mysql --datadir=/mydata/data/

    切记:现在就不需要在节点2上初始化数据了,节点2上的配置文件要跟节点1上保持一致

   5.配置权限

1
2
MariaDB[none]> grant all on *.* to  'wangfeng7399' @ '192.168.1.231'  identified by  'wangfeng7399' ;
MariaDB[none]> flush privileges;

   6.配置集群

     添加一个mariadbservice的组,用来存放关于mariadb定义的资源

wKioL1NSX5KBGNHBAAHyrlDNTRs542.jpg

wKiom1NSX7vRYLw7AALiRhhUsB8506.jpg

wKioL1NSX5LA9TpbAAKooKZc2wc965.jpg

wKiom1NSX7yT7u8pAAJcAHraRxM448.jpg

wKioL1NSX5Ohfc53AALor73G_Fk602.jpg

   7测试

   先创建一个数据库

wKiom1NSYCLgIHBFAABTsshLhpo860.jpg

   此处我们将node2节点关掉

wKioL1NSX_nik4kDAAJ0Ye3Zhro668.jpg

   在node1上登陆查看


wKiom1NSYCLCgbshAAMi7hzc0Gg215.jpg

   也可以看到我们创建的数据库

二、对LVS做高可用集群

   1.环境规划

我们通过192.168.1.232对外提供LVS提供服务,两台DS的地址分别为192.168.1.200和192.168.1.201,两个RealServer的ip地址分别为192.168.1.204和192.168.1.202

   2.在RealServer上配置LVS的服务,两台的配置方法相同

1
2
3
4
5
6
7
8
[root@php ~]# echo  1  > /proc/sys/net/ipv4/conf/all/arp_ignore
[root@php ~]# echo  1  > /proc/sys/net/ipv4/conf/eth0/arp_ignore
[root@php ~]# echo  2  > /proc/sys/net/ipv4/conf/eth0/arp_announce
[root@php ~]# echo  2  > /proc/sys/net/ipv4/conf/all/arp_announce
[root@php ~]# ifconfig lo: 0  192.168 . 1.232  netmask  255.255 . 255.255  broadcast  192.168 . 1.232  up
[root@php ~]# route add -host  192.168 . 1.232  lo: 0
启动httpd服务
[root@php ~]# service httpd start

   3.在两台DS上安装基于lvs的rpm包,如果不安装官方给的文档,要自己书写配置文档,有点麻烦,ldirectord还会检测RealServer的健康状态

1
2
3
4
[root@node1 ha]#  yum install -y heartbeat-ldirectord- 2.1 . 4 - 12 .el6.x86_64.rpm
最好是通过yum安装,这样可以解决依赖关系
chkconfig ldirectord off
关闭开机自启动

   4.准备配置文件

1
[root@node1 ha]# cp /usr/share/doc/heartbeat-ldirectord- 2.1 . 4 /ldirectord.cf /etc/ha.d/

   5.修改配置文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
checktimeout= 3   检查超时时间
checkinterval= 1  每个多长时间检测一次心跳
fallback= 127.0 . 0.1 : 80  如果都失败了,会转移到被本机的web服务上
autoreload=yes 配置文件会不会自动装载
logfile= "/var/log/ldirectord.log"  日志文件
#logfile= "local0"  或者使用syslog
#emailalert= "admin@x.y.z"
#emailalertfreq= 3600
#emailalertstatus=all
quiescent=yes 是否使用静默模式
virtual= 192.168 . 1.232 : 80  定义VIP与端口
         real= 192.168 . 1.204 : 80  gate RealServer的ip地址 gate表示DR
         real= 192.168 . 1.202 : 80  gate
         fallback= 127.0 . 0.1 : 80  gate 如果所有的检查失败,使用的页面
         service=http 基于那种方式做监控检查
         request= ".health.html"  监控检查的文件
         receive= "wangfeng7399"  检查的内容
         scheduler=rr 调度算法
         #persistent= 600  定义持久连接时间
         netmask= 255.255 . 255.255  定义子网掩码

       说明:定义时,只能virtual顶个写,其余的都要空一个制表符,要不会出现语法错误    

   6.在各Real Server上添加.health.html内容为wangfeng7399

   7.在DS上准备一个错误页面,内容为“维护时间”,并启动web服务

   8.配置服务

wKioL1NQHmjg0iXfAAIuVJR7SOI180.jpg

wKiom1NQHqPhZumuAALyIEtX1aI068.jpg

wKioL1NQHpbyV50EAALlsQypD5g507.jpg

   9.测试

     通过ipvsadm查看

wKiom1NQHsCRS_gXAAFHrOzGQQc882.jpg

   通过网页查看

wKioL1NQHpbAPFEiAADq0YWuDLo219.jpg

   我们将web1关掉,依次来模拟一台Real Server 坏掉

wKiom1NQHsCj17KEAAESgIP63g4873.jpg

 我们将两台服务器都关掉

wKiom1NQH-7AJGyEAAF1yvTrPVo738.jpg

   通过web查看,为我们在DS上定义的页面

wKioL1NQHpeQRyfBAADk9Pzmy0k216.jpg

   我们启动其中任何一台,在查看

wKioL1NQIDyTL9kvAAEu74dp-IQ922.jpg

wKiom1NQIGXj7kowAADnzRLHB9Q484.jpg

   都不会再看到我们定义的维护页面

   大功告成,由于本人水平有限,可能会有错误,请各位大神批评指正



本文转自wangfeng7399 51CTO博客,原文链接:http://blog.51cto.com/wangfeng7399/1398676,如需转载请自行联系原作者
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
21小时前
|
云安全 人工智能 自然语言处理
|
5天前
|
搜索推荐 编译器 Linux
一个可用于企业开发及通用跨平台的Makefile文件
一款适用于企业级开发的通用跨平台Makefile,支持C/C++混合编译、多目标输出(可执行文件、静态/动态库)、Release/Debug版本管理。配置简洁,仅需修改带`MF_CONFIGURE_`前缀的变量,支持脚本化配置与子Makefile管理,具备完善日志、错误提示和跨平台兼容性,附详细文档与示例,便于学习与集成。
314 116
|
8天前
|
数据采集 人工智能 自然语言处理
Meta SAM3开源:让图像分割,听懂你的话
Meta发布并开源SAM 3,首个支持文本或视觉提示的统一图像视频分割模型,可精准分割“红色条纹伞”等开放词汇概念,覆盖400万独特概念,性能达人类水平75%–80%,推动视觉分割新突破。
556 51
Meta SAM3开源:让图像分割,听懂你的话
|
20天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
5天前
|
人工智能 Java API
Java 正式进入 Agentic AI 时代:Spring AI Alibaba 1.1 发布背后的技术演进
Spring AI Alibaba 1.1 正式发布,提供极简方式构建企业级AI智能体。基于ReactAgent核心,支持多智能体协作、上下文工程与生产级管控,助力开发者快速打造可靠、可扩展的智能应用。
|
4天前
|
弹性计算 人工智能 Cloud Native
阿里云无门槛和有门槛优惠券解析:学生券,满减券,补贴券等优惠券领取与使用介绍
为了回馈用户与助力更多用户节省上云成本,阿里云会经常推出各种优惠券相关的活动,包括无门槛优惠券和有门槛优惠券。本文将详细介绍阿里云无门槛优惠券的领取与使用方式,同时也会概述几种常见的有门槛优惠券,帮助用户更好地利用这些优惠,降低云服务的成本。
264 132
|
8天前
|
机器学习/深度学习 人工智能 自然语言处理
AgentEvolver:让智能体系统学会「自我进化」
AgentEvolver 是一个自进化智能体系统,通过自我任务生成、经验导航与反思归因三大机制,推动AI从“被动执行”迈向“主动学习”。它显著提升强化学习效率,在更少参数下实现更强性能,助力智能体持续自我迭代。开源地址:https://github.com/modelscope/AgentEvolver
396 29
|
14天前
|
安全 Java Android开发
深度解析 Android 崩溃捕获原理及从崩溃到归因的闭环实践
崩溃堆栈全是 a.b.c?Native 错误查不到行号?本文详解 Android 崩溃采集全链路原理,教你如何把“天书”变“说明书”。RUM SDK 已支持一键接入。
709 224