- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试创建一个 WCF 服务,其中数千(~10,000)个客户端可以通过双工 NetTcpBinding 连接很长一段时间(几周,也许几个月)。
经过一些阅读,看起来托管在 IIS 中比自定义应用程序或 Windows 服务更好。
将 WCF 用于此类服务是否可以接受,甚至可能?如果是这样,我会在哪里遇到限制或性能问题,例如增加 WCF ListenBacklog 和 MaxConcurrentConnections?
谢谢!
最佳答案
为什么您需要将打开的连接保持数周/数月?这将引入很多复杂性、超时处理、错误处理、重新创建连接等。我什至怀疑这是否可行。
Net.tcp 连接使用传输 session 导致 WCF 服务的 PerSession
实例化 - 单个服务实例服务器所有请求并在整个 session 期间(在您的情况下为数周或数月) = instance and whole 它的内容仍然在内存中。任何中断或未处理的异常都会中断 channel 并关闭 session = 所有 session 的本地数据都将丢失,客户端必须创建新代理才能再次启动新 session 。此外,任何超时(默认为 20 分钟不活动)都将关闭 session 。最后 - 根据业务逻辑的复杂性,您会发现即使有数百个客户端需要同时处理,单个服务器也无法为所有客户端提供服务,并且一些客户端会超时(再次中断 session )。允许使用 net.tcp 进行负载平衡需要具有粘性 session ( session 亲和性)的负载平衡算法,整个体系结构变得更加复杂和脆弱。 net.tcp 中的可伸缩性意味着服务可以部署在多个服务器上,但整个客户端 session 必须由单个服务器处理(如果服务器死掉,服务器服务的所有 session 也会死掉)。
在 IIS/WAS/AppFabric 中托管有几个优势,其中两个是健康监控和进程回收。健康监控持续检查工作进程是否仍然存在并且可以处理请求 - 如果它不存在,它会静默启动新的工作进程并将新的传入请求路由到该进程。进程回收定期回收(默认设置为 29 小时后)应用程序域,使进程健康并减少内存泄漏。副作用是重新创建进程或应用程序域都会终止所有 session 。一旦您自行托管服务,您将失去所有服务,因此您必须自己处理服务的健康状况。
编辑:
恕我直言,健康状态信息不必通过 TCP 发送。那是不需要所有花哨的东西的信息。如果你丢失了一些信息,它不会影响任何东西 = 你可以使用 UDP 进行健康状态传输。
当使用 TCP 时,您不需要为了保持连接打开而保持代理/ session 打开。关闭代理时,TCP 连接不会立即关闭。它在池中保持打开状态很短的时间,如果任何其他代理需要连接到同一服务器,它会被重用(池中的默认空闲超时应为 2 分钟)- I discussed Net.Tcp transport in WCF in another answer .
我不喜欢回调——WCF 中的整个概念都被过度使用和滥用了。保持 10.000 个 TCP 连接打开几个月,以防有时能够将数据发送回几台 PC,这听起来很荒谬。如果你需要和 PC 通信,暴露 PC 上的服务,当你需要发送一些命令时调用它。只需添加在PC启动和PC即将关闭时调用服务器的功能+添加传输监控信息。
无论如何,每分钟有 10,000 台 PC 发送信息 - 这可能会导致您同时收到 10,000 个请求 - 它的效果与拒绝服务攻击相同。根据处理时间,您的服务器可能无法处理它们,许多请求将超时。您还可以考虑一些消息队列或发布-订阅协议(protocol)。消息将传递到队列或主题,服务器将持续处理它们。
关于c# - 是否可以创建具有数千个长时间运行的 TCP 连接的可伸缩 WCF 服务?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6234192/
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 服务启动了我的订阅者,然后继续发布我的发布者的帖子。我的订阅者能够收到帖子。 其次,我关闭了我的第一个订阅者并再次打开它以订阅相同的服务,即所谓的已订阅该服务的第二个订阅者。再一
我是一名优秀的程序员,十分优秀!