`
1028826685
  • 浏览: 942515 次
  • 性别: Icon_minigender_1
  • 来自: 重庆
社区版块
存档分类

Codis集群部署架构

阅读更多

Codis安装部署全架构

 

 

 

前期规划

 

机器与应用列表:

操作系统:CentOS6.5

 

1,操作系统:CentOS6.5

192.168.88.106    codis-server1

192.168.88.107    codis-server2

192.168.88.108    codis-server3

192.168.88.111    codis-ha1

192.168.88.112    codis-ha2

192.168.88.113  zookeeper-1(codis-proxy-1)

192.168.88.114  zookeeper-2(codis-proxy-2)

192.168.88.115  zookeeper-3(codis-proxy-3)

2,硬件配置:

ha              mem:8G   cpu:4   disk:100G

zookeeper     mem:16G  cpu:8   disk:300G

codis-server mem:16G  cpu:8   disk:200G

 

3,架构应用

1), HA(192.168.88.111、192.168.88.112、VIP 192.168.88.159)

hostname:codisha-1   apps:keepalived master,haproxy                      prots:19000

hostname:codisha-2 apps:keepalived slave ,haproxy,codis-config        prots:19000,18087

 

2),zookeeper+codis-proxy

hostname:zookeeper-1     apps: zookeeper1, codis_proxy_1          prots:2811,19000

hostname:zookeeper-2     apps: zookeeper2, codis_proxy_2          prots:2811,19000

hostname:zookeeper-3     apps: zookeeper3, codis_proxy_3          prots:2811,19000

 

3),codis-server

codis-server(192.168.88.106、192.168.88.107、192.168.88.108)

hostname: codis-server1    apps: codis_server_master,slave,        ports:6379,6380,6389,6390

hostname: codis-server2    apps: codis_server_master,slave         ports:6379,6380,6389,6390

hostname: codis-server3    apps: codis_server_master,slave         ports:6379,6380,6389,6390

 

 

 

部署安装详细步骤

 

一,安装zookeeper

 

1,配置hosts文件 (所有机器上配置)

vim /etc/hosts

192.168.88.106    codis-server1

192.168.88.107    codis-server2

192.168.88.108    codis-server3

192.168.88.111    codis-ha1

192.168.88.112    codis-ha2

192.168.88.113  zookeeper-1(codis-proxy-1)

192.168.88.114  zookeeper-2(codis-proxy-2)

192.168.88.115  zookeeper-3(codis-proxy-3)

 

 

2,安装java环境

ZooKeeper 要求 JAVA 的环境才能运行,并且需要 JAVA6 以上的版本,可以从 SUN 官网上下载,并对 JAVA 环境变量进行设置。

yum -y install java-1.7.0-openjdk-devel

java -version

java version "1.7.0_75"

OpenJDK Runtime Environment (rhel-2.5.4.0.el6_6-x86_64 u75-b13)

OpenJDK 64-Bit Server VM (build 24.75-b04, mixed mode)

 

 

3,安装zookeeper

wget http://mirrors.cnnic.cn/apache/zookeeper/zookeeper-3.4.6/zookeeper-3.4.6.tar.gz

tar zxvf zookeeper-3.4.6.tar.gz

mv zookeeper-3.4.6 /usr/local/zookeeper

mkdir -p /data/zookeeper/{data,logs}

配置zoo.cfg

vim /usr/local/zookeeper/conf/zoo.cfg 

tickTime=2000

initLimit=5

syncLimit=2

dataDir=/data/zookeeper/data

#dataLogDir=/data/zookeeper/logs

clientPort=2181

server.1=zookeeper-1:2888:3888

server.2=zookeeper-2:2888:3888

server.3=zookeeper-3:2888:3888

上述配置内容说明,可以参考http://zookeeper.apache.org/doc/trunk/zookeeperStarted.html#sc_RunningReplicatedZooKeeper

 

 

4,设置myid

在我们配置的dataDir指定的目录下面,创建一个myid文件,里面内容为一个数字,用来标识当前主机,conf/zoo.cfg文件中配置的server.X中X为什么数字,则myid文件中就输入这个数字

[root@zookeeper-1 ~]# echo 1 > /data/zookeeper/data/myid

[root@zookeeper-2 ~]# echo 2 > /data/zookeeper/data/myid

[root@zookeeper-3 ~]# echo 3 > /data/zookeeper/data/myid

 

 

5,启动zookeeper

启动顺序zookeeper-1>zookeeper-2>zookeeper-3

[root@zookeeper-1 zookeeper]# zkServer.sh start  

JMX enabled by default

Using config: /usr/local/zookeeper/bin/../conf/zoo.cfg

Starting zookeeper ... STARTED

[root@zookeeper-1 zookeeper]# zkServer.sh status

JMX enabled by default

Using config: /usr/local/zookeeper/bin/../conf/zoo.cfg

Mode: leader

可以看到最先开始启动的是leader,其他两个是follower

 

设置开机启动

vim /etc/rc.local

/usr/local/zookeeper/bin/zkServer.sh start

 

设置环境变量

vim /etc/profile

export ZOOKEEPERPATH=/usr/local/zookeeper

export GOROOT=/usr/local/go

export CODISPATH=/usr/local/codis

export PATH=$PATH:$GOROOT/bin:$ZOOKEEPERPATH/bin:$CODISPATH/bin

 

source /etc/profile

 

二,安装codis集群

 

 

1,安装go

设置环境变量

vim /etc/profile

export GOROOT=/usr/local/go

export CODISPATH=/usr/local/codis

export PATH=$PATH:$GOROOT/bin:$CODISPATH/bin

source /etc/profile

下载安装go

cd /usr/local/

 

wget http://golangtc.com/static/go/go1.3.3.linux-amd64.tar.gz

 

tar -zxvf go1.3.3.linux-amd64.tar.gz                                                                             

go version

go version go1.3.3 linux/amd64

 

 

2,安装依赖环境

yum groupinstall "Development Tools"

 

 

3,安装codis

yum install -y git

go get github.com/wandoulabs/codis  #这个需要几分钟下载共30M文件

package github.com/wandoulabs/codis

imports github.com/wandoulabs/codis

imports github.com/wandoulabs/codis: no buildable Go source files in /usr/local/codis/src/github.com/wandoulabs/codis

cd $GOPATH/src/github.com/wandoulabs/codis

[root@localhost codis]# pwd

/usr/local/codis/src/github.com/wandoulabs/codis

#执行编译测试脚本,编译go和reids。 

./bootstrap.sh #这个需要十几分钟共下载50M文件

make gotest

# 将编译好后,把bin目录和一些脚本复制过去/usr/local/codis目录下:

mkdir -p /usr/local/codis/{logs,conf,scripts}

mkdir -p /data/codis_server/{logs,conf,data}

cp -rf bin /usr/local/codis/

cp sample/config.ini /usr/local/codis/conf/

cp sample/redis_conf/6381.conf /data/codis_server/conf/

cp -rf /usr/local/codis/src/github.com/wandoulabs/codis/sample/*.sh /usr/local/codis/scripts/

cp -rf /usr/local/codis/src/github.com/wandoulabs/codis/sample/usage.md /usr/local/codis/scripts/

cp /usr/local/codis/src/github.com/wandoulabs/codis/extern/redis-2.8.13/src/redis-cli /usr/local/codis/bin/redis-cli-2.8.13

cp /usr/local/codis/src/github.com/wandoulabs/codis/extern/redis-2.8.21/src/redis-cli /usr/local/codis/bin/redis-cli-2.8.21

ln -s /usr/local/codis/bin/redis-cli-2.8.21 /usr/local/codis/bin/redis-cli

 

 

4. 配置codis_proxy  ( zookeeper-1、zookeeper-2、zookeeper-3 机器上配置)

 

配置codis_proxy_1 ( zookeeper-1 机器上配置)

cd /usr/local/codis/conf

vim config.ini 

zk=zookeeper-1:2181,zookeeper-2:2181,zookeeper-3:2181

product=jerrymin-codis

proxy_id=codis_proxy_1

net_timeout=50

dashboard_addr=192.168.88.112:18087

coordinator=zookeeper

 

配置codis_proxy_2 ( zookeeper-1 机器上配置)

cd /usr/local/codis/conf

vim config.ini 

zk=zookeeper-1:2181,zookeeper-2:2181,zookeeper-3:2181

product=jerrymin-codis

proxy_id=codis_proxy_2

net_timeout=50

dashboard_addr=192.168.88.112:18087

coordinator=zookeeper

 

配置codis_proxy_3 ( zookeeper-1 机器上配置)

cd /usr/local/codis/conf

vim config.ini 

zk=zookeeper-1:2181,zookeeper-2:2181,zookeeper-3:2181

product=jerrymin-codis

proxy_id=codis_proxy_3

net_timeout=50

dashboard_addr=192.168.88.112:18087

coordinator=zookeeper

 

 

5. 修改配置文件,启动codis-server服务(codis-server1、codis-server2、codis-server3 机器上配置)

cd /data/codis_server/conf/

grep -Ev "^#|^$" 6379.conf.bak >6379.conf

vim 6379.conf

修改如下参数: (生产环境,参数适当进行调整)

daemonize yes

timeout 300

pidfile /var/run/redis_6379.pid

port 6379

logfile "/data/codis_server/logs/codis_6379.log"

save 900 1

save 300 10

save 60 10000

dbfilename 6379.rdb

dir /data/codis_server/data

appendfilename "6379_appendonly.aof"

appendfsync everysec

 

具体配置文件如下:

daemonize yes

pidfile /var/run/redis_6379.pid

port 6379

tcp-backlog 511

timeout 300

tcp-keepalive 0

loglevel notice

logfile "/data/codis_server/logs/redis_6379.log"

databases 16

stop-writes-on-bgsave-error yes

rdbcompression yes

rdbchecksum yes

dbfilename 6379.rdb

dir /data/codis_server/data

slave-serve-stale-data yes

slave-read-only yes

repl-disable-tcp-nodelay no

slave-priority 100

maxclients 10000

maxmemory 3gb

maxmemory-policy allkeys-lru

appendonly no

appendfilename "6379_appendonly.aof"

appendfsync everysec

no-appendfsync-on-rewrite no

auto-aof-rewrite-percentage 100

auto-aof-rewrite-min-size 64mb

lua-time-limit 5000

slowlog-log-slower-than 10000

slowlog-max-len 128

latency-monitor-threshold 0

notify-keyspace-events ""

hash-max-ziplist-entries 512

hash-max-ziplist-value 64

list-max-ziplist-entries 512

list-max-ziplist-value 64

set-max-intset-entries 512

zset-max-ziplist-entries 128

zset-max-ziplist-value 64

hll-sparse-max-bytes 3000

activerehashing yes

client-output-buffer-limit normal 0 0 0

client-output-buffer-limit slave 256mb 64mb 60

client-output-buffer-limit pubsub 32mb 8mb 60

hz 10

aof-rewrite-incremental-fsync yes

 

 

 

复制6380、6389、6390配置文件

cp 6379.conf 6380.conf

cp 6379.conf 6389.conf

cp 6379.conf 6390.conf

sed -i 's/6379/6380/g' 6380.conf

sed -i 's/6379/6389/g' 6380.conf

sed -i 's/6379/6390/g' 6380.conf

 

添加内核参数

echo "vm.overcommit_memory = 1" >>  /etc/sysctl.conf

sysctl -p

内核参数说明如下:                                                                                                                                       

overcommit_memory文件指定了内核针对内存分配的策略,其值可以是0、1、2。                               

0, 表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。 

1, 表示内核允许分配所有的物理内存,而不管当前的内存状态如何。

2, 表示内核允许分配超过所有物理内存和交换空间总和的内存

 

启动codis-server服务

/usr/local/codis/bin/codis-server /data/codis_server/conf/6379.conf 

/usr/local/codis/bin/codis-server /data/codis_server/conf/6380.conf 

/usr/local/codis/bin/codis-server /data/codis_server/conf/6389.conf 

/usr/local/codis/bin/codis-server /data/codis_server/conf/6390.conf 

[root@codis-server1 ~]# /usr/local/codis/bin/codis-server /data/codis_server/conf/6379.conf 

[root@codis-server1 ~]# /usr/local/codis/bin/codis-server /data/codis_server/conf/6380.conf 

[root@codis-server1 ~]# /usr/local/codis/bin/codis-server /data/codis_server/conf/6389.conf 

[root@codis-server1 ~]# /usr/local/codis/bin/codis-server /data/codis_server/conf/6390.conf 

[root@codis-server1 ~]# ps aux |grep codis

root      7473  0.0  0.0 137388  9540 ?        Ssl  09:48   0:00 /usr/local/codis/bin/codis-server *:6379                           

root      7478  0.0  0.0 137388  9524 ?        Ssl  09:48   0:00 /usr/local/codis/bin/codis-server *:6380                           

root      7482  0.0  0.0 137388  9516 ?        Ssl  09:48   0:00 /usr/local/codis/bin/codis-server *:6389                           

root      7486  0.0  0.0 137388  9524 ?        Ssl  09:48   0:00 /usr/local/codis/bin/codis-server *:6390                           

root      7490  0.0  0.0 103252   856 pts/0    S+   09:49   0:00 grep --color=auto codis

[root@codis-server1 ~]# netstat -tulpn|grep codis

tcp        0      0 0.0.0.0:6379                0.0.0.0:*                   LISTEN      7473/codis-server * 

tcp        0      0 0.0.0.0:6380                0.0.0.0:*                   LISTEN      7478/codis-server * 

tcp        0      0 0.0.0.0:6389                0.0.0.0:*                   LISTEN      7482/codis-server * 

tcp        0      0 0.0.0.0:6390                0.0.0.0:*                   LISTEN      7486/codis-server * 

tcp        0      0 :::6379                     :::*                        LISTEN      7473/codis-server * 

tcp        0      0 :::6380                     :::*                        LISTEN      7478/codis-server * 

tcp        0      0 :::6389                     :::*                        LISTEN      7482/codis-server * 

tcp        0      0 :::6390                     :::*                        LISTEN      7486/codis-server * 

 

 

 

6. 查看一下启动流程:

cat /usr/local/codis/scripts/usage.md

0. start zookeeper       //启动zookeeper服务

1. change config items in config.ini  //修改codis配置文件

2. ./start_dashboard.sh    //启动 dashboard

3. ./start_redis.sh        //启动redis实例

4. ./add_group.sh          //添加redis组,一个redis组只能有一个master

5. ./initslot.sh          //初始化槽

6. ./start_proxy.sh        //启动proxy

7. ./set_proxy_online.sh    //上线proxy项目

8. open browser to http://localhost:18087/admin     //访问web

这只是一个参考,有些顺序不是必须的,但启动dashboard前,必须启动zookeeper服务,这是必须的,后面有很多操作,都可以在web页面完成,例如添加/删除组,添加/删除redis实例等

 

 

7. 修改脚本,启动 dashboard。( 只需在一台机器上启动即可。codis-ha2上启动 ,后续大部分操作都可以在面板上操作)

cat /usr/local/codis/scripts/start_dashboard.sh

#!/bin/sh

CODIS_HOME=/usr/local/codis 

 

nohup $CODIS_HOME/bin/codis-config -c $CODIS_HOME/conf/config.ini -L $CODIS_HOME/logs/dashboard.log dashboard --addr=:18087 --http-log=$CODIS_HOME/logs/requests.log &>/dev/null &

 

启动dashboard

[root@codis-ha2 scripts]# ls -lh start_dashboard.sh 

-rwxr-xr-x 1 root root 218 Jun 24 22:04 start_dashboard.sh

[root@codis-ha2 scripts]# ./start_dashboard.sh 

[root@codis-ha2 scripts]# ps aux |grep codis-config

root      2435  0.0  0.1 216444 11044 pts/1    Sl   10:06   0:00 /usr/local/codis/bin/codis-config -c /usr/local/codis/conf/config.ini -L /usr/local/codis/logs/dashboard.log dashboard --addr=:18087 --http-log=/usr/local/codis/logs/requests.log

root      2441  0.0  0.0 103252   840 pts/1    S+   10:06   0:00 grep --color=auto codis-config

[root@codis-ha2 scripts]# netstat -tulpn |grep codis

tcp        0      0 :::10086                    :::*                        LISTEN      2435/codis-config   

tcp        0      0 :::18087                    :::*                        LISTEN      2435/codis-config   

 

访问dashboard

http://192.168.88.112:18087/admin/

 

 

8. 添加redis组 

通过管理页面添加组ID,为组添加主从实例,一个组里只能有一个redis-master:

http://192.168.88.112:18087/admin/(最好用Firefox浏览器或者谷歌浏览器)

登录http://192.168.88.112:18087/admin/,添加2个组,组里面有2个实例,一个主一个从,默认每个组里面第一个实例是主

group_1

192.168.88.106:6379   master

192.168.88.107:6380   slave

group_2

192.168.88.106:6389   master

192.168.88.108:6390   slave

 

group_3

192.168.88.107:6379   master

192.168.88.106:6380   slave

group_4

192.168.88.107:6389   master

192.168.88.108:6380   slave

 

group_5

192.168.88.108:6379   master

192.168.88.106:6390   slave

group_6

192.168.88.108:6389   master

192.168.88.107:6390   slave

 

9. 修改脚本,初始化槽 ( 在codis-ha2机器上配置,初始化solt是在group设置好之后 )

[root@codis-ha2 scripts]# cat initslot.sh 

#!/bin/sh

CODIS_HOME=/usr/local/codis

echo "slots initializing..."

$CODIS_HOME/bin/codis-config -c $CODIS_HOME/conf/config.ini slot init -f

echo "done"

echo "set slot ranges to server groups..."

$CODIS_HOME/bin/codis-config -c  config.ini slot range-set 0 170 1 online

$CODIS_HOME/bin/codis-config -c  config.ini slot range-set 171 341 2 online

$CODIS_HOME/bin/codis-config -c  config.ini slot range-set 342 512 3 online

$CODIS_HOME/bin/codis-config -c  config.ini slot range-set 513 683 4 online

$CODIS_HOME/bin/codis-config -c  config.ini slot range-set 684 853 5 online

$CODIS_HOME/bin/codis-config -c  config.ini slot range-set 854 1023 6 online

echo "done"

 

 

10.测试一下redis-master和redis-slave是否正常同步数据了:

这个需要用redis-cli测试:

[root@codis-server1 ~]# redis-cli -h 192.168.88.106 -p 6379

192.168.88.106:6379> ping

PONG

192.168.88.106:6379> set name jerrymin

OK

192.168.88.106:6379> get name

"jerrymin"

192.168.88.106:6379> quit

[root@codis-server1 ~]# redis-cli -h 192.168.88.107 -p 6380

192.168.88.107:6380> get name

"jerrymin"

192.168.88.107:6380> set name foo

(error) READONLY You can't write against a read only slave.

192.168.88.107:6380> quit

 

 

11. 修改start_proxy.sh,启动codis-proxy服务 ( 在zookeeper-1、zookeeper-2、zookeeper-3上配置)

 

zookeeper-1上(其他上面就是codis_proxy_2、codis_proxy_3)

 

查看start_proxy脚本

[root@zookeeper-1 scripts]# cat start_proxy.sh 

#!/bin/sh

 

CODIS_HOME=/usr/local/codis

 

echo "shut down codis_proxy_1..."

$CODIS_HOME/bin/codis-config -c $CODIS_HOME/conf/config.ini proxy offline codis_proxy_1

echo "done"

 

echo "start new codis_proxy_1..."

nohup $CODIS_HOME/bin/codis-proxy --log-level info -c $CODIS_HOME/conf/config.ini -L $CODIS_HOME/logs/codis_proxy_1.log  --cpu=4 --addr=0.0.0.0:19000 --http-addr=0.0.0.0:11000 &

echo "done"

 

echo "sleep 3s"

sleep 3

tail -n 30 $CODIS_HOME/logs/codis_proxy_1.log.0

 

查看proxy_online脚本

[root@zookeeper-1 scripts]# cat set_proxy_online.sh 

#!/bin/sh

 

CODIS_HOME=/usr/local/codis

echo "set codis_proxy_1 online"

$CODIS_HOME/bin/codis-config -c $CODIS_HOME/conf/config.ini proxy online codis_proxy_1

echo "done"

 

启动proxy

[root@zookeeper-1 scripts]# ./start_proxy.sh 

shut down codis_proxy_1...

{

  "msg": "OK",

  "ret": 0

}

done

start new codis_proxy_1...

done

sleep 3s

nohup: appending output to `nohup.out'

