- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
由于这是一个很长的问题,因此悬崖音节优先。
悬崖笔记:
一个客户端将输入发送到多个服务,它们继续工作并发送结果,直到客户端告诉它们停止或达到预设的最大结果数为止。
您是否知道应该如何实现这一目标,或者您有Cth示例作为示例?像这样? WCF和流式传输是否适合此工具集? (考虑到结果是自定义对象,因此与流式传输文件并不完全相同)
更详细的问题定义:
情况:
我可以完全控制客户端和服务的代码(现在不依赖于封闭的第三方)
一切都在C#中
我们有一个客户想要完成一项任务,并为此提供了若干平等的独立服务。
(等于=等于服务软件,运行每个服务的硬件可能会有所不同->服务速度可能会有所不同)
一项任务由“ 1000项工作”组成,它们彼此独立。
在一项任务中,所有1000项工作都基于相同的输入数据。
我提到解决方案A + B,因为我认为它们有助于解释问题:
解决方案(A)-慢速非并行方式:
1.客户端将输入发送到一项服务。
2.服务根据输入进行初始化。
3.服务处理所有1000项工作
(结果相加(超级快),所以1000件作品的结果与一个结果的大小相同)
4.服务将结果发送给客户端。
5.客户收到结果并感到高兴
解决方案(B)-并行更快的方法:
假设有十个服务,因此我们将其平均分配,每个应处理100个。
问题在于某些服务可能比其他服务快得多,因此给每个服务相同的数量(100)比
必要。
此外,由于一项服务的速度会发生变化,因此我们无法根据先验速度测试进行细分
有些甚至在处理过程中可能会失败,这就是为什么我认为以下对我而言是最佳的原因。
解决方案(C)-我想要实现的方式:
客户端向所有服务发出相同的请求。 (相同的请求仍然意味着要并行处理任务,对于我的问题,并行化非常容易,因为1000项工作是如此独立,以至于完成“第一”项工作的1000倍就意味着我们完成了工作)
服务会一直工作并发送结果,直到被告知停止或已处理1000件工作为止。
完成10项工作后,将发送一份结果。
这意味着所有服务并行执行任务,并且当客户端从所有服务答复中获得1000个结果的总和时,它将发送停止信号。
这意味着通常没有任何一项服务应该达到1000,但是有了1000,我们就可以解决只有一项服务的情况,并且我们具有故障保护功能,可以避免在停止信号丢失时发生无限循环。 (客户无需等待也不必绝对确定停止信号已到达服务)
放弃超出我们的1000个目标的其他结果就可以了。
(替代方法是对响应速度比其他响应速度更快的服务提出后续请求
由于来回的消息和额外的初始化而浪费时间。
(可以避免添加init,但这会很复杂,您还有其他开销))
我基本上有解决方案/会知道如何实现A + B,但是我不知道如何实现(C)。
您如何在C#中实现客户端/服务体系结构,使服务不断发送结果,而不仅仅是返回一个对象/值? (结果是自定义对象,顺便说一句)
有人知道某处的C#示例代码。像这样实现?流媒体是正确的方法吗?
我已经找到了"writing a custom stream"-示例,但从那里到我想要的似乎似乎还有很长的路要走。 (作为WCF菜鸟,我在这方面很容易出错。)
最佳答案
WCF中的流无法以打开流,将流返回给客户端的方式工作,并且服务仍将为流生成结果。如果要以这种方式工作,则必须更深入并直接使用套接字。在WCF中,必须先将流写入,然后再从操作中将其返回(我试图从其他线程写入返回的流,但它不起作用)。 WCF中的流仅用于数据传输。
我不喜欢您的任何解决方案。我会尝试:
B的变体。但是任务不会在前期平均分配。如果您有10个服务和1000个任务,则仅在该服务返回结果后才发送另一个任务,才发送前10个任务(每个任务到一个服务)。如果任务可以在合理的时间内完成,则只需要对服务进行多个异步调用即可等待响应。如果任何服务将无法在定义的超时时间内完成任务,则您会将任务发送给另一服务。如果任务可以快速完成,则可以发送小批量而不是单个任务。如果任务完成需要很长时间,则需要双工通信。
使用事务性消息队列-MSMQ。您的客户端将生成1000条消息到“生产者队列”,服务将一一处理这些消息并进行处理。它们将结果作为消息发送到另一个“消费者队列”,客户端将在其中获取结果并对其进行处理(每个结果必须与任务相关)。事务性队列将确保每个任务只能由单个服务处理,但是如果服务失败或事务超时,则该任务将可用于其他服务。 MSMQ还提供了一些其他功能,例如用于错误任务的队列等。这是高级场景。这种情况下的主要问题可能是邮件大小的限制(每条邮件最大4MB)。
编辑:
好的,因为您的澄清,看来您需要将同一任务发送到多个服务,并且该任务只会触发对同一数据的一系列相同计算。您可以通过以下方式实现:
使用Net.tcp绑定构建双工服务
服务将实现服务合同,该合同将具有开始计算和停止计算的操作(可以使用IsInitiating
的IsTerminating
和OperationContract
属性)
服务将在启动操作中启动的单独线程中进行计算
停止操作将中止计算线程
客户将实施回调合同以接收来自服务的结果
当处理线程有结果(或多个结果)发回时,服务将调用客户端回调
Here是将双工服务与WsDualHttpBinding
一起使用的示例-请勿在您的方案中使用此绑定,因为如果要让单个客户端通过双工HTTP与多个相同的服务进行通信会更加复杂。
关于c# - WCF-C#服务应连续发送结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6318179/
WCF 服务、WCF RIA 服务和 WCF 数据服务之间有什么区别? 最佳答案 WCF 是一般服务的通信基础设施。 WCF RIA 服务自动生成客户端和服务器代理对象以方便应用程序开发,并依赖 WC
我想在我的 WPF 项目中使用 WCF 服务 (.svc)。, 我正在尝试创建一个服务。但在 Visual Studio 中,我们有“WCF 服务库”和“WCF 服务应用程序”。我两个都试了。 当我们
我正在开发 WCF Web 服务,并使用 WCF 服务应用程序模板来执行此操作。 创建“WCF 服务应用程序”是否满足此要求?与 WCF 服务应用程序相比,创建 WCF 服务库有哪些优势? 最佳答案
我是 WCF 的新手,对 Web 服务进行编码的经验有限。 在工作中,所有面向网络服务的事物都被要求使用 WCF。我需要做的工作涉及查询一个非 WCF Web 服务,该服务显然是用 Java 构建的,
我有一个数据契约(Contract)说用户。它是可序列化的并且可以通过网络传输。我想要一个操作契约(Contract) SaveUser()。我可以将 SaveUser(User user) 作为运营
我一直在开发一个使用 WCF 访问服务器端逻辑和数据库的 WPF 应用程序。 我从一个 WCF 客户端代理对象开始,我反复使用它来调用服务器上的方法。使用代理一段时间后,服务器最终会抛出异常: Sys
不要添加关于不同 WCF 堆栈的另一篇 SO 帖子,但我想在浪费更多开发时间之前确保我朝着正确的方向前进...... 我的场景 - 我们公司有许多 Web 应用程序,它们都访问同一系列的数据库。所有应
我是WCF技术的新手,我想知道RESTful WCF服务和普通WCF服务有什么区别。 RESTful 服务相对于普通 WCF 服务有哪些优势? 谢谢。 最佳答案 REST服务基于HTTP协议(prot
我正在构建的应用程序公开了多个 WCF 服务(A、B)。在内部,它消耗了在我们的内部网络(X、Y)上运行的其他几个 WCF 服务。 使用 WCF 消息日志记录,我希望仅记录我们的服务 A、B 与调用它
我们需要从另一个 WCF 服务调用 WCF 服务。为了测试这一点,我构建了一个示例控制台应用程序来显示一个简单的字符串。设置是: 控制台应用程序 -> WCF 服务 1 -> WCF 服务 2 Con
假设永远不会直接查询数据的情况。 AKA,总会有一些必须发生的过滤逻辑和/或业务逻辑。 什么时候是在 ajax/js 之外使用数据服务的好理由? 请不要访问此页面 http://msdn.micros
我在尝试将所有常规 WCF 调用转换为异步 WCF 调用时遇到问题。我发现我重构了很多代码,但不确定具体该怎么做。我使用了我找到的方法 here但遇到了我需要事情按顺序发生的问题。 private v
我在 IIS 上有一个 WCF 服务,一些 .net Web 应用程序正在使用它。我的任务是编写一个新的 WCF 服务,要求现有的 Web 应用程序可以使用新服务而无需更改它们的 web.config
我正在尝试用外部提供 WSDL 的 WCF 等效服务替换 WSE 服务。 首先,我使用 svcutil 和 wsdl 生成所有服务和客户端类(ATP,我只关心服务实现。)我生成了一个空的 WCF 服务
场景是这样的:有2个WCF Web Services,一个是客户端(WCFClient),一个是服务端(WCFServer),部署在不同的机器上。我需要他们两个之间的证书通信。 在服务器 WCF 上,
我在 Visual Studio 2013 中创建一个 WCF 服务并将其发布到 IIS。我可以在另一个项目中添加服务引用并使用该服务的方法。当我转到 IIS 服务器管理器时,我看到 WCF 激活及其
我是 .net 的新手,对 WCF 知之甚少,如果有任何愚蠢的问题,请耐心等待。我想知道如果我的代码没有显式生成任何线程,WCF 如何处理 SELF-HOST 场景中的同时调用。因此,在阅读了很多关于
我正在为应用程序开发一个面向服务的体系结构,我希望这些服务既可以通过 WCF 公开,也可以通过一个简单的库使用。理想情况下,我想减少重复代码。 从概念上讲,这映射到: Client => WCF Se
我有一个小型测试网络服务来模拟我在现实世界应用程序中注意到的一些奇怪的东西。由于演示显示与应用程序相同的行为,为了简洁起见,我将使用演示。 简而言之,我的服务接口(interface)文件如下所示(您
我首先为我的 WCF 服务启动了我的订阅者,然后继续发布我的发布者的帖子。我的订阅者能够收到帖子。 其次,我关闭了我的第一个订阅者并再次打开它以订阅相同的服务,即所谓的已订阅该服务的第二个订阅者。再一
我是一名优秀的程序员,十分优秀!