Twemproxy是Twitter开源的Redis代理,借助其可实现稳定的Redis分布式方案,相对于官方较新的Redis Cluster架构,容量伸缩较麻烦。



安装比较简单,注意可能会遇到autoconf版本低的问题。


安装依赖库

# yum install autoconf libtool -y


下载最新版本

https://github.com/twitter/twemproxy/releases


编译安装twemproxy

# tar zxf twemproxy-0.4.1.tar.gz

# cd twemproxy-0.4.1


遇到autoconf版本低的报错

# autoreconf -fvi

...

configure.ac:8: error: Autoconf version 2.64 or higher is required


下载较高版本的autoconf

http://ftp.gnu.org/gnu/autoconf/autoconf-2.69.tar.gz


编译安装autoconf,并覆盖低版本文件

# ./configure

# make

# make install


# cp /usr/local/bin/autoconf /usr/bin/

# cp /usr/local/bin/autoreconf /usr/bin/


重新安装

# autoreconf -fvi

# ./configure --prefix=/usr/local/twemproxy

# make

# make install



twemproxy的重要特性

1. Maintains persistent server connections.

2. Keeps connection count on the backend caching servers low.

3. Enables pipelining of requests and responses.

4. Supports multiple server pools simultaneously.

5. Observability via stats exposed on the stats monitoring port.

6. Supports multiple hashing modes including consistent hashing and distribution.



配置文件,其中端口6379和6389为2个Redis实例。

$ cat kp.conf 

kp:

  listen: 127.0.0.1:7379

  hash: fnv1a_64

  distribution: ketama

  timeout: 100

  auto_eject_hosts: true

  server_retry_timeout: 2000

  server_failure_limit: 2

  redis: true

  redis_auth: abcdefg

  servers:

   - 127.0.0.1:6379:1

   - 127.0.0.1:6389:1


启动twemproxy

$ nutcracker --daemonize --verbose=11 --output=nut.log --conf-file=kp.conf --stats-port=22222 --pid-file=nut.pid


登陆twemproxy

$ redis-cli -p 7379 -a abcdefg

127.0.0.1:7379> get hello

"redis"

127.0.0.1:7379> set twe proxy

OK

127.0.0.1:7379> dbsize

Error: Server closed the connection


获取twemproxy状态

$ curl --get http://127.0.0.1:22222

{"service":"nutcracker", "source":"51", "version":"0.4.1", "uptime":22766, 

...

}


若感兴趣可关注订阅号”数据库最佳实践”(DBBestPractice).

Redis的代理(Twemproxy)_twemproxy