2015/07/24 11:06:13 [INFO] set log level to %!s(log.LogLevel=7)

2015/07/24 11:06:13 [INFO] running on 0.0.0.0:19000

2015/07/24 11:06:13 [INFO] start proxy with config: &{proxyId:codis_proxy_1 productName:jerrymin-codis zkAddr:zookeeper-1:2181,zookeeper-2:2181,zookeeper-3:2181 fact:<nil> netTimeout:50 proto:tcp provider:zookeeper}

2015/07/24 11:06:13 [INFO] proxy info = {Id:codis_proxy_1 Addr:zookeeper-1:19000 LastEvent: LastEventTs:0 State:offline Description: DebugVarAddr:zookeeper-1:11000 Pid:8097 StartAt:2015-07-24 11:06:13.4791833 +0800 CST}

2015/07/24 11:06:13 [WARN] wait to be online: codis_proxy_1

 

上线proxy

[root@zookeeper-1 scripts]# ./set_proxy_online.sh 

set codis_proxy_1 online

{

  "msg": "OK",

  "ret": 0

}

done

 

 

 

三,配置HA

 

1,codis-ha1和codis-ha2上操作

安装keeplived和ipvsadm

设置VIP 192.168.88.159

codis-ha1  为LVS主

codis-ha2  为LVS备

