Memcachedの+ Magent + keepalivedの高可用性クラスタ

I.はじめに

magentは、オープンソースのプロキシサーバーソフトウェアです、我々はmemcachedの間の同期が互いに通信することができるようになります、とmagentはmagentによって結ば同時に接続する複数のmemcachedのノード、できることをここで言っていない、もちろん、それを介してデータの同期をキャッシュすることができます与えられたVIPログデータを書き込むために、クライアントからmemcachedを、他のノードからmemcachedのデータが同期されます。

第二に、展開アーキテクチャ

環境の説明:
Memcachedの+ Magent + keepalivedの高可用性クラスタ
1、一次キャッシュメモリキャッシュのキャッシングノード(二つのサーバの構成と同じ)から配置されたノード

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は、メイクコンパイル編集後
6を、この時間は、メイク完了後、magentは、実行可能プログラム生成する
Memcachedの+ Magent + keepalivedの高可用性クラスタ
magent PATH環境変数に7、プログラムのコピーを

cp magent /usr/bin/

図8は、サーバーからコピーmagentに設置することができるので、サーバを設定する必要はありません。

yum install openssh-clients -y   //安装工具包
scp magent [email protected]:/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は、configureプライマリサーバとセカンダリサーバスクリプト
スクリプトを作成するには、(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ファイル、キーワードが見つかりました:MASTERへの移行STATE
Memcachedの+ Magent + keepalivedの高可用性クラスタ
2は、サーバからキーワードを見つける-----:BACKUPに状態に入ります
Memcachedの+ Magent + keepalivedの高可用性クラスタ
( 6)のaddrコマンドIP -----ドリフトアドレスは効果になります決定
Memcachedの+ Magent + keepalivedの高可用性クラスタ
プライマリサーバとセカンダリサーバを起動します。ステップ5を
(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の高可用性クラスタ
ステップ6:テストクライアント
の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の高可用性クラスタ

おすすめ

転載: blog.51cto.com/14475593/2458634