redis上手

如何在windows电脑上部署一个redis

有以下几种方案:
(1)最佳方案是安装redis on Ubuntu on windows
教程见: https://github.com/ServiceStack/redis-windows

image.png

(2) 最方便的方案是直接下载exe安装程序.
下载链接
下载之后直接点击安装就可以了.

如何配置redis, 更改配置之后何时生效?

  • 启动redis的时候指定配置文件. 如下,可以设置配置文件.这个配置文件更改之后,再下次重启的时候生效.
cd D:\Program Files\Redis
redis-server.exe redis.windows.conf
  • 也可以在redis-cli终端中进行配置. 其中config get *是用来查看所有的配置项.此时修改的配置项立刻生效.
cd D:\Program Files\Redis
redis-cli.exe
config set notify-keyspace-events xK
config get * 

如何插入数值

import redis
r = redis.StrictRedis(host='localhost', port=6379, db=0)
r.set('foo', 'bar')
r.get('foo')

如何订阅-发布消息

import redis
r = redis.StrictRedis(host='localhost', port=6379, db=0)
p = r.pubsub() 
p.subscribe('my-first-channel', 'my-second-channel')  #增加一个指定channel名的订阅
p.psubscribe('my-*')#增加一个指定名称模式的订阅
p.subscribe('my-first-channel') #重复订阅的命令会增加一条change_log,但不会对订阅列表有实质影响.
p.unsubscribe() # 取消所有订阅
message_list = []
for _ in range(10):
    message_list.append(p.get_message())  # 一次输出订阅列表的change_log.如果已经输出完了,则返回none.
print(message_list) 
# [{'type': 'subscribe', 'pattern': None, 'channel': b'my-first-channel', 'data': 1}, {'type': 'subscribe', 'pattern': None, 'channel': b'my-second-channel', 'data': 2}, {'type': 'psubscribe', 'pattern': None, 'channel': b'my-*', 'data': 3}, {'type': 'unsubscribe', 'pattern': None, 'channel': b'my-second-channel', 'data': 2}, {'type': 'unsubscribe', 'pattern': None, 'channel': b'my-first-channel', 'data': 1}, None, None, None, None, None]

如何利用callback函数来处理消息

使用p.subscribe方法可以把一个callback函数关联到一个channel上去.这里的坑: 订阅请求是异步执行的.

import redis
import time
r = redis.StrictRedis(host='localhost', port=6379, db=0)
p = r.pubsub()
def my_handler(message):
    print('my-handler:{}'.format(message))
p.subscribe(**{'my-channel':my_handler}) #使用这个方式来把callback函数关联到某个channel上去, 这个可能仅是发一个request过去,没有等到确认就返回了.
time.sleep(0.1) #这里不进行等待的话每次出来的结果是不一样的.
msg_list = []
msg_list.append(p.get_message())
r.publish('my-channel','good data')
msg_list2 = []
for _ in range(10):
    msg_list2.append(p.get_message())
    print(msg_list2)
print(msg_list)

如何开启与关闭订阅线程?

开启线程: 使用p.run_in_thread方法来开启线程.
关闭线程:thread.stop方法来关闭线程.

p.subscribe(**{'my-channel': my_handler})
thread = p.run_in_thread(sleep_time=0.001)
r.publish('my-channel', 'good_news') # 可以调用my_handle
thread.stop()

如果p订阅了一个没有绑定callback函数的channel,会报错.因为这么做会导致订阅的消息无法被消费掉.


image.png

如何使用redis来传递python对象

使用redis的pubsub功能可以传递二进制编码. 如果想传递一个python:py_obj. 发送的时候使用json.dumps(py_obj), 接收者使用json.loads(py_obj).
推测通过pickle做序列化也可以,但是安全性存疑.

如何管理redis的订阅列表

功能: PUBSUB类实例的两种订阅列表. 一种是普通的频道订阅, 另一种是pattern频道订阅.这两个列表分别使用subscribe,psubscribe来增加订阅列表, 使用unsubscribe, 与punsubscribe(必须输入参数)来取消订阅, 使用channels,与patterns来插件订阅列表.\

如何利用redis做微服务?

redis-dealer: 一个基于redis的微型处理单元. 功能类似于flask这样的微服务.只是数据传递不再通过web端口,而是通过redis中的指定通道. 一个redis可以对应多个dealer, 一个dealer也可以对应多个redis.
相对于flask的优势: 1.这个微服务对应一个redis的一个订阅渠道而已. 而一个flask则需要占用一个端口.
2.向这个微服务发其请求比较简单,直接使用redis.publish就可以.
3.利用redis的expire功能,可以方便时间定时启动程序. 而flask则没有这么简洁的方法.
4.在一个脚本里面可以启动N个redis-dealer,而一个脚本通常只能启动一个flask.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,948评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,371评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,490评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,521评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,627评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,842评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,997评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,741评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,203评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,534评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,673评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,339评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,955评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,770评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,000评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,394评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,562评论 2 349

推荐阅读更多精彩内容