INE: 141043.72 requests per second
PING_BULK: 142857.14 requests per second
SET: 141442.72 requests per second
GET: 145348.83 requests per second
INCR: 137362.64 requests per second
LPUSH: 145348.83 requests per second
LPOP: 146198.83 requests per second
SADD: 146198.83 requests per second
SPOP: 149253.73 requests per second
LPUSH (needed to benchmark LRANGE): 148588.42 requests per second
LRANGE_100 (first 100 elements): 58411.21 requests per second
LRANGE_300 (first 300 elements): 21195.42 requests per second
LRANGE_500 (first 450 elements): 14539.11 requests per second
LRANGE_600 (first 600 elements): 10504.20 requests per second
MSET (10 keys): 93283.58 requests per second
?
?
Redis - 客户端连接
?
Redis接受配置监听TCP端口和Unix套接字客户端的连接,如果启用。当一个新的客户端连接被接受以下操作进行:
?
客户端套接字置于非阻塞状态,因为Redis使用复用和非阻塞I/O操作。
?
TCP_NODELAY选项设定是为了确保我们没有在连接时延迟。
?
创建一个可读的文件时,这样Redis能够尽快收集客户端的查询作为新的数据可供读取的套接字。
?
客户端的最大数量
在Redis的配置(redis.conf)属性调用maxclients,它描述客户端可以连接到Redis的最大数量。命令的基本语法是:
?
config get maxclients
?
1) "maxclients"
2) "10000"
?
默认情况下,此属性设置为10000(这取决于操作
系统的文件描述符限制最大数量),但你可以改变这个属性。
?
例子
在下面给出的例子中,在启动服务器我们设置客户端的最大数量为10万。
?
?
?
redis-server --maxclients 100000
Redis - 管道传输
?
Redis是一个TCP服务器,并支持请求/响应协议。在redis一个请求完成下面的步骤:
?
客户端发送一个查询到服务器,并从套接字中读取,通常在阻塞的方式,对服务器的响应。
?
服务器处理命令并将响应返回给客户端。
?
管道传输的含义
管道的基本含义是,客户端可以发送多个请求给服务器,而无需等待答复所有,并最后读取在单个步骤中的答复。
?
例子
要检查redis的管道,只要启动Redis实例,然后在终端键入以下命令。
?
$(echo -en "PING\r\n SET tutorial redis\r\nGET tutorial\r\nINCR visitor\r\nINCR visitor\r\nINCR visitor\r\n"; sleep 10) | nc localhost 6379
?
+PONG
+OK
redis
:1
:2
:3
?
在上述例子中,我们必须使用PING命令检查Redis的连接,之后,我们已经设定值的Redis字符串命名tutorial ,之后拿到key的值和增量访问量的三倍。在结果中,我们可以检查所有的命令都一次提交给Redis,Redis是在一个步骤给出所有命令的输出。
?
管道的好处
这种技术的好处是极大地改善协议的性能。通过管道将慢互联网连接速度从5倍的连接速度提高到localhost至少达到百过倍。
?
Redis - 分区
?
分区是一种将数据分成多个Redis的情况下,让每一个实例将只包含你的键字的子集的过程。
?
分区的好处
它允许更大的
数据库,使用的多台计算机的存储器的总和。如果不分区,一台计算机的内存可支数量有限。
?
它允许以大规模的计算能力,以多个内核和多个计算机,以及网络带宽向多台计算机和网络适配器。
?
分区的缺点
通常不支持涉及多个键的操作。例如,不能两个集合之间执行交叉点,因为它们存储在被映射到不同Redis实例中的键。
?
涉及多个键的Redis事务不能被使用。
?
分区粒度是关键,所以它是不可能分片数据集用一个硕大的键是一个非常大的有序集合。
?
当分区时,数据处理比较复杂,比如要处理多个RDB/AOF文件,使数据备份需要从多个实例和主机聚集持久性文件。
?
添加和删除的能力可能很复杂。比如Redis的集群支持有添加,并在运行时删除节点不支持此功能的能力,但其他系统,如客户端的分区和代理的数据大多是透明的重新平衡。但是有一个叫Presharding技术有助于在这方面。
?
分区的类型
redis的提供有两种类型的分区。假设我们有四个Redis实例R0,R1,R2,R3和代表用户很多键如:user:1, user:2, ... 等等
?
范围分区
范围分区被映射对象转化为具体的Redis实例的范围内实现。假定在本例中用户ID0~ID10000将进入实例R0,而用户形成ID10001至20000号将进入实例R1等等。
?
散列分区
在这种类型的分区,一个散列函数(例如,模数函数)被用于转换键成数字,然后数据被存储在不同redis的实例。
?