我正在尝试用signalR构建一个应用程序.申请大纲将是:
>从数据库加载初始状态
>订阅成功的消息
我一直在寻找一套最佳实践.如果我在初始加载后订阅更新,则存在丢失更新的风险.在初始加载和订阅之间可能会有更新,我会错过更新.
其次,我可以使用某种对象状态id,然后首先订阅更新流,检索数据,然后在对象落后时应用更新.这需要相当多的代码.
有没有最好的做法来处理这个问题?
解决方法:
根据您查询更新的时间,可能会出现错过.例如,假设您的后端查询某些通知并将其推送到客户端,然后用户连接(订阅)通知 – 如果在此初始化阶段发送更新并且错过了您推送的原始数据集可能是陈旧的.
作为最佳做法,我发现废弃发送任何初始数据.相反,请尽快订阅并查询成功连接的更新.例如….
var proxy = $.connection.yourHub;
$.connection.hub.start()
.done(function () { // <--- immediately call once connected
// define and call server hub method
// this will query updates and immediately
// invoke the associated client function
proxy.server.queryUpdates();
})
.fail(function () {
console.log('Could not connect!');
});
proxy.client.serveUpdates = function(updates) {
// here's your fetched updates on initial connect
}
// YourHub.cs
public void QueryUpdates()
{
var updates = this.yourService.yourQueryUpdatesmethod();
Clients.Caller.serveUpdates(updates) // this calls proxy.client.serveUpdates
}
这为您提供了建立连接,监听更新以及在连接时以一次性方式有效提供最新数据集的好处.
请注意,这不一定是SignalR特定的实现.您可以在此.done()回调中进行典型的ajax调用以检索结果,但我不明白为什么您无法重新使用集线器上已有的所有逻辑.您基本上可以通过从客户端显式调用它来调用现有的集线器方法.