Redis能够将数据复制到放肆数量的从服务器中,可

2020-03-14 11:55 来源:未知

Redis哈希

语法

redis的基准的基本语法如下所示:

1 redis-benchmark [option] [option value]

示例

字符串

Redis字符串是字节序列。Redis字符串是二进制安全的,这意味着他们有一个已知的长度没有任何特殊字符终止,所以你可以存储任何东西,512兆为上限。

示例

语法

eval命令的基本语法如下:

redis 127.0.0.1:6379> EVAL script numkeys key [key ...] arg [arg ...]

分区类型

Redis - 集合

Redis的集合是唯一的字符串的无序集合。集合的唯一性不允许数据的重复的键。

在Redis的集合添加,删除和测试文件是否存在成员在O(1)(常数时间不管里面包含的元素集合的数量)。集合的最大长度为 232 - 1 个元素(每集合超过4294967295元素)。

Redis订阅和发布实现了通讯系统,发件人发送邮件,而接收器接收它们。信息传输的链路称为通道。Redis一个客户端可以订阅任意数量的通道。

Redis - Strings

Redis strings命令用于在Redis的管理字符串值。Redis strings命令的使用语法,如下所示:

列表

例子

以下举例说明Redis脚本的工作原理:

1 redis 127.0.0.1:6379> EVAL "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 key1 key2 first second
2 
3 1) "key1"
4 2) "key2"
5 3) "first"
6 4) "second"

要在Ubuntu上安装Redis桌面管理,可以从下载包并安装它。

哈希

Redis的哈希是键值对的集合。 Redis的哈希值是字符串字段和字符串值之间的映射,因此它们被用来表示对象

$redis-server

例子

 1 redis 127.0.0.1:6379> SADD tutorials redis
 2 (integer) 1
 3 redis 127.0.0.1:6379> SADD tutorials mongodb
 4 (integer) 1
 5 redis 127.0.0.1:6379> SADD tutorials mysql
 6 (integer) 1
 7 redis 127.0.0.1:6379> SADD tutorials mysql
 8 (integer) 0
 9 redis 127.0.0.1:6379> SMEMBERS tutorials
10 
11 1) "mysql"
12 2) "mongodb"
13 3) "redis"

在上述例子中的三个值被命令SADD插入redis的集合名称tutorials。

Redis是完全在内存中保存数据的数据库,使用磁盘只是为了持久性目的; Redis相比许多键值数据存储系统有相对丰富的数据类型; Redis可以将数据复制到任意数量的从服务器中;

例子

 1 redis 127.0.0.1:6379> HMSET yiibai name "redis tutorial" description "redis basic commands for caching" likes 20 visitors 23000
 2 OK
 3 redis 127.0.0.1:6379> HGETALL yiibai
 4 
 5 1) "name"
 6 2) "redis tutorial"
 7 3) "description"
 8 4) "redis basic commands for caching"
 9 5) "likes"
10 6) "20"
11 7) "visitors"
12 8) "23000"

在上面的例子中,已经在哈希命名yiibai的Redis集合名为tutorials(name, description, likes, visitors)

管道的含义

例子

以下举例说明Redis事务如何启动并执行。

 1 redis 127.0.0.1:6379> MULTI
 2 OK
 3 redis 127.0.0.1:6379> SET tutorial redis
 4 QUEUED
 5 redis 127.0.0.1:6379> GET tutorial
 6 QUEUED
 7 redis 127.0.0.1:6379> INCR visitors
 8 QUEUED
 9 redis 127.0.0.1:6379> EXEC
10 
11 1) OK
12 2) "redis"
13 3) (integer) 1

Redis哈希是键值对的集合。Redis哈希是字符串字段和字符串值之间的映射,所以它们用来表示对象。

Redis有序集

Redis的有序集合类似Redis的集合存储在设定值具有唯一性。不同的是,一个有序集合的每个成员用分数,以便采取有序set命令,从最小的到最大的分数有关。

在Redis的有序set添加,删除和测试存在成员O(1)(固定时间,无论里面包含集合元素的数量)。列表的最大长度为 232 - 1 个元素(每集合超过4294967295元素)。

