twemproxy配置详解

twemproxy的配置信息填写在nutcracker.yml之中,默认的查找位置是在conf目录下,也可以通过-c参数指定。

nutcracker.yml的例子:

redis1:
listen: 10.18.129.48:11299
redis: true
hash: fnv1a_64
distribution: ketama
auto_eject_hosts: true
timeout: 400
server_retry_timeout: 2000
server_failure_limit: 1
servers:
- 10.18.129.48:6379:1
- 10.18.129.48:9898:1



详细的配置信息如下:

[b]listen[/b]
twemproxy监听的端口。可以以ip:port或name:port的形式来书写。

 hash
可以选择的key值的hash算法:
>one_at_a_time
>md5
>crc16
>crc32 (crc32 implementation compatible with libmemcached)
>crc32a (correct crc32 implementation as per the spec)
>fnv1_64
>fnv1a_64
>fnv1_32
>fnv1a_32
>hsieh
>murmur
>jenkins

如果没选择,默认是fnv1a_64。

[b]hash_tag[/b]
hash_tag允许根据key的一个部分来计算key的hash值。hash_tag由两个字符组成,一个是hash_tag的开始,另外一个是hash_tag的结束,在hash_tag的开始和结束之间,是将用于计算key的hash值的部分,计算的结果会用于选择服务器。

例如:如果hash_tag被定义为”{}”,那么key值为"user:{user1}:ids"和"user:{user1}:tweets"的hash值都是基于”user1”,最终会被映射到相同的服务器。而"user:user1:ids"将会使用整个key来计算hash,可能会被映射到不同的服务器。

[b]distribution[/b]
存在ketama、modula和random3种可选的配置。其含义如下:

[b]ketama[/b]
ketama一致性hash算法,会根据服务器构造出一个hash ring,并为ring上的节点分配hash范围。ketama的优势在于单个节点添加、删除之后,会最大程度上保持整个群集中缓存的key值可以被重用。

[b]modula[/b]
modula非常简单,就是根据key值的hash值取模,根据取模的结果选择对应的服务器。

[b]random[/b]
random是无论key值的hash是什么,都随机的选择一个服务器作为key值操作的目标。

[b]timeout[/b]
单位是毫秒,是连接到server的超时值。默认是永久等待。

[b]backlog[/b]
监听TCP 的backlog(连接等待队列)的长度,默认是512。

[b]preconnect[/b]
是一个boolean值,指示twemproxy是否应该预连接pool中的server。默认是false。

[b]redis[/b]
是一个boolean值,用来识别到服务器的通讯协议是redis还是memcached。默认是false。

[b]server_connections[/b]
每个server可以被打开的连接数。默认,每个服务器开一个连接。

[b]auto_eject_hosts[/b]
是一个boolean值,用于控制twemproxy是否应该根据server的连接状态重建群集。这个连接状态是由server_failure_limit阀值来控制。
默认是false。

[b]server_retry_timeout[/b]
单位是毫秒,控制服务器连接的时间间隔,在auto_eject_host被设置为true的时候产生作用。默认是30000 毫秒。

[b]server_failure_limit[/b]
控制连接服务器的次数,在auto_eject_host被设置为true的时候产生作用。默认是2。

[b]servers[/b]
一个pool中的服务器的地址、端口和权重的列表,包括一个可选的服务器的名字,如果提供服务器的名字,将会使用它决定server的次序,从而提供对应的一致性hash的hash ring。否则,将使用server被定义的次序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值