memcached高可用群集部署

环境部署

服务器角色 IP地址 需要安装的软件包
主缓存服务器 192.168.142.130 Telnet、libevent、memcached、keepalived、magent
从缓存服务器 192.168.142.131 Telnet、libevent、memcached、keepalived
客户端 192.168.142.132 Telnet

第一步:配置memcached主缓存服务器

#挂载软件包
mount.cifs //192.168.142.1/memcached /mnt
cd /mnt/memcached

#创建目录
mkdir /opt/magent       

#解压安装包
tar zxvf magent-0.5.tar.gz -C /opt/magent/
tar zxvf libevent-2.1.8-stable.tar.gz -C /opt
tar zxvf memcached-1.5.6.tar.gz -C /opt

#安装必要组件
yum install gcc gcc-c++ make -y

#进行编译安装
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

cd /opt/magent/

vim ketama.h
#ifndef SSIZE_MAX
#define SSIZE_MAX 32767
#endif
#第一行末尾添加-lm
vim Makefile
LIBS = -levent-lm

#编译
make

#安装openssh
yum install openssh-clients -y
cp magent /usr/bin

#推送magent文件
scp magent [email protected]:/usr/bin

#关闭防火墙和安全功能
systemctl stop firewalld.service
setenforce 0

#安装keepalived
yum install keepalived -y

#修改配置文件
vim /etc/keepalived/keepalived.conf
! Configuration File for keepalived

#写入下列内容,定义函数
vrrp_script magent {
        script "/opt/shell/magent.sh"
        interval 2
}

#修改route-id
global_defs {
   notification_email {
     [email protected]
     [email protected]
     [email protected]
   }
   notification_email_from [email protected]
   smtp_server 192.168.200.1
   smtp_connect_timeout 30
   router_id MAGENT_HAL
   #修改id名
}

#修改网卡端口
vrrp_instance VI_1 {
    state MASTER
    interface ens33         #修改网卡信息
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    #修改,调用上边函数
    track_script {
        magent
   }
    virtual_ipaddress {
        192.168.142.100     #定义虚拟IP地址
    }
}

mkdir /opt/shell
cd /opt/shell/

#配置从服务器脚本
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.142.100 -p 12000 -s 192.168.45.132:
11211 -b 192.168.142.131:11211
else
pkill -9 magent
fi

chmod +x magent.sh
#启动
systemctl start keepalived.service

#查看迁移地址
ip addr

#启动主服务器
memcached -m 512k -u root -d -l 192.168.142.130 -p 11211

#查看端口是否正常开启
netstat -anptu | grep 11211

第二步:配置memcached从缓存服务器

#挂载软件包
mount.cifs //192.168.142.1/memcached /mnt

#解压安装包
cd /mnt/memcached
tar zxvf libevent-2.1.8-stable.tar.gz -C /opt
tar zxvf memcached-1.5.6.tar.gz -C /opt
yum install gcc gcc-c++ make -y

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

[[email protected] memcached-1.5.6]# cd /etc/keepalived/
[[email protected] keepalived]# mv keepalived.conf keepalived.conf.bk
[[email protected] keepalived]# touch keepalived.conf
[[email protected] keepalived]# vim keepalived.conf

vrrp_script magent {
        script "/opt/shell/magent.sh"
        interval 2
}

global_defs {
   notification_email {
     [email protected]
     [email protected]
     [email protected]
   }
   notification_email_from [email protected]
   smtp_server 192.168.200.1
   smtp_connect_timeout 30
   router_id MAGENT_HB      #id名不可与主服务器相同
}

vrrp_instance VI_1 {
    state BACKUP            #设定从服务器
    interface ens33
    virtual_router_id 52    #id号不可与主服务器相同
    priority 90             #优先级低与主服务器
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    track_script {
        magent
   }
    virtual_ipaddress {
        192.168.142.100     #定义虚拟IP地址
    }
}

mkdir /opt/shell
cd /opt/shell/

#配置从服务器脚本
vim magent.sh
#!/bin/bash
K=`ip addr | grep 192.168.142.100 | grep -v grep | wc -l`
if [ $K -gt 0 ];then
        magent -u root -n 51200 -l 192.168.142.100 -p 12000 -s 192.168.142.130:
11211 -b 192.168.142.131:11211
else
pkill -9 magent
fi
chmod +x magent.sh

#启动keepalived
systemctl start keepalived.service

#关闭防火墙和安全功能
systemctl stop firewalld.service
setenforce 0

#启动从服务器
memcached -m 512k -u root -d -l 192.168.142.131 -p 11211

#查看端口是否正常开启
netstat -anptu | grep 11211

#安装telent进行测试
yum install telnet -y

第三步:客户端测试

#关闭防火墙和安全功能
systemctl stop firewalld.service
setenforce 0

#安装telent进行测试
yum install telnet -y

#使用漂移地址登录连接
telnet 192.168.142.100 12000

#创建键值对,验证主从同步
add username 0 0 7
1234567

#双机热备
#停掉主服务器
systemctl stop keepalived.service