Redis的SAVE命令用于创建当前Redis数据库的备份。

例子

Redis的事务由指令多重发起,然后需要传递在事务,而且整个事务是通过执行命令EXEC执行命令列表。

1 redis 127.0.0.1:6379> MULTI
2 OK
3 List of commands here
4 redis 127.0.0.1:6379> EXEC

要恢复redis数据只需要要将Redis的备份文件放到Redis的目录中,并启动服务器。要了解知道Redis目录在什么位置,可使用CONFIG命令,如下所示:

Redis - 安全

可以Redis的数据库更安全,所以相关的任何客户端都需要在执行命令之前进行身份验证。客户端输入密码匹配需要使用Redis设置在配置文件中的密码。

如果客户端运行命令无需验证设置密码,那么NOAUTH需要验证。错误将返回。因此,客户端需要使用AUTH命令来验证自己的身份信息。

例子

1 redis 127.0.0.1:6379> SET yiibai redis
2 OK
3 redis 127.0.0.1:6379> GET yiibai
4 "redis"

在上面的例子SET和GET是命令,而yiibai是key。

redis 127.0.0.1:6379 pingPONG

例子

下面的示例显示了 Redis 当前数据库如何创建备份。

1 127.0.0.1:6379> SAVE
2 
3 OK

这个命令将创建dump.rdb文件在Redis目录中。

Bgsave

Redis - HyperLogLog

Redis的HyperLogLog使用随机化,以提供唯一的元素数目近似的集合只使用一个常数,并且体积小,少量内存的算法。

HyperLogLog提供,即使每个使用了非常少量的内存(12千字节),标准误差为集合的基数非常近似,没有限制的条目数,可以指定,除非接近 264个条目。

redis 127.0.0.1:6379 EVAL "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 key1 key2 first second1) "key1"2) "key2"3) "first"4) "second"

例子

1 redis 127.0.0.1:6379> SET yiibai redis
2 OK
3 redis 127.0.0.1:6379> DEL yiibai
4 (integer) 1

在上面的例子中DEL是命令,而yiibai是key。如果key被删除,那么输出该命令将是(整数)1,否则它会是(整数)0

Redis HyperLogLog

例子

要检查redis的管道,只要启动Redis实例,然后在终端键入以下命令。

1 $(echo -en "PINGrn SET tutorial redisrnGET tutorialrnINCR visitorrnINCR visitorrnINCR visitorrn"; sleep 10) | nc localhost 6379
2 
3 +PONG
4 +OK
5 redis
6 :1
7 :2
8 :3

在上述例子中,我们必须使用PING命令检查Redis的连接,之后,我们已经设定值的Redis字符串命名tutorial ,之后拿到key的值和增量访问量的三倍。在结果中,我们可以检查所有的命令都一次提交给Redis,Redis是在一个步骤给出所有命令的输出。

示例

例子

 1 redis 127.0.0.1:6379> HMSET user:1 username yiibai password yiibai points 200
 2 OK
 3 redis 127.0.0.1:6379> HGETALL user:1
 4 
 5 1) "username"
 6 2) "yiibai"
 7 3) "password"
 8 4) "yiibai"
 9 5) "points"
10 6) "200"

在上面的例子中的哈希数据类型,用于存储其中包含的用户的基本信息用户的对象。这里HMSET,HEGTALL用户命令user:1是键。

范围分区

分区的缺点

  • 通常不支持涉及多个键的操作。例如,不能两个集合之间执行交叉点,因为它们存储在被映射到不同Redis实例中的键。

  • 涉及多个键的Redis事务不能被使用。

  • 分区粒度是关键,所以它是不可能分片数据集用一个硕大的键是一个非常大的有序集合。

  • 当分区时,数据处理比较复杂,比如要处理多个RDB/AOF文件,使数据备份需要从多个实例和主机聚集持久性文件。

  • 添加和删除的能力可能很复杂。比如Redis的集群支持有添加,并在运行时删除节点不支持此功能的能力,但其他系统,如客户端的分区和代理的数据大多是透明的重新平衡。但是有一个叫Presharding技术有助于在这方面。

示例

有序集合

