gpt4 book ai didi

wcf - 可扩展(插件/插件)WCF 服务主机的想法?

转载 作者:行者123 更新时间:2023-12-05 00:44:16 33 4
gpt4 key购买 nike

我正在寻找有关如何构建可扩展 WCF 服务器(具有动态加载的服务)的建议,最好使用 System.Addins 或 MEF。

服务器应托管实现最小“插件”API(StartService/StopService/GetStatus?/etc)的任何 WCF 服务(包含在 DLL 程序集中,在运行时加载)。

This post是一个好的开始。一些要讨论的目标和要点:

  • 为每个服务使用/不使用隔离的 AppDomain?
  • 如何配置每个服务(端点、传输协议(protocol))? XML-config 文件还是更好的选择?
  • 程序集的延迟/延迟加载(当服务请求到达时)?可能的?有用?如何?
  • 磁盘上的文件更改时重新加载程序集(对开发环境有用);
  • 磁盘配置更改时服务重启;

  • 当然,其他想法总是受欢迎的;)

    最佳答案

  • 是的,使用独立的 AppDomain 对于每项服务。您需要AppDomain隔离,这样您就不会关闭正在运行的其他服务,以防万一出现故障。
  • 提供 WCF 当前所做的所有方式,无论是通过编程还是通过配置。程序访问很困难,因为 ServiceHost 实例不可序列化,因此跨应用程序域边界获取信息将是一件痛苦的事。
  • 我会说这是可能的。但是,这基本上是在复制 Windows Process Activation Service ,所以你可能想开始在那里寻找你的功能。
  • 它对开发很有帮助,但老实说,我不认为它有那么重要的功能。它使您的代码复杂化以获得不太可衡量的 yield (IMO)。我宁愿编写一个脚本来停止服务、复制文件并重新启动它,而不是使代码库过于复杂并且总是不得不观察程序集。
  • 现在你在谈论 IIS。您基本上可以让 IIS 托管您的服务,它会在配置文件更改时回收它。

  • 话虽如此,似乎 WAS 和 IIS 为您提供了您想要的大部分内容(高度可用、隔离的应用程序域、配置等),因此您可能想问为什么要自己做这件事。

    关于wcf - 可扩展(插件/插件)WCF 服务主机的想法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/277028/

    33 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com