如何在必要时实现可以将消息"推送"到客户端的系统?基本上,我需要的是能够从Python服务器"推送"文本到Python客户端.然后将文本解析为将在客户端处理的操作(一旦收到'action-text',我已经知道如何做这件事).我可以每隔几秒检查一下正在等待的新"动作文本" - 我认为这对于成千上万的客户来说并不可靠且可扩展.实时的事情在这里非常重要.
有什么建议吗?
您可以在此处更多地使用redis发布订阅模型.
Redis具有高度可扩展性和快速性.
示例:(来自https://github.com/andymccurdy/redis-py/blob/master/tests/pubsub.py)
import redis
import unittest
class PubSubTestCase(unittest.TestCase):
def setUp(self):
self.connection_pool = redis.ConnectionPool()
self.client = redis.Redis(connection_pool=self.connection_pool)
self.pubsub = self.client.pubsub()
def tearDown(self):
self.connection_pool.disconnect()
def test_channel_subscribe(self):
self.assertEquals(
self.pubsub.subscribe('foo'),
['subscribe', 'foo', 1]
)
self.assertEquals(self.client.publish('foo', 'hello foo'), 1)
self.assertEquals(
self.pubsub.listen().next(),
{
'type': 'message',
'pattern': None,
'channel': 'foo',
'data': 'hello foo'
}
)
self.assertEquals(
self.pubsub.unsubscribe('foo'),
['unsubscribe', 'foo', 0]
)
def test_pattern_subscribe(self):
self.assertEquals(
self.pubsub.psubscribe('fo*'),
['psubscribe', 'fo*', 1]
)
self.assertEquals(self.client.publish('foo', 'hello foo'), 1)
self.assertEquals(
self.pubsub.listen().next(),
{
'type': 'pmessage',
'pattern': 'fo*',
'channel': 'foo',
'data': 'hello foo'
}
)
self.assertEquals(
self.pubsub.punsubscribe('fo*'),
['punsubscribe', 'fo*', 0]
)
Run Code Online (Sandbox Code Playgroud)