繁体   English   中英

服务器应该如何将数据推送到富客户端

[英]How should server push data to rich client

我正在编写一个简单的会计程序,包括几个C#winform客户端和一个将数据读/写到数据库中的java服务器应用程序。 其中一个要求是所有C#客户端都应该从服务器接收更新。 例如,如果用户a从其C#客户端创建新发票,则其他用户应从其客户端看到此新发票。

我的经验主要是Web开发,我不知道用C#s客户端和Java servlet服务器满足这个要求的最佳方法是什么。

我最初的目的是使用Glassfish运行ActiveMQ并使用消息传递pub / sub方法,以便可以将更新推送到C#客户端。 我将创建不同的主题,如newInvoice,cancelInvoice等,以区分消息类型。 每条消息都只包含以JSON编码的对象。

但在我看来,这涉及到相当多的工作。 鉴于我的用户群非常小(只有3或4个并发用户),在我看来应该有一些更简单的解决方案。 (我不熟悉套接字编程:))

我知道这是一个客户端 - 服务器编程101个问题,但如果有经验的程序员可以指出我一些简单的解决方案,这将是很好的。

这里最简单的方法通常是简单地使用轮询 - 即让客户端每次(您的时间间隔)查询数据。 这避免了一系列问题(防火墙,安全性,视线,分辨率,客户端跟踪等)。

使用WCF,您可以在双工通道上进行回调(允许服务器主动向客户端发送消息),但这更复杂。 我重视简单,所以我通常只是轮询。

在这里有所帮助的技巧是设计系统以具有用于查询“自x以来的变化”的内置机制 - 例如,可能由数据库触发器提供的审计表。 当然,具体细节因项目而异。

您可能想要查看的另一个选项是ADO.NET Sync Services; 这可以满足您的要求,保持数据库的本地副本与服务器保持同步 - 但它有一些复杂性。 这在“本地数据库缓存”VS模板中可用(IIRC)。

您可能想看一下StreamHub Push Server--它是一个用Java编写的流行Comet服务器,它有一个.NET Client SDK,用于从C#中的服务器接收更新。 它还具有Java Client SDK和通常的Ajax / Comet Web浏览器支持,使您可以更灵活地将数据推送到Web,Java和C#客户端。

而不是将信息从服务器推送到1:N客户端,让客户端经常轮询服务器以进行更新是不是更容易? 或者当客户端启动并创建与服务器的连接时,服务器可以为该客户端连接动态生成新的消息队列,然后客户端可以轮询更新?

您可以使用几种推送技术,如ActiveMQ(如您所述)或XMPP。 但如果您只有3或4个客户关注自己,那么轮询将是最简单的解决方案。 它不能很好地扩展,但在你的情况下这不是一个真正的问题,除非你的服务器是8086或8-)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM