利用Redis流怎么實(shí)現(xiàn)一個(gè)消息隊(duì)列?相信很多沒(méi)有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。
在無(wú)錫等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供網(wǎng)站設(shè)計(jì)制作、網(wǎng)站設(shè)計(jì) 網(wǎng)站設(shè)計(jì)制作按需策劃設(shè)計(jì),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站設(shè)計(jì),成都營(yíng)銷網(wǎng)站建設(shè),成都外貿(mào)網(wǎng)站建設(shè)公司,無(wú)錫網(wǎng)站建設(shè)費(fèi)用合理。代碼清單 10-1 展示了一個(gè)具有基本功能的消息隊(duì)列實(shí)現(xiàn):
代碼最開(kāi)頭的是幾個(gè)轉(zhuǎn)換函數(shù), 它們負(fù)責(zé)對(duì)程序的相關(guān)輸入輸出進(jìn)行轉(zhuǎn)換和格式化;
MessageQueue 類用于實(shí)現(xiàn)消息隊(duì)列, 它的添加消息、移除消息以及返回消息數(shù)量三個(gè)方法分別使用了流的 XADD 命令、 XDEL 命令和 XLEN 命令;
消息隊(duì)列的兩個(gè)獲取方法 get_message() 和 get_by_range() 分別以兩種形式調(diào)用了流的 XRANGE 命令;
最后, 用于迭代消息的 iterate() 方法使用了 XREAD 命令對(duì)流進(jìn)行迭代。
代碼清單 10-1 使用 Redis 流實(shí)現(xiàn)的消息隊(duì)列: /stream/message_queue.py
def reconstruct_message_list(message_list): """ 為了讓多條消息能夠以更結(jié)構(gòu)化的方式返回給調(diào)用者, 將 Redis 返回的多條消息從原來(lái)的格式: [(id1, {k1:v1, k2:v2, ...}), (id2, {k1:v1, k2:v2, ...}), ...] 轉(zhuǎn)換成以下格式: [{id1: {k1:v1, k2:v2, ...}}, {id2: {k1:v1, k2:v2, ...}}, ...] """ result = [] for id, kvs in message_list: result.append({id: kvs}) return result def get_message_from_nested_list(lst): """ 從嵌套列表中取出消息本體。 """ return lst[0][1] class MessageQueue: """ 使用 Redis 流實(shí)現(xiàn)的消息隊(duì)列。 """ def __init__(self, client, stream_key): self.client = client self.stream = stream_key def add_message(self, key_value_pairs): """ 將給定的鍵值對(duì)存入到消息里面,并返回相應(yīng)的消息 ID 。 """ return self.client.xadd(self.stream, key_value_pairs) def get_message(self, message_id): """ 根據(jù)給定的消息 ID 返回相應(yīng)的消息,如果消息不存在則返回 None 。 """ reply = self.client.xrange(self.stream, message_id, message_id) if len(reply) == 1: return get_message_from_nested_list(reply) def remove_message(self, message_id): """ 根據(jù)給定的消息 ID 刪除相應(yīng)的消息,如果消息不存在則忽略該動(dòng)作。 """ self.client.xdel(self.stream, message_id) def len(self): """ 返回消息隊(duì)列的長(zhǎng)度。 """ return self.client.xlen(self.stream) def get_by_range(self, start_id, end_id, max_item=10): """ 根據(jù)給定的 ID 區(qū)間范圍返回隊(duì)列中的消息。 """ reply = self.client.xrange(self.stream, start_id, end_id, max_item) return reconstruct_message_list(reply) def iterate(self, start_id=0, max_item=10): """ 對(duì)消息隊(duì)列進(jìn)行迭代,返回最多 N 條大于給定 ID 的消息。 """ reply = self.client.xread({self.stream: start_id}, max_item) if len(reply) == 0: return list() else: messages = get_message_from_nested_list(reply) return reconstruct_message_list(messages)
對(duì)于這個(gè)消息隊(duì)列實(shí)現(xiàn), 我們可以通過(guò)執(zhí)行以下代碼, 創(chuàng)建出它的實(shí)例:
>>> from redis import Redis >>> from message_queue import MessageQueue >>> client = Redis(decode_responses=True) >>> mq = MessageQueue(client, "mq")
然后通過(guò)執(zhí)行以下代碼, 向隊(duì)列里面添加十條消息:
>>> for i in range(10): ... key = "key{0}".format(i) ... value = "value{0}".format(i) ... msg = {key:value} ... mq.add_message(msg) ... '1554113926280-0' '1554113926280-1' '1554113926281-0' '1554113926281-1' '1554113926281-2' '1554113926281-3' '1554113926281-4' '1554113926281-5' '1554113926281-6' '1554113926282-0'
還可以根據(jù) ID 獲取指定的消息, 又或者使用 get_by_range() 方法同時(shí)獲取多條消息:
>>> mq.get_message('1554113926280-0') {'key0': 'value0'} >>> mq.get_message('1554113926280-1') {'key1': 'value1'} >>> mq.get_by_range("-", "+", 3) [{'1554113926280-0': {'key0': 'value0'}}, {'1554113926280-1': {'key1': 'value1'}}, {'1554113926281-0': {'key2': 'value2'}}]
又或者使用 iterate() 方法對(duì)消息隊(duì)列進(jìn)行迭代, 等等:
>>> mq.iterate(0, 3) [{'1554113926280-0': {'key0': 'value0'}}, {'1554113926280-1': {'key1': 'value1'}}, {'1554113926281-0': {'key2': 'value2'}}] >>> mq.iterate('1554113926281-0', 3) [{'1554113926281-1': {'key3': 'value3'}}, {'1554113926281-2': {'key4': 'value4'}}, {'1554113926281-3': {'key5': 'value5'}}]
看完上述內(nèi)容,你們掌握利用Redis流怎么實(shí)現(xiàn)一個(gè)消息隊(duì)列的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道,感謝各位的閱讀!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
當(dāng)前名稱:利用Redis流怎么實(shí)現(xiàn)一個(gè)消息隊(duì)列-創(chuàng)新互聯(lián)
文章出自:http://aaarwkj.com/article12/jcjgc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動(dòng)態(tài)網(wǎng)站、企業(yè)網(wǎng)站制作、網(wǎng)站維護(hù)、App開(kāi)發(fā)、域名注冊(cè)、服務(wù)器托管
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容