Redis的有序集合类似于Redis的集合,字符串不重复的集合。不同的是,一个有序集合的每个成员用分数,以便采取有序set命令,从最小的到最大的成员分数有关。虽然成员具有唯一性,但分数可能会重复。

127.0.0.1:6379 BGSAVEBackground saving started

分区的好处

  • 它允许更大的数据库,使用的多台计算机的存储器的总和。如果不分区,一台计算机的内存可支数量有限。

  • 它允许以大规模的计算能力,以多个内核和多个计算机,以及网络带宽向多台计算机和网络适配器。

Redis中的keys命令用于管理redis中的键。Rediskeys命令使用的语法如下所示:

Redis - 连接

Redis的连接命令基本上都是用于管理与Redis的服务器客户端连接。

Redis有序集合

Redis - 分区

分区是一种将数据分成多个Redis的情况下,让每一个实例将只包含你的键字的子集的过程。

Redis字符串

例子

 1 redis 127.0.0.1:6379> lpush tutoriallist redis
 2 (integer) 1
 3 redis 127.0.0.1:6379> lpush tutoriallist mongodb
 4 (integer) 2
 5 redis 127.0.0.1:6379> lpush tutoriallist rabitmq
 6 (integer) 3
 7 redis 127.0.0.1:6379> lrange tutoriallist 0 10
 8 
 9 1) "rabitmq"
10 2) "mongodb"
11 3) "redis"

列表的最大长度为 232 - 1 元素(4294967295,每个列表中可容纳超过4十亿的元素)。

字符串

Redis - 管道传输

Redis是一个TCP服务器,并支持请求/响应协议。在redis一个请求完成下面的步骤:

  • 客户端发送一个查询到服务器,并从套接字中读取,通常在阻塞的方式,对服务器的响应。

  • 服务器处理命令并将响应返回给客户端。

通道的好处

Redis - 脚本

Redis脚本使用Lua解释脚本用于评估计算。它内置的Redis,从2.6.0版本开始使用脚本命令 eval。

Redis集合是唯一字符串的无序集合。唯一集合是不允许数据有重复的键的。在Redis集合中添加,删除和测试成会是否存的时间复杂度为O。集合的最大长度为232- 1个元素。

范围分区

范围分区被映射对象转化为具体的Redis实例的范围内实现。假定在本例中用户ID0〜ID10000将进入实例R0,而用户形成ID10001至20000号将进入实例R1等等。

redis 127.0.0.1:6379 AUTH "password"OKredis 127.0.0.1:6379 PINGPONG

Redis - 列表

Redis的列表是简单的字符串列表,排序插入顺序。您可以添加Redis元素在列表头部或列表的尾部。

列表的最大长度为 232 - 1 个元素(每个列表元素个数超过4294967295)。

Redis事务允许一组命令在单一步骤中执行。事务有两个属性,说明如下:

语法

1 redis 127.0.0.1:6379> COMMAND KEY_NAME

示例

例子

1 127.0.0.1:6379> BGSAVE
2 
3 Background saving started

示例

在Ubuntu上安装Redis的桌面管理器

在Ubuntu上安装Redis的桌面管理器,只需从 打开下载软件包并安装它。

Redis桌面管理器会给你用户界面来管理Redis的Key和数据。

$(echo -en "PINGrn SET tutorial redisrnGET tutorialrnINCR visitorrnINCR visitorrnINCR visitorrn"; sleep 10) | nc localhost 6379+PONG+OKredis:1:2:3

还原Redis数据

要恢复Redis的数据只需移动 Redis 的备份文件(dump.rdb)到 Redis 目录,然后启动服务器。为了得到你的 Redis 目录,使用配置命令如下所示:

1 127.0.0.1:6379> CONFIG get dir
2 
3 1) "dir"
4 2) "/user/yiibai/redis-2.8.13/src"

在上述命令的输出在 /user/yiibai/redis-2.8.13/src 目录,在安装redis的服务器安装位置。

客户端最大连接数量

Redis - 订阅

Redis的订阅实现了邮件系统,发送者(在Redis的术语中被称为发布者)发送的邮件,而接收器(用户)接收它们。由该消息传送的链路被称为通道。

在Redis客户端可以订阅任何数目的通道。

