python--memcached---activemq

1.安装memcached的python客户端

 wget ftp://ftp.tummy.com/pub/python-memcached/python-memcached-latest.tar.gz
  python2.x setup.py install


2.安装activemq的python客户端

  wget http://stomppy.googlecode.com/files/stomp.py-3.0.3.tar.gz
  python2.x setup.py install --prefix=/usr/local/similarlib/

  stomp官网支持:http://code.google.com/p/stomppy/


3.python-activemq的demo程序

mq_send:

#!/usr/bin/python
#
# Usage: stomp_send.py <msize> <nmsgs>
#

import sys
import os
import logging
import stomp
import time
import json

logging.basicConfig()

nmsgs = int(sys.argv[1])
msg = {'pid':1,'id':1,'start_at':"time",'type':'parse_title','articleid':0, 'from':1, 'to':361}
dest = '/queue/worker'
start = time.time()

conn = stomp.Connection([('172.16.1.217', 61612)])
conn.start()
conn.connect(wait=True)

for i in range(nmsgs):
	msg['articleid'] = i
	conn.send(json.write(msg), destination=dest)
	print "send one"

conn.disconnect()
print "OK Finished msgs %d time %f" % (nmsgs, (time.time()-start))
mq_receive:
import sys
import os
import logging
import stomp
import json
import time

class MyListener(object):
	def on_error(self, headers, message):
		print 'received an error %s' % message

	def on_message(self, headers, message):
		print 'received a message %s' % message
#		print headers['message-id']
#		sys.exit(0)
		conn.ack({'message-id':headers['message-id']})

dest = '/queue/test1'
logging.basicConfig()

conn = stomp.Connection([('172.16.1.217', 61612)])
conn.set_listener('', MyListener())
conn.start()
conn.connect(wait=True)
conn.subscribe(destination=dest, ack='client')

while True:
	try:
		time.sleep(1)
	except:
		break

4. python-memcached的demo程序

import time,memcache,pickle,cPickle,sys #,msgpack

f = file("/tmp/ids", 'r')
mc = memcache.Client(["172.16.1.217:11211"])
#count = 0
#for i in range(1,10000):
#	if mc.get("content-%s"%str(i)) != None:
#		count += 1
#		f.write("%s\n"%str(i))
#	if count >= 1000:
#		break
#sys.exit(0)
id_list = [int(x.strip()) for x in f]
print id_list
start = time.time()
results = mc.get_multi(id_list, key_prefix="content-")
#for k,v in results.iteritems():
#	results[k] = cPickle.loads(v)
#	print v 
#	time.sleep(1)
#mc.set_multi(results,key_prefix="content-")
print "eats %s s"%str(time.time()-start)
print len(results)
下面是一个同时使用mq和memcached的demo:

#!/usr/bin/python
#
#

import sys
import os
import logging
import stomp
import time
import json,memcache

mc = memcache.Client(["172.16.1.217:11211"])

t = time.time()
tstart = time.strftime("%Y-%m-%d %H:%M:%S",time.localtime(t))
tstart += ".%03d" % ((t-int(t))*1000)

start = time.time()
maxaid = 10000
conn = stomp.Connection([('172.16.1.217', 61612)])
dest = '/queue/test_worker_2'
conn.start()
conn.connect(wait=True)

for item in ['title','content','tag','cate','baike']:
	for i in range(1,25666):
		if mc.get(item+"-"+str(i)) == None:
			task = {'id':str(time.time()),'pid':'','start_at':tstart,
				'type':"parse_"+item,'from':i,'to':i}
			conn.send(json.write(task), destination=dest)

conn.disconnect()


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 30
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 30
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值