tcp_nodelay memcached java_memcached客户端应该具备的功能

memcached 只是一个服务,为了更好的使用它,必须从客户端的角度来审视它,很多客户端实现了很多 memcached 本身不具备的功能,优秀的 memcached 客户端应该具备哪些功能呢?

本篇文章从 PHP memcached 扩展的角度,看看它具备了哪些功能。

1:支持一致性 Hash

一致性 hash 是一种更好分布key的模型,增加或删除某个实例的时候,不会导致过多的 key 失效。

常规hash算法,增加第11个实例,将有40%的key 失效,而使用一致性hash算法,只有10%的key 失效。

在 PHP memcached 扩展中,普通 Hash 算法由 Memcached::OPT_HASH 变量定义,分布式 Hash 算法由 Memcached::OPT_DISTRIBUTION 变量定义。

2:权重

不同 memcached 节点的能力不一定相同,所以在启用一致性hash的时候,需要给节点配置不同的权重。需要注意到是,各个客户端配置的节点顺序和对应权重必须一致,否则就会导致相同的key对应到不同的节点中。

3:序列化

memcached 服务不关心数据结构,它存储的就是字符串,如果用户想存储复杂的数据结构,客户端可以先序列化,然后 set,get 的时候再反序列化。

那么客户端在 get 的时候怎么知道是否要反序列化?客户端在 set 的时候需要对 item 设置特殊的 flag,这样 get 的时候才能正确反解。

PHP memcached 客户端支持三种序列算法,Memcached::SERIALIZER_PHP、Memcached::SERIALIZER_IGBINARY、Memcached::SERIALIZER_JSON。

4:压缩

为了有效利用内存和减少网络延迟,item 大小如果过大,客户端在 set 之前会压缩数据。

大部分客户端会根据阀值决定是否启用压缩,过小的item如果压缩只会消耗cpu,并不能减少内存的使用。

5:管理连接对象

如果频繁的打开和关闭memcached连接对象,可能会导致连接泄漏,所以大部分客户端都有管理memcached连接对象的方法。

比如 PHP memcached 客户端的 addServer() 函数不会直接连接 memcached 节点,只有具体 set/get 请求的时候才会连接。

6:Failure or Failover

在《正确理解memcached,才能更好的使用》这篇文章中已经说过,尽量选择 Failure。

参考了 Laravel 代码,PHP 如果想支持 Failover,请使用下列代码:

$m = new Memcached;

$m->setOption(Memcached::OPT_DISTRIBUTION,Memcached::DISTRIBUTION_CONSISTENT);

$->setOption(Memcached::OPT_LIBKETAMA_COMPATIBLE,TRUE);

$m->setOption(Memcached::OPT_RETRY_TIMEOUT,2);

$m->setOption(Memcached::OPT_SERVER_FAILURE_LIMIT, 1);

$m->setOption(Memcached::OPT_AUTO_EJECT_HOSTS,true);

7:Multi-Get

客户端可以从多个 memcached 实例中获取多个 key 对应的数据,具体的实现方法取决于客户端的实现(比如客户端可以并行向不同的 memcached 节点发送请求)。

8:客户端应该能够存储二进制或字符串数据

PHP memcached 扩展默认没有开启二进制协议的支持,Memcached::OPT_BINARY_PROTOCOL 可以控制打开。

9:Noreply

如果对 set 的结果不关心,为了提升性能,客户端不用等待 memcached 响应。

在 PHP memcached 扩展中,该功能默认没有开启,可以使用 Memcached::OPT_TCP_NODELAY 开启。

10:超时控制

大部分 memcached 客户端支持连接超时(毫秒级别)、连接重试次数、发送超时、读取超时。

PHP memcached 扩展在这方面说的不是很详细,只有非阻塞模式,这些控制才能生效,参考下列代码:

$m = new Memcached;

//阻塞模式调用memcached

$m->setOption(Memcached::OPT_NO_BLOCK,FALSE);

$m->setOption(Memcached::OPT_CONNECT_TIMEOUT,2000);

$m->setOption(Memcached::OPT_POLL_TIMEOUT,2000);

$m->setOption(Memcached::OPT_RECV_TIMEOUT,750);

$m->setOption(Memcached::OPT_SEND_TIMEOUT,750);

11:支持从特定 memcached 节点获取数据

在启用一致性 hash 算法的时候,如果某个用户的数据有多个 key(姓名、地址、身高...),为避免分散存储,可以将关联的key存储到同一个节点上,PHP memcached 扩展的 setByKey() 函数支持该功能。

//指定某个key存储在特定的server上

$memcache->addByKey('server1','key','value1');

$memcache->addByKey('server2','key','value2');

$memcache->addByKey('server3','key','value3');

echo $memcache->getByKey('server1','key');

print_r($keys);

memcached 系列文章:

欢迎了解我的书《深入浅出HTTPS:从原理到实战》,也可以关注公众号(ID:yudadanwx,虞大胆的叽叽喳喳)。

CCF大数据与计算智能大赛-面向电信行业存量用户的智能套餐个性化匹配模型联通赛-复赛第二名-【多分类,embedding】.zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值