设为首页 收藏本站
查看: 645|回复: 0

[经验分享] redis学习笔记(二)

[复制链接]
YunVN网友  发表于 2016-12-18 08:01:36 |阅读模式

Redis - 订阅



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

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


示例



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


redis 127.0.0.1:6379> SUBSCRIBE redisChat

Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "redisChat"
3) (integer) 1



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

redis 127.0.0.1:6379> PUBLISH redisChat "Redis is a great caching technique"

(integer) 1

redis 127.0.0.1:6379> PUBLISH redisChat "Learn redis by tutorials point"

(integer) 1


1) "message"
2) "redisChat"
3) "Redis is a great caching technique"
1) "message"
2) "redisChat"
3) "Learn redis by tutorials point"



Redis - 事务



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



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


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



例子



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


redis 127.0.0.1:6379> MULTI
OK
List of commands here
redis 127.0.0.1:6379> EXEC


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

例子




redis 127.0.0.1:6379> MULTI
OK
redis 127.0.0.1:6379> SET tutorial redis
QUEUED
redis 127.0.0.1:6379> GET tutorial
QUEUED
redis 127.0.0.1:6379> INCR visitors
QUEUED
redis 127.0.0.1:6379> EXEC

1) OK
2) "redis"
3) (integer) 1



Redis - 脚本



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


eval命令的基本语法如下:

语法




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


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

例子




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

1) "key1"
2) "key2"
3) "first"
4) "second"



Redis - 连接



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


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

Example




redis 127.0.0.1:6379> AUTH "password"
OK
redis 127.0.0.1:6379> PING
PONG


Redis - 备份



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


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

语法




127.0.0.1:6379> SAVE


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

例子




127.0.0.1:6379> SAVE

OK



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


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

还原Redis数据




127.0.0.1:6379> CONFIG get dir

1) "dir"
2) "/user/yiibai/redis-2.8.13/src"



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


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



Bgsave



例子


127.0.0.1:6379> BGSAVE

Background saving started



Redis - 安全



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




例子

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






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


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

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


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




语法



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








127.0.0.1:6379> AUTH password

Redis - 基准



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




语法


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


redis-benchmark [option] [option value]


例子



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


redis-benchmark -n 100000

PING_INLINE: 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至少达到百过倍。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-315722-1-1.html 上篇帖子: redis 安装 选数据库 下篇帖子: jmind-redis一个redis的nio客户端
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表