Redis的基准性能测试是通过同时运行N个命令以检查Redis性能的工具。

Redis - 事务

Redis事务让一组命令在单个步骤执行。事务中有两个属性,说明如下:

  • 在一个事务中的所有命令按顺序执行作为单个隔离操作。通过另一个客户端发出的请求在Redis的事务的过程中执行,这是不可能的。

  • Redis的事务具有原子性。原子意味着要么所有的命令都执行或都不执行。

在上面示例中SET和GET是Redis的命令,这里yiibai就是一个键;

列表

Redis的列表是简单的字符串列表,排序插入顺序。您可以添加元素到Redis的列表的头部或尾部。

在我们的例子中,用户从ID为0至ID10000将进入实例R0,而用户ID10001到ID20000将进入实例R1等等。

Redis - 数据类型

Redis支持5种类型的数据类型,它描述如下的:

不同的是,一个有序集合的每个成员都可以排序,就是为了按有序集合排序获取它们,按权重分值从最小到最大排序。虽然成员都是独一无二的,按权重分数值可能会重复。

Redis 优势

  • 异常快速:Redis的速度非常快,每秒能执行约11万集合,每秒约81000+条记录。

  • 支持丰富的数据类型:Redis支持最大多数开发人员已经知道像列表,集合,有序集合,散列数据类型。这使得它非常容易解决各种各样的问题,因为我们知道哪些问题是可以处理通过它的数据类型更好。

  • 操作都是原子性:所有Redis操作是原子的,这保证了如果两个客户端同时访问的Redis服务器将获得更新后的值。

  • 多功能实用工具:Redis是一个多实用的工具,可以在多个用例如缓存,消息,队列使用(Redis原生支持发布/订阅),任何短暂的数据,应用程序,如Web应用程序会话,网页命中计数等。

redis 127.0.0.1:6379 SET yiibai redisOKredis 127.0.0.1:6379 GET yiibai"redis"

Redis从它的许多竞争继承来的三个主要特点:

Redis分区

管道传输的含义

管道的基本含义是,客户端可以发送多个请求给服务器,而无需等待答复所有,并最后读取在单个步骤中的答复。

redis 127.0.0.1:6379 SET yiibai redisOKredis 127.0.0.1:6379 DEL yiibai(integer) 1

示例

以下举例说明如何发布用户的概念工作。在下面的例子给出一个客户端订阅一个通道名为redisChat

1 redis 127.0.0.1:6379> SUBSCRIBE redisChat
2 
3 Reading messages... (press Ctrl-C to quit)
4 1) "subscribe"
5 2) "redisChat"
6 3) (integer) 1

现在,两个客户端都发布在同一个命名通道redisChat消息,并且以上订阅客户端接收消息。

 1 redis 127.0.0.1:6379> PUBLISH redisChat "Redis is a great caching technique"
 2 
 3 (integer) 1
 4 
 5 redis 127.0.0.1:6379> PUBLISH redisChat "Learn redis by tutorials point"
 6 
 7 (integer) 1
 8 
 9 
10 1) "message"
11 2) "redisChat"
12 3) "Redis is a great caching technique"
13 1) "message"
14 2) "redisChat"
15 3) "Learn redis by tutorials point"

 

异常快速:Redis是非常快的,每秒可以执行大约110000设置操作,81000个/每秒的读取操作。 支持丰富的数据类型:Redis支持最大多数开发人员已经知道如列表,集合,可排序集合,哈希等数据类型。这使得在应用中很容易解决的各种问题,因为我们知道哪些问题处理使用哪种数据类型更好解决。 操作都是原子的:所有Redis的操作都是原子,从而确保当两个客户同时访问Redis服务器得到的是更新后的值。 MultiUtility工具:Redis是一个多功能实用工具,可以在很多如:缓存,消息传递队列中使用,在应用程序中,如:Web应用程序会话,网站页面点击数等任何短暂的数据;

客户端的最大数量

在Redis的配置(redis.conf)属性调用maxclients,它描述客户端可以连接到Redis的最大数量。命令的基本语法是:

1 config get maxclients
2 
3 1) "maxclients"
4 2) "10000"