#使用漂移地址登录连接
telnet 192.168.142.100 12000

谢谢阅读!!!

原文地址:https://blog.51cto.com/14449521/2461646

时间: 2024-11-07 02:23:26

memcached高可用群集部署的相关文章

领会Memcached高可用群集(Memcached主主复制+Keepalived)

10月3号我写了高性能内存缓存对象缓存Memcached原理 (Memcached核心概念,部署),本片将Memcached高可用群集(Memcached主主复制+Keepalived)掌握一下. memcached高可用集群原理及介绍: memcached在实现分布式群集部署时,memcached服务之间是不能进行通讯的,分布式也是通过客户端的算法吧数据保存在不同的memcached中,所以当我们做完群集客户端往一个memcached节点写入数据后,另外两个节点是查询不到的. 那么如何结局额这

Memcached高可用群集

Memcached高可用群集 主服务器安装Memcached.magent.libevent 安装 libevent memcached magent (主服务器) [[email protected] asd] cd /opt/libevent-2.1.8-stable [[email protected] libevent-2.1.8-stable] ./configure --prefix=/usr/ [[email protected] asd] cd /opt/memcached-1.

Haproxy实现大并发web高可用群集部署

Haproxy web群集部署 HAProxy提供高可用性.负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费.快速并且可靠的一种解决方案.HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要会话保持或七层处理,HAProxy实现了一种 单一进程模型,此模型支持非常大的并发连接数多进程或多线程模型受内存限制 .系统调度器限制以及无处不在的锁限制,很少能处理数千并发连接. 部署环境: 主机 IP地址 主机名 软件 操作系统 Haproxy服务器 192.168.1.

Memcached高可用群集(Memcached主主复制+Keepalived)

案例说明 为解决memcached单点故障,需要实现memcached缓存的高可用.首先,需要实现Memcached的主主复制,指任意一台memcached服务器修改数据都会被同步到另外一台,但是memcached API无法判断连接哪一台服务器,因此需要VIP.其次,通过Keepalived产生的VIP连接memcached服务器,提供高可用架构. 案例拓扑 案例环境 主机 IP地址 操作系统 主要软件 Memcached 1 192.168.37.128 Centos7 libevent:m

LVS + Keepalived 高可用群集部署

简介:keepalived是专门针对LVS设计的一款强大的辅助工具,主要用来提供故障切换(Failover)和健康检查(Health Checking)功能--判断LVS负载调度器.节点服务器的可用性,及时隔离并替换为新的服务器,当故障主机修复后将其重新加入群集.Keepalived采用VRRP(Virtual Router Redundancy Protocl,虚拟路由冗余协议)热备份协议,以软件的方式实现Linux服务器的多机热备功能. 实验拓扑: 实验环境: 序号 名称 类型 IP地址 1

Memcached+magent实现主从同步 +keepalived高可用群集

Memcached+magent实现主从同步 +keepalived高可用群集 简介 Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度.Memcached基于一个存储键/值对的hashmap.其守护进程(daemon )是用C写的,但是客户端可以用任何语言来编写,并通过memcached协议与守护进程通信. 实验部署 主机名称 IP地址 主要服务软件 memcach

Centos7 下实现 memcached + keepalived 高可用群集

memcached + keepalived 高可用群集 memcached介绍 Memcached是一套开源的高性能分布式内存对象缓存系统,它将所有的数据都存储在内存中,因为在内存中会统一维护一张巨大的Hash表,所以支持任意存储类型的数据.很多网站通过使用 Memcached提高网站的访问速度,尤其是对于大型的需要频繁访问数据的网站.Memcached是典型的C/S架构,因此需要安装 Memcached服务端与 MemcachedAPI客户端. Memcached服务端是用C语言编写的,而

MHA高可用群集基本部署(纯实战)

MHA高可用群集基本部署 MHA概述 MHA目前在MySQL高可用方面是一个相对成熟的解决方案,它由日本DeNA公司youshimaton(现就职于Facebook公司)开发. MySQL高可用性环境下故障切换和主从提升的高可用软件.在MySQL故障切换过程中,MHA能做到在0~30秒之内自动完成数据库的故障切换操作,并且在进行故障切换的过程中,MHA能在最大程度上保证数据的一致性,以达到真正意义上的高可用. MHA还提供在线主库切换的功能,能够安全地切换当前运行的主库到一个新的主库中(通过将从

Windows2012R2 Hyper-v3.0 高可用群集安装及配置(Live Migration)

Windows2012R2 高可用群集安装及配置(Live Migration) 近期闲着没事做了一些高可用相关的实验分享给大家,上一篇我们介绍了SQL Server2014的高可用,今天主要介绍一下windows server2012下Hyper-v3.0的高可用安装及配置:对于当下很多启用都会应用到虚拟机,所谓的虚拟化就是讲物理机转换为虚拟机.将物理机的应用服务运行到虚拟机下,当然虚拟化还是相对比较方便的,不管是从管理及应用上,都是占用相对的优势的,同样现在企业中的应用服务也要求比较严格,要