如下是备的配置,主的配置与此类似

[root@codis-ha2 haproxy]# cat /etc/keepalived/keepalived.conf

! Configuration File for keepalived

global_defs {

   notification_email {

     local@localhost

   }

   notification_email_from localhost@localhost

   smtp_server 127.0.0.1

   smtp_connect_timeout 30

   router_id LVS_DEVEL_112

}

vrrp_script chk_haproxy_port {

   script "/etc/keepalived/check_haproxy.sh"

   interval 2

   weight 2

}

vrrp_instance VI_1 {

    state BACKUP

    interface eth0

    virtual_router_id 159

    priority 50

    advert_int 3

    authentication {

        auth_type PASS

        auth_pass jerrymin

    }

    virtual_ipaddress {

        192.168.88.159

    }

    track_script {

      chk_haproxy_port

    }

}

检测脚本,保证keepalived切换成主时haproxy在工作

[root@codis-ha2 keepalived]# cat check_haproxy.sh 

#!/bin/bash

A=`ps -C haproxy --no-header |wc -l`

if [ $A -eq 0 ];then

/usr/local/haproxy/sbin/haproxy -f /usr/local/haproxy/haproxy.cfg

sleep 3

if [ `ps -C haproxy --no-header |wc -l` -eq 0 ];then

