0.
http://qing.blog.sina.com.cn/tj/4a1a3ea33300004d.html
1.
记Redis那坑人的HGETALL
http://huoding.com/2013/01/21/214
2.
http://www.kazaff.me/2013/02/21/hiredis%E5%85%A5%E9%97%A8/
3. http://www.searchdatabase.com.cn/showcontent_72701.htm
低效操作产生的延迟
单线程的一个结果是,当一个请求执行得很慢,其他的客户端调用就必须等待这个请求执行完毕。当执行GET、SET或者LPUSH 命令的时候这不是个问题,因为这些操作可在很短的常数时间内完成。然而,对于多个元素的操作,像SORT,LREM, SUNION 这些,做两个大数据集的交叉要花掉很长的时间。文档中提到了所有操作的算法复杂性。 在使用一个你不熟悉的命令之前系统的检查它会是一个好办法。
如果你对延迟有要求,那么就不要执行涉及多个元素的慢操作,你可以使用Redis的replication功能,把这类慢操作全都放到replica上执行。可以用Redis 的Slow Log来监控慢操作。此外,你可以用你喜欢的进程监控程序(top, htop, prstat, 等...)来快速查看Redis进程的CPU使用率。如果traffic不高而CPU占用很高,八成说明有慢操作。
4.
http://lingqi1818.iteye.com/blog/1182429
结论:
1.由于服务器采用单进程单线程的模型,服务器实际响应客户请求其实是先来后到的串行模式,只要服务器算法OK,那么单个请求响应时间绝对OK。
2.假如你要提升服务器的并发能力,那么可以采用在单台机器部署多个redis进程的方式。
*********************
1.Data Modeling In Redis http://openmymind.net/Data-Modeling-In-Redis/
2.
Storing two way relational data in Redis
3. https://github.com/jiedan/redis-search-py/blob/master/redis_search/query.py
4.