Memcached + Magent + keepalived高可用集群
admin
2023-03-27 18:41:34
0

一、前言

magent是一款开源的代理服务软件,我们可以通过它来实现缓存数据的同步,当然这里说的同步不是说memcached之间就能互相通讯了, 而magent可以同时连接多个memcached节点, 通过magent绑定的VIP从客户端登录memcached写入数据,其他节点的memcached数据也会同步。

二、架构部署

环境说明:
Memcached + Magent + keepalived高可用集群
1、配置 memcache 主缓存节点和从缓存节点(两台服务器配置相同)

yum install gcc gcc-c++ make -y
1、tar zxvf memcached-1.5.6.tar.gz -C /opt/

2、tar zxvf libevent-2.1.8-stable.tar.gz -C /opt/

3、mkdir /opt/magent
tar zxvf magent-0.5.tar.gz -C /opt/magent/

2、编译安装

cd    /opt/libevent-2.1.8-stable
./configure  --prefix=/usr/
make && make install

cd    /opt/memcached-1.5.6
./configure \
--with-libevent=/usr
make && make install

3、创建软连接

ln   -s  /usr/lib/libevent-2.1.so.6   /usr/lib64/libevent-2.1.so.6

4、部署主服务器 ----- 安装 magent代理,从服务器不需要
cd /opt/magent

vim ketama.h
在开头处增减以下代码:
#ifndef SSIZE_MAX
#define SSIZE_MAX 32767
#endif

Memcached + Magent + keepalived高可用集群

vim Makefile
LIBS = -levent -lm   //加上 -lm

Memcached + Magent + keepalived高可用集群
5、修改完成后 make 编译
6、此时,make完成后,就会产生 magent可执行程序
Memcached + Magent + keepalived高可用集群
7、将这个 magent 程序复制到path环境变量中

cp magent /usr/bin/

8、可以将安装好的 magent 复制到从服务器,这样从服务器就不需要再配置了

yum install openssh-clients -y   //安装工具包
scp magent root@192.168.220.135:/usr/bin/

9、在主从服务器上都安装 keepalived,并部署
(1)主服务器

yum install keepalived -y    //安装keepalived

修改配置文件:

vim /etc/keepalived/keepalived.conf

//定义一个函数,建议写在最前面
vrrp_script magent {
        script "/opt/shell/magent.sh"
        interval 2
      }

做如下修改:
router_id MAGENT_HA        //修改id名
interface ens33            //修改网卡信息

virtual_ipaddress {
        192.168.220.100     //定义好虚拟ip地址
    }   

vrrp_instance VI_1 {
.....
//调用函数.以下三行代码写在vrrp模块内
track_script {
        magent
      }
.....
}

(2)从服务器

vim /etc/keepalived/keepalived.conf

做如下修改:
router_id MAGENT_HB         //id名和第一台要不一样
state BACKUP               //从服务器
virtual_router_id 52       //id号和第一台不一样
priority 90                 //优先级低与主服务器

10、配置主、从服务器脚本
(1)创建一个脚本

mkdir   /opt/shell

(2)编写

vim magent.sh

#!/bin/bash
K=`ps -ef | grep keepalived | grep -v grep | wc -l`
if [ $K -gt 0 ]; then
    magent -u root -n 51200 -l 192.168.220.100 -p 12000 -s 192.168.220.137:11211 -b 192.168.220.135:11211
else
pkill -9 magent
fi

//
-n 51200             //定义用户最大连接数
-l 192.168.220.100   //指定虚拟IP
-p 12000             //指定端口号
-s                   //指定主缓存服务器
-b                   //指定从缓存服务器

(3)给脚本添加一个执行权限

chmod +x magent.sh
systemctl stop firewalld.service   //必须关闭否则magent不启动
setenforce 0

(4)开启 keepalived 服务

systemctl start keepalived.service

netstat -anpt | grep 12000 //确认magent运行,端口正常运行

Memcached + Magent + keepalived高可用集群
(5)验证主从 :
1、主服务器 ----- 查看 /var/log/messages 文件,找到关键词:Transition to MASTER STATE
Memcached + Magent + keepalived高可用集群
2、从服务器 ----- 找到关键词:Entering BACKUP STATE
Memcached + Magent + keepalived高可用集群
(6) ip addr 命令 ----- 确定漂移地址生效
Memcached + Magent + keepalived高可用集群
第五步:启动主 、从服务器
(1)启动主服务器:

memcached -m 512k -u root -d -l 192.168.220.137 -p 11211

(2)启动从服务器:

memcached -m 512k -u root -d -l 192.168.220.135 -p 11211
netstat -anptu | grep 11211

Memcached + Magent + keepalived高可用集群
第六步:客户机测试
先安装 Telnet 工具:

yum install telnet -y

测试:
1、使用漂移地址登录连接:

Memcached + Magent + keepalived高可用集群
2、我们在客户机上操作,写入一个数据,同时观察主、从服务器上是否会同步生成:
Memcached + Magent + keepalived高可用集群
(1)主服务器:
Memcached + Magent + keepalived高可用集群
(2)从服务器:
Memcached + Magent + keepalived高可用集群
3、双机热备:
(1)停掉主服务器:

systemctl stop keepalived.service

(2)客户机依旧可以连接:
Memcached + Magent + keepalived高可用集群

相关内容

热门资讯

天舟十号货运飞船点火发射 今天上午,搭载天舟十号货运飞船的长征七号遥十一运载火箭,在我国文昌航天发射场点火发射。
伊朗知情人士:特朗普不满意反而... 据凤凰卫视报道,特朗普对伊朗提交的回应表示“完全不能接受”。对此,伊朗知情人士回应称,伊朗没有人会为...
环天智慧获国家航天局授牌 成都... 5月9日,从眉山市的环天智慧科技股份有限公司获悉,该企业正式获国家航天局对地观测与数据中心授予“CP...
“我把她推开了”县交警队长被举... “公安干警有禁酒令要求,工作日不允许饮酒,也不能进入经营性娱乐场所。我认为,他违规违纪了。”一名不愿...
古尔曼:苹果macOS 27将... IT之家 5 月 10 日消息,据彭博社记者马克・古尔曼消息,苹果正准备为下一版 macOS 推出“...
一觉醒来,美伊又谈崩了 (一)一觉醒来,又谈崩了。世间外交,我们看到的,从来没有轻易的握手言和,更多是互不退让的底线博弈。最...
伊媒:伊朗已拒绝美国提出的方案 新华社德黑兰5月11日电 据伊朗新闻电视台10日晚报道,伊朗已拒绝美国提出的方案,认为同意该方案将意...
目标2028年发射,美国Sky... 来源:市场资讯 (来源:IT之家) IT之家 5 月 9 日消息,科技媒体 Ars Technica...
英伟达新技术“翻车”? 今年3月,英伟达发布新技术DLSS 5,其主要目标是通过一系列技术提升游戏的视觉保真度,使场景呈现更...
特朗普称伊朗的回复完全不可接受... 伊朗对美国的结束战争方案做出回应,美国总统特朗普5月10日表示十分不满。美媒爆料双方存在的分歧。《华...