/etc/init.d/keepalived stop

fi

fi

 

 

2,安装配置haproxy

[root@codis-ha1 ~]#tar zxvf  haproxy-1.5.11.tar.gz 

[root@codis-ha1 ~]#cd  haproxy-1.5.11

[root@codis-ha1 haproxy-1.5.11]#make TARGET=linux26 PREFIX=/usr/local/haproxy 

[root@codis-ha1 haproxy-1.5.11]#make install PREFIX=/usr/local/haproxy

 

3,配置haproxy.cfg

global 

        maxconn 40000 

daemon

        user root

        group root 

        nbproc 4 

        log 127.0.0.1 local3 

        spread-checks 2 

defaults 

         timeout server  3s 

         timeout connect 3s 

         timeout client  60s 

         timeout http-request 3s 

         timeout queue   3s

frontend codis-proxy

        bind :19000 

        default_backend codis-proxy-19000

 

frontend web_haproxy_status 

        bind :8080 

        default_backend web_status

 

 

backend codis-proxy-19000

        mode    tcp 

        option  tcpka 

        balance roundrobin 

        server  msvr1 192.168.88.113:19000 check   inter 1s rise 5 fall 1 

        server  msvr2 192.168.88.114:19000 check   inter 1s rise 5 fall 1 

        server  msvr3 192.168.88.115:19000 check   inter 1s rise 5 fall 1 

