redis 隊列操作的例子(php)

來源:互聯網
上載者:User
Reids是一個比較進階的開源key-value儲存系統,採用ANSI C實現。其與memcached類似,但是支援持久化資料存放區

入隊操作 
複製代碼代碼如下:
<?php 
$redis = new Redis(); 
$redis->connect('127.0.0.1',6379); 
while(True){ 
try{ 
$value = 'value_'.date('Y-m-d H:i:s'); 
$redis->LPUSH('key1',$value); 
sleep(rand()%3); 
echo $value."\n"; 
}catch(Exception $e){ 
echo $e->getMessage()."\n"; 


?> 

出隊操作 
複製代碼代碼如下:
<?php 
$redis = new Redis(); 
$redis->pconnect('127.0.0.1',6379); 
while(True){ 
try{ 
echo $redis->LPOP('key1')."\n"; 
}catch(Exception $e){ 
echo $e->getMessage()."\n"; 

sleep(rand()%3); 
}?> 

如何使用Redis 做隊列操作 
Reids是一個比較進階的開源key-value儲存系統,採用ANSI C實現。其與memcached類似,但是支援持久化資料存放區,同時value支援多種類型:字串 (同memcached中的value),列表 ,集合 (Set),有序集合 (OrderSet)和Hash 。所有的實值型別均支援原子操作,如列表中追加彈出元素,集合中插入移除元素等。Rdids的資料大部分位於記憶體中,其讀寫效率非常高,其提供AOF(追加 式操作記錄檔案)和DUMP(定期資料備份)兩種持久化方式。Redis支援自訂的VM(虛擬記憶體)機制,當資料容量超過記憶體時,可以將部分Value 儲存到檔案中。同時Redis支援Master-Slave機制,可以進行資料複製。 
可以把Redis的list結構當隊列來用. 
從上面Redis的情境和作用來說,對於我們現在的開發活動,究竟能把Redis引入在那些情境,而不是把這麼好的東東演變成“為了使用Redis,而Redis”的慘烈局面呢。當然,具體問題具體分析,這個真的很重要哈。 
緩衝。分布式緩衝。 
隊列。分布式隊列。 
某些系統應用(例如,電信、銀行和大型互連網應用等)都會使用到,當然,現在大行其道的memcache就是很好的證明;但從某一方面來說,memcache是否能把兩張囊括其中,而且能做到更好(沒有實際的應用過,所以只是拋出)。但從Redis身上,我就能感覺到,Redis,就能把隊列和緩衝兩張都囊括其中,而且都不會產生並發環境下的困擾,因為Redis中的操作都是原子操作來著。 
至於評論兩者的孰好孰壞就免了,存在就是理由,選擇適合的就是最好的。 
下面開始玩玩Redis中的隊列(分布式)設計YY吧,請大蝦們多多指點。 
狀況情境: 
現在的項目,都是部署在多個伺服器,或者多個IP上,而且前台經由F5分發,所以使用者的請求究竟落在那一台的伺服器上,是無法確定的。對於項目中,有一秒殺設計,剛開始沒有考慮到這種部署,同時也是使用最容易處理的方式,直接給資料庫表鎖行記錄(Oracle上的)。可以說,對於不同的應用部署,而只有一台資料庫伺服器來說,很“輕鬆”的就解決了這個並發的問題。所以現在考慮一下,是不是挪到應用上,避免資料庫伺服器也摻雜到業務上。 
比如,現在有2台應用伺服器,1台資料庫伺服器。想法是,把Redis部署在資料庫伺服器上,兩台伺服器在操作並發緩衝或者隊列時,先從Redis伺服器上,取得在兩台應用伺服器的代理對象,再做入列出列的操作。 
看代碼實現(PHP) 
入隊列操作檔案 list_push.php 
複製代碼代碼如下:
<?php 
$redis = getRedisInstance();//從Redis伺服器拿到redis執行個體 
$redis->connect('Redis伺服器IP', 6379); 
while (true) { 
$redis->lPush('list1', 'A_'.date('Y-m-d H:i:s')); 
sleep(rand()%3); 

?> 

執行# php list_push.php & 
出隊列操作 list_pop.php檔案 
複製代碼代碼如下:
<?php 
$redis = getRedisInstance();//從Redis伺服器拿到redis執行個體 
$redis->pconnect('Redis伺服器IP', 6379); 
while(true) { 
try { 
var_export( $redis->blPop('list1', 10) ); 
} catch(Exception $e) { 
//echo $e; 



實現方法(Python) 
1.入隊列(write.py) 
複製代碼代碼如下:
#!/usr/bin/env python 
import time 
from redis import Redis 
redis = Redis(host='127.0.0.1', port=6379) 
while True: 
now = time.strftime("%Y/%m/%d %H:%M:%S") 
redis.lpush('test_queue', now) 
time.sleep(1) 

2.出隊列(read.py) 
複製代碼代碼如下:
#!/usr/bin/env python 
import sys 
from redis import Redis 
redis = Redis(host='127.0.0.1', port=6379) 
while True: 
res = redis.rpop('test_queue') 
if res == None: 
pass 
else: 
print str(res) 

在操作時,注意,要操作的是同一個list對象。 
呵呵,現在的主要思路就差不多就是如此,不過真實情境中,會有出入。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.