默认情况下,此属性设置为10000(这取决于操作系统的文件描述符限制最大数量),但你可以改变这个属性。

Redis安全

管道的好处

这种技术的好处是极大地改善协议的性能。通过管道将慢互联网连接速度从5倍的连接速度提高到localhost至少达到百过倍。

redis 127.0.0.1:6379 PUBLISH redisChat "Redis is a great caching technique"(integer) 1redis 127.0.0.1:6379 PUBLISH redisChat "Learn redis by tutorials point"(integer) 11) "message"2) "redisChat"3) "Redis is a great caching technique"1) "message"2) "redisChat"3) "Learn redis by tutorials point"

例子

在下面给出的例子中,在启动服务器我们设置客户端的最大数量为10万。

1 redis-server --maxclients 100000

语法

Redis - 客户端连接

Redis接受配置监听TCP端口和Unix套接字客户端的连接,如果启用。当一个新的客户端连接被接受以下操作进行:

  • 客户端套接字置于非阻塞状态,因为Redis使用复用和非阻塞I/O操作。

  • TCP_NODELAY选项设定是为了确保我们没有在连接时延迟。

  • 创建一个可读的文件时,这样Redis能够尽快收集客户端的查询作为新的数据可供读取的套接字。

Redis数据类型

Redis是一个开源,先进的key-value存储,并用于构建高性能,可扩展的Web应用程序的完美解决方案。

下面的例子说明了Redis脚本是如何工作的:

Redis - keys

Redis keys命令用于在Redis的管理键。Redis keys命令使用语法如下所示:

Redis事务

例子

下面给出的例子检查redis调用100000命令。

 1 redis-benchmark -n 100000
 2 
 3 PING_INLINE: 141043.72 requests per second
 4 PING_BULK: 142857.14 requests per second
 5 SET: 141442.72 requests per second
 6 GET: 145348.83 requests per second
 7 INCR: 137362.64 requests per second
 8 LPUSH: 145348.83 requests per second
 9 LPOP: 146198.83 requests per second
10 SADD: 146198.83 requests per second
11 SPOP: 149253.73 requests per second
12 LPUSH (needed to benchmark LRANGE): 148588.42 requests per second
13 LRANGE_100 (first 100 elements): 58411.21 requests per second
14 LRANGE_300 (first 300 elements): 21195.42 requests per second
15 LRANGE_500 (first 450 elements): 14539.11 requests per second
16 LRANGE_600 (first 600 elements): 10504.20 requests per second
17 MSET (10 keys): 93283.58 requests per second

Redis是一个TCP服务器,支持请求/响应协议。在redis中一个请求完成以下步骤:

例子

 1 redis 127.0.0.1:6379> zadd tutoriallist 0 redis
 2 (integer) 1
 3 redis 127.0.0.1:6379> zadd tutoriallist 0 mongodb
 4 (integer) 1
 5 redis 127.0.0.1:6379> zadd tutoriallist 0 rabitmq
 6 (integer) 1
 7 redis 127.0.0.1:6379> zadd tutoriallist 0 rabitmq
 8 (integer) 0
 9 redis 127.0.0.1:6379> ZRANGEBYSCORE tutoriallist 0 1000
10 
11 1) "redis"
12 2) "mongodb"
13 3) "rabitmq"
127.0.0.1:6379 SAVE

Redis - 哈希

Redis的哈希值是字符串字段和字符串值之间的映射,所以他们是代表对象的完美数据类型

在Redis的哈希值,最多可存储超过400十亿字段

  • 值对。

Redis发布订阅

集合

Redis的集合是字符串的无序集合。在Redis您可以添加,删除和测试文件是否存在,在成员O(1)的时间复杂度。

散列分区

语法

AUTH命令的基本语法如下所示:

1 127.0.0.1:6379> AUTH password

Redis哈希是字符串字段和字符串值之间的映射,所以它是用来表示对象的一个完美的数据类型,Redis的哈希值最多可存储超过4十亿字段-值对。