timeout server   9s 

 

backend  web_status 

         mode http 

         stats enable 

         stats refresh 5s 

         stats uri /status 

         stats realm Haproxy\ statistics 

         stats auth jerrymin:jerrymin@2015

 

4.启动服务

启动服务:

[root@codis-ha1 haproxy]# /usr/local/haproxy/sbin/haproxy -f /usr/local/haproxy/haproxy.cfg

[root@codis-ha1 haproxy]# ps aux |grep haproxy

root      3147  0.0  0.0  18668  3020 ?        Ss   14:42   0:00 /usr/local/haproxy/sbin/haproxy -f /usr/local/haproxy/haproxy.cfg

root      3148  0.0  0.0  18668  2888 ?        Ss   14:42   0:00 /usr/local/haproxy/sbin/haproxy -f /usr/local/haproxy/haproxy.cfg

root      3149  0.0  0.0  18668  2888 ?        Ss   14:42   0:00 /usr/local/haproxy/sbin/haproxy -f /usr/local/haproxy/haproxy.cfg

root      3150  0.0  0.0  18668  3020 ?        Ss   14:42   0:00 /usr/local/haproxy/sbin/haproxy -f /usr/local/haproxy/haproxy.cfg

[root@codis-ha1 haproxy]# ipvsadm -ln

