本文整理匯總了Python中channel.Channel.read方法的典型用法代碼示例。如果您正苦於以下問題:Python Channel.read方法的具體用法?Python Channel.read怎麽用?Python Channel.read使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類channel.Channel
的用法示例。
在下文中一共展示了Channel.read方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: MQStar
# 需要導入模塊: from channel import Channel [as 別名]
# 或者: from channel.Channel import read [as 別名]
class MQStar():
""" MQStar is a Message Queue with a star topology. There's a server and multiple clients.
Each mqstar is identified by a session, which is the name of the underlining redis channels.
A server can send messages to clients on different channels, but receives answers on one channel: channel_to_server
"""
session = ""
channels = {}
"""MQStar is a MessageQueue with a star topology based on Redis"""
def __init__(self, host, session=None):
self.host = host
if not session:
self.session = id_generator()
else:
self.session = session
self.set_session(session)
def set_session(self, session):
channel_server = "MQ_%s_to_server" % self.session
self.channel_to_server = Channel(self.host, channel_server)
def _make_channel(self, frm="server", to="server"):
name = "MQ_%s_%s_%s" % (self.session, frm, to)
channel = Channel(self.host, name)
return channel
def notify_connection(self, av):
logging.debug("notify_connection %s" % av)
redis = self.channel_to_server.redis
name = "MQ_%s_connection" % (self.session)
redis.sadd(name,av)
def reset_connection(self, av):
logging.debug("reset_connection %s" % av)
redis = self.channel_to_server.redis
name = "MQ_%s_connection" % (self.session)
redis.srem(name,av)
def check_connection(self, av):
logging.debug("check_connection %s" % av)
redis = self.channel_to_server.redis
name = "MQ_%s_connection" % (self.session)
return redis.sismember(name,av)
def clean(self, av=None):
""" Cleans all the redis keys related to the used channels
"""
if av:
key = "MQ_*_server_%s" % av
else:
key = "MQ_*"
for k in self.channel_to_server.redis.keys(key):
logging.debug(" MQ clean %s" % k)
self.channel_to_server.redis.delete(k)
#assert not self.channel_to_server.redis.keys("MQ_*")
def add_client(self, client):
if client not in self.channels.keys():
ch = self._make_channel(to=client)
#chRight = self.channelToServer
self.channels[client] = ch
def add_clients(self, clients):
for c in clients:
self.add_client(c)
def send_server(self, client, message):
if client not in self.channels.keys():
logging.debug(" MQ error, client not found")
ch = self.channel_to_server
payload = (client, message)
ch.write(payload)
def receive_server(self, blocking=False, timeout=10):
#logging.debug(" MQ receive_server")
payload = self.channel_to_server.read(blocking, timeout)
if not payload:
logging.error("TIMEOUT")
return None
p = re.compile("\('(\w+)', (.+)\)")
m = p.match(payload)
assert m, "wrong format: %s" % m
cmd, args = m.group(1), m.group(2)
#logging.debug(" MQ read: %s args: %s" % (str(cmd), str(args)))
#client, message = payload
return cmd, args
def send_client(self, client, message):
if client not in self.channels.keys():
logging.debug(" MQ error, sendClient, client not found: %s" %
self.channels)
ch = self.channels[client]
ch.write(message)
#.........這裏部分代碼省略.........