例子

 1 redis 127.0.0.1:6379> LPUSH tutorials redis
 2 (integer) 1
 3 redis 127.0.0.1:6379> LPUSH tutorials mongodb
 4 (integer) 2
 5 redis 127.0.0.1:6379> LPUSH tutorials mysql
 6 (integer) 3
 7 redis 127.0.0.1:6379> LRANGE tutorials 0 10
 8 
 9 1) "mysql"
10 2) "mongodb"
11 3) "redis"

在上述例子中的三个值被插入在redis列表名为LPUSH的命令教程。

示例

Redis - 环境

Ubuntu上安装Redis,打开终端,然后键入以下命令:

1 $sudo apt-get update
2 $sudo apt-get install redis-server

这将在您的计算机上安装Redis。

启动 Redis

1 $redis-server

检查Redis是否在工作?

1 $redis-cli

这将打开一个Redis提示,如下图所示:

1 redis 127.0.0.1:6379>

上面的提示127.0.0.1是本机的IP地址,6379为Redis服务器运行的端口。现在输入PING命令,如下图所示。

redis 127.0.0.1:6379> ping
PONG

这说明你已经成功地安装Redis在您的机器上。

在上面的提示信息中:127.0.0.1是本机的IP地址,6379是Redis服务器运行的端口。现在输入PING命令,如下图所示:

例子

1 redis 127.0.0.1:6379> SET name "yiibai"
2 OK
3 redis 127.0.0.1:6379> GET name
4 "yiibai"

上面是Redis的set和get命令的例子,Redis名称为yiibai使用的key存储在Redis的字符串值。

在Redis有序集合添加,删除和测试成员的存在的时间复杂度为O。列表的最大长度为232- 1个元素。

语法

对Redis SAVE命令的基本语法如下所示:

1 127.0.0.1:6379> SAVE
redis 127.0.0.1:6379 LPUSH tutorials redis(integer) 1redis 127.0.0.1:6379 LPUSH tutorials mongodb(integer) 2redis 127.0.0.1:6379 LPUSH tutorials mysql(integer) 3redis 127.0.0.1:6379 LRANGE tutorials 0 101) "mysql"2) "mongodb"3) "redis"

例子

 1 redis 127.0.0.1:6379> ZADD tutorials 1 redis
 2 (integer) 1
 3 redis 127.0.0.1:6379> ZADD tutorials 2 mongodb
 4 (integer) 1
 5 redis 127.0.0.1:6379> ZADD tutorials 3 mysql
 6 (integer) 1
 7 redis 127.0.0.1:6379> ZADD tutorials 3 mysql
 8 (integer) 0
 9 redis 127.0.0.1:6379> ZADD tutorials 4 mysql
10 (integer) 0
11 redis 127.0.0.1:6379> ZRANGE tutorials 0 10 WITHSCORES
12 
13 1) "redis"
14 2) "1"
15 3) "mongodb"
16 4) "2"
17 5) "mysql"
18 6) "4"

在上述例子中的三个值被命令ZADD插入其得分在redis的有序集命名为tutorials。

语法

例子

 1 redis 127.0.0.1:6379> sadd tutoriallist redis
 2 (integer) 1
 3 redis 127.0.0.1:6379> sadd tutoriallist mongodb
 4 (integer) 1
 5 redis 127.0.0.1:6379> sadd tutoriallist rabitmq
 6 (integer) 1
 7 redis 127.0.0.1:6379> sadd tutoriallist rabitmq
 8 (integer) 0
 9 redis 127.0.0.1:6379> smembers tutoriallist
10 
11 1) "rabitmq"
12 2) "mongodb"
13 3) "redis"

注意:在上面的例子中rabitmq集合添加加两次,但由于集合元素具有唯一属性。

集合中的元素最大数量为 232 - 1 (4294967295,可容纳超过4十亿元素)。

Redis备份

语法

1 redis 127.0.0.1:6379> COMMAND KEY_NAME

下面的例子说明了一个客户端在Redis服务器上,如何检查服务器是否正在运行并验证自己。

Bgsave

要创建Redis的备份备用命令BGSAVE也可以。这个命令将开始执行备份过程,并在后台运行。

127.0.0.1:6379 SAVEOK

例子

下面给出的例子显示的步骤,以确保您的Redis实例安全。