IP Virtual Server version 1.2.1 (size=4096)

Prot LocalAddress:Port Scheduler Flags

  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn

TCP  192.168.88.159:19000 wrr

  -> 192.168.88.111:19000           Local   1      0          0 

 

分享到:
评论

相关推荐

    codis集群部署

    三、CODIS集群部署步骤 1. 安装Zookeeper集群:首先,你需要搭建一个稳定的Zookeeper集群,通常由3个或以上节点组成,以保证高可用性。 2. 部署Redis实例:安装多个Redis实例,并配置为集群模式,不启用主从复制。...

    Redis专场:Codis 集群演化与 Redis 异步迁移

    在深入探讨Redis专场中Codis集群演化与Redis异步迁移的内容之前,首先需要对Codis和Redis这两个核心概念有所了解。Redis是一个开源的内存中的数据结构存储系统,用作数据库、缓存和消息中间件。它支持数据结构如字符...

    redis-codis集群

    Zookeeper负责存储Codis集群的状态信息,包括Proxy、Server和数据分片的映射关系等,确保集群的一致性和可靠性。 7. **性能优化** Codis代理使用epoll事件模型,能够高效处理大量并发连接。同时,通过批处理和合并...

    codis集群安装包及文档

    **CODIS集群安装包及文档详解** CODIS(Cluster Of Distributed Internet Services)是阿里巴巴开源的一款分布式Redis解决方案,它为了解决单个Redis实例在内存和网络带宽上的扩展瓶颈问题而设计。CODIS通过代理...

    Codis ansiable playbook 一键部署

    Codis Ansible Playbook 是一个自动化部署工具,用于简化 Codis 的集群安装和管理过程。Codis 是一个分布式 Redis 解决方案,它允许你水平扩展 Redis 集群,提高数据存储和处理能力。Ansible 是一个强大的 IT 自动化...

    细细品味架构·分布式Redis解决方案Codis(第9期)

    2.5 Codis 集群部署实战 2.5.1 集群概要 2.5.2 系统架构 2.5.3 角色分配 2.5.4 部署安装 2.5.5 服务启动及初始化集群 2.5.6 codis-server 的HA 2.5.7 关于集群监控的思考 2.5.8 使用过程中遇到的问题

    Redis 集群解决方案 Codis.zip

    server)ZooKeepercodis-proxy 是客户端连接的 Redis 代理服务, codis-proxy 本身实现了 Redis 协议, 表现得和一个原生的 Redis 没什么区别 (就像 Twemproxy), 对于一个业务来说, 可以部署多个 codis-proxy, codis-...

    codis+lvs+keepalived

    在Codis集群中,可以有多个Codis Server构成高可用的主从架构。 - Codis Dashboard:管理后台,通过该后台可以配置和管理集群状态,如添加、删除Proxy、Server等。 - Zookeeper:用于集群元信息的存储和管理,提供...

    codis安装文档以及安装包

    总结,CODIS是应对大数据量、高并发场景下的理想选择,通过上述步骤,你可以成功地在Linux环境下搭建一个完整的CODIS集群。记得在实际操作过程中,根据自己的服务器配置和业务需求调整相关参数,确保系统的稳定性和...

    codis测试环境搭建

    Codis 的核心架构由四个主要组件组成: 1. **Codis-Proxy**:作为客户端连接的 Redis 代理服务,它实现了 Redis 协议,确保客户端与 Codis 交互时的透明性。 Codis-Proxy 是无状态的,可以部署多个实例以提高并发...

    codis-3.0.3环境搭建

    - **Codis Dashboard:** 集群管理工具,支持组件的添加、删除及数据迁移等操作,确保集群状态一致性。 - **Codis Admin:** 命令行工具,用于控制 Codis Proxy 和 Codis Dashboard 的状态以及访问外部存储。 - **...

    Go-codis-3.2.2源码分析

    Codis提供了一套完整的部署和运维工具,包括codis-proxy、codis-server、codis-config、codis-admin等,方便用户快速搭建和管理Redis集群。 10. 性能优化 Codis在设计上考虑了性能优化,如命令预处理、批量发送等...

    codis-release-src-fromgit.zip

    通过以上步骤,你可以构建并运行一个完整的CODIS集群,实现Redis的高可用性和水平扩展。不过,实际操作中还可能涉及更多细节,比如网络配置、安全策略、数据备份等,需要根据具体场景进行适配。对于开发者来说,理解...

    codis3.2.0-go1.7.5-linux.tar.gz安装包

    7. **与Redis兼容**:CODIS完全兼容Redis协议,这意味着任何支持Redis的客户端都可以无缝接入CODIS集群。 在安装“codis3.2.0-go1.7.5-linux.tar.gz”时,你需要按照以下步骤操作: 1. **解压文件**:使用`tar -...

    codis-release3.1.zip

    在部署和使用CODIS 3.1时,你需要了解Linux环境下的基本操作,熟悉Zookeeper的配置和管理,以及如何通过Dashboard进行集群的监控和操作。在实际应用中,可以根据业务需求调整Proxy和Redis实例的数量,确保系统性能和...

    codis for pika 二进制包

    - **分布式架构**:Codis通过Proxy代理层实现了客户端与多个Redis实例之间的透明通信,使得客户端无需感知后端Redis集群的结构变化。 - **动态扩容/缩容**:Codis支持在线添加或删除Redis节点,无需停机,保证业务...

    codis-3.2.2.zip

    这些工具极大地简化了集群的部署和维护工作。 6. Key限制: 描述中提到的"key最多只支持1024*1024个"可能指的是单个Redis实例的限制,而非Codis框架本身的限制。在分布式环境中,Codis可以通过多实例分片来突破...

    redis数据库集群部署

    ### Redis数据库集群部署知识点详解 #### 一、Redis简介与特性 **Redis**(Remote Dictionary Server)是一款开源的键值(key-value)存储系统,它以其卓越的性能和灵活性,在众多NoSQL数据库中脱颖而出。Redis主要...

    用Go编写的基于代理的高性能Redis集群解决方案Codis.rar

    3. **Redis集群解决方案Codis**: Codis是专门针对Redis设计的集群管理工具,它提供了完整的集群部署、运维和扩展能力,帮助用户轻松管理和维护大规模Redis集群。 **内容详解** 1. **Codis架构**:Codis由三部分...

Global site tag (gtag.js) - Google Analytics