我正在建立一个发布金融工具价格的系统。有些仪器每秒更新几次,其中一些更新频率更低。无论更新频率如何,所有订户都需要查看该工具的最新更新或当前价格。
订阅者可能会等待一段时间才能看到所有主题的主题更新,让他们对较慢主题的查看为空。我可以使用SessionPropertiesListener
收听新的受众群体成员,然后使用当前价格更新每个主题,但这会为现有受众群体产生很多的噪音,感觉就像尾巴一样摇着狗。
我可以通过缓慢更新的主题来说明我的问题:
#!/usr/local/bin/node
var diffusion = require('diffusion');
const diffHost = "localhost";
const exampleTopic = "some/counter";
diffusion.connect({
host : diffHost,
port: 8080,
secure: false,
principal : 'admin',
credentials : 'password',
}).then(function(session) {
console.log('Connected to %s', diffHost);
var count = 0;
session.topics.add(exampleTopic).then(function(result) {
console.log("Created %s", exampleTopic);
setInterval(function() {
session.topics.update(exampleTopic, ++count);
console.log("Updated %s to %d", exampleTopic, count);
}, 5000);
}, function(error) {
console.log('Topic add failed: ', error);
});
});
任何订阅some/counter
的人都会在看到任何内容之前平均等待2.5秒。我觉得我在这里错过了一个技巧,我怎样才能确保订户在订阅后立即有效地获得当前价格?
答案 0 :(得分:1)
您的主题some/counter
是无状态的,这解释了为什么新订阅者在更新之前不会收到任何内容。而不是创建您的主题:
session.topics.add(exampleTopic)
将其替换为:
session.topics.add(exampleTopic, count)
..创建一个州 ful 主题。