1 127.0.0.1:6379> CONFIG get requirepass
2 1) "requirepass"
3 2) ""

默认情况下,此属性为空,表示没有设置密码,此实例。您可以通过执行以下命令来更改这个属性

1 127.0.0.1:6379> CONFIG set requirepass "yiibai"
2 OK
3 127.0.0.1:6379> CONFIG get requirepass
4 1) "requirepass"
5 2) "yiibai"

设置密码,如果客户端运行命令没有验证,会提示(错误)NOAUTH,需要通过验证。错误将返回客户端。因此,客户端需要使用AUTHcommand进行认证。

范围分区被映射对象指定Redis实例在一个范围内完成。

Example

下面的例子说明了一个客户如何通过Redis服务器验证自己,并检查服务器是否正在运行。

1 redis 127.0.0.1:6379> AUTH "password"
2 OK
3 redis 127.0.0.1:6379> PING
4 PONG
$redis-cli

分区的类型

redis的提供有两种类型的分区。假设我们有四个Redis实例R0,R1,R2,R3和代表用户很多键如:user:1, user:2, ... 等等

下面给出的例子显示的步骤是用来确保Redis实例的安全。

Redis - 基准

Redis基准是公用工具同时运行Ñ命令检查Redis的性能。

示例

散列分区

在这种类型的分区,一个散列函数(例如,模数函数)被用于转换键成数字,然后数据被存储在不同redis的实例。

(文章出处:

Redis的字符串命令用于管理redis的字符串值。Redis的字符串命令语法的使用如下所示:

例子

下面的示例说明Redis的HyperLogLog工作原理:

 1 redis 127.0.0.1:6379> PFADD tutorials "redis"
 2 
 3 1) (integer) 1
 4 
 5 redis 127.0.0.1:6379> PFADD tutorials "mongodb"
 6 
 7 1) (integer) 1
 8 
 9 redis 127.0.0.1:6379> PFADD tutorials "mysql"
10 
11 1) (integer) 1
12 
13 redis 127.0.0.1:6379> PFCOUNT tutorials
14 
15 (integer) 3

Redis脚本

  • Redis数据库完全在内存中,使用磁盘仅用于持久性。

  • 相比许多键值数据存储,Redis拥有一套较为丰富的数据类型。

  • Redis可以将数据复制到任意数量的从服务器。

这种技术的好处是显着提高协议的性能。管道localhost获得至少达到百倍的网络连接速度。

Redis - 备份

Redis SAVE命令用来创建当前的 Redis 数据库备份。

示例

示例

分区的好处

列表的最大长度为232- 1个元素。

示例

示例

在Redis的配置文件有一个属性maxclients,它描述了可以连接到Redis的客户的最大数量。命令的基本语法是:

Redis的连接命令基本上都用于管理Redis服务器与客户端连接。

启动 Redis

示例

语法

分区的劣势

Redis环境

Redis列表

如果启用了Redis的接受配置监听,客户端可在TCP端口上与Unix套接字连接。以下操作执行后新的客户端连接被服务器接受:

示例

语法

管道的基本含义是:客户端可以发送多个请求给服务器,而不等待全部响应,最后在单个步骤中读取所有响应。

$sudo apt-get update$sudo apt-get install redis-server

恢复Redis数据

EVAL命令的基本语法如下:

127.0.0.1:6379 CONFIG get requirepass1) "requirepass"2) ""

注:在上面的例子中rabitmq被添加两次,但由于它是只集合具有唯一特性。集合中的成员最大数量为232- 1。

要在 Ubuntu 上安装Redis,打开终端,然后输入以下命令:

redis 127.0.0.1:6379 MULTIOKredis 127.0.0.1:6379 SET tutorial redisQUEUEDredis 127.0.0.1:6379 GET tutorialQUEUEDredis 127.0.0.1:6379 INCR visitorsQUEUEDredis 127.0.0.1:6379 EXEC1) OK2) "redis"3) (integer) 1

这说明现在你已经成功地在计算机上安装了Redis。

TAG标签:
版权声明:本文由www.129028.com-澳门金沙唯一官网www129028com发布于编程新闻,转载请注明出处:Redis能够将数据复制到放肆数量的从服务器中,可