草庐IT

C#/.NET : Reporting subprocess state to the parent service

coder 2024-06-11 原文

我目前有一个运行多个子进程的服务(使用 System.Diagnostics.Process)。每个子流程可以运行数小时并处于特定的预定义状态(想想“开始”、“工作”、“清理”等 - 完全预定义,无需报告附加到每个状态的自定义数据)。每个进程不能是单独的 Windows 服务(可能的状态比 Windows 服务状态多)。我需要以某种方式将此状态报告给父服务。所有进程都在同一台 Windows 机器上运行。

我需要能够从其他进程(不是由服务启动的进程)查询子进程状态,并更新有关来自这些子进程的每个子进程状态的父服务。每个进程都有一个唯一的 ID,因此其他进程可以轻松读取状态,而无需自己管理进程。所有进程共享一个配置文件,其中每个子进程都被分配了一个唯一的 ID 来标识自己。我考虑过这样做:

  • 将子进程的标准输出重定向到服务 (RedirectStandardOutput = true),读取输出中的每一行并捕获“特殊”行 (STATECHANGE:state)
  • 每当状态发生变化时,将所有子进程的状态写到预定义位置的文件中,并在服务退出时删除该文件。

看起来我正在尝试为很久以前解决的问题找到解决方案,但我还没有找到该解决方案。是否有任何“好的”方式来进行此类状态报告?

最佳答案

一般来说,您正在深入研究进程间通信或 IPC 领域。

虽然您没有将此问题标记为特定于 Microsoft Windows,但它被标记为 C# 和 .NET,因此您可能在 Windows 环境中运行。我的回答假设您在 MS Windows 中运行该系统。

解决此类问题的常见方法是将状态存储在数据库中。每个服务/进程都可以独立地写入数据库,然后任何对该信息感兴趣的进程都可以查询它。但这不是真正的双向通信。

关于父进程如何与子进程通信,这可以通过多种方式完成,但如果子进程在一个线程上运行某种消息泵并在另一个线程上执行数据处理,这可能是最简单的。消息泵将接收和响应消息,而数据处理线程将执行其操作。

使用此方案,可以通过多种不同方式交换消息,包括:

  • Windows 通信框架 (WCF)
  • 命名管道
  • .NET 远程处理
  • MS 消息队列 (MSMQ)
  • Windows 剪贴板
  • 动态数据交换 (DDE)
  • 组件对象模型 (COM)
  • 内存映射文件
  • 远程过程调用 (RPC)
  • socket

由于所有这些进程都在同一台机器上运行,因此管道是一个简单直接的选择。查看 System.IO.Pipes 命名空间

WCF 允许您构建丰富的消息传递接口(interface),该接口(interface)可以在管道以及其他 IPC 机制之上实现。

I'net 上有很多讨论 .NET 上的进程间通信的好资源,与其在这里重复这些内容,不如使用“.NET”、“进程间通信”、“IPC”等术语搜索这些资源”和“本地机器”(因为您需要在本地机器上的进程之间进行 IPC)。

关于C#/.NET : Reporting subprocess state to the parent service,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41496902/

有关C#/.NET : Reporting subprocess state to the parent service的更多相关文章

  1. ruby-on-rails - Ruby net/ldap 模块中的内存泄漏 - 2

    作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代

  2. ruby - 如何模拟 Net::HTTP::Post? - 2

    是的,我知道最好使用webmock,但我想知道如何在RSpec中模拟此方法:defmethod_to_testurl=URI.parseurireq=Net::HTTP::Post.newurl.pathres=Net::HTTP.start(url.host,url.port)do|http|http.requestreq,foo:1endresend这是RSpec:let(:uri){'http://example.com'}specify'HTTPcall'dohttp=mock:httpNet::HTTP.stub!(:start).and_yieldhttphttp.shou

  3. ruby - Net::HTTP 获取源代码和状态 - 2

    我目前正在使用以下方法获取页面的源代码:Net::HTTP.get(URI.parse(page.url))我还想获取HTTP状态,而无需发出第二个请求。有没有办法用另一种方法做到这一点?我一直在查看文档,但似乎找不到我要找的东西。 最佳答案 在我看来,除非您需要一些真正的低级访问或控制,否则最好使用Ruby的内置Open::URI模块:require'open-uri'io=open('http://www.example.org/')#=>#body=io.read[0,50]#=>"["200","OK"]io.base_ur

  4. Get https://registry-1.docker.io/v2/: net/http: request canceled while waiting - 2

    1.错误信息:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:requestcanceledwhilewaitingforconnection(Client.Timeoutexceededwhileawaitingheaders)或者:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:TLShandshaketimeout2.报错原因:docker使用的镜像网址默认为国外,下载容易超时,需要修改成国内镜像地址(首先阿里

  5. .net - .NET 将如何影响 Python 和 Ruby 应用程序? - 2

    我很好奇.NET将如何影响Python和Ruby应用程序。用IronPython/IronRuby编写的应用程序是否会非常特定于.NET环境,以至于它们实际上将变得特定于平台?如果他们不使用任何.NET功能,那么IronPython/IronRuby相对于非.NET同类产品的优势是什么? 最佳答案 我不能说任何关于IronRuby的东西,但是大多数Python实现(如IronPython、Jython和PyPy)都试图尽可能忠实于CPython实现。不过,IronPython正在迅速成为这方面的佼佼者之一,并且在PlanetPyth

  6. ruby - 如何使用 Ruby HTTP::Net 处理 404 错误? - 2

    我正在尝试解析网页,但有时会收到404错误。这是我用来获取网页的代码:result=Net::HTTP::getURI.parse(URI.escape(url))如何测试result是否为404错误代码? 最佳答案 像这样重写你的代码:uri=URI.parse(url)result=Net::HTTP.start(uri.host,uri.port){|http|http.get(uri.path)}putsresult.codeputsresult.body这将打印状态码和正文。

  7. .net - 是否有 Ruby .NET 编译器? - 2

    是否有适用于Ruby语言的.NETFramework编译器?我听说过DLR(动态语言运行时),这是否将使Ruby能够用于.NET开发? 最佳答案 IronRuby是Microsoft支持的项目,建立在动态语言运行时之上。 关于.net-是否有Ruby.NET编译器?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/199638/

  8. ruby - 使用 ruby​​ gem net-ssh-multi 同时在多个服务器上执行 sudo 命令 - 2

    在previousquestion中我想出了如何在多个服务器上启动经过密码验证的sshsession来运行单个命令。现在我需要能够执行“sudo”命令。问题是,net-ssh-multi没有分配sudo需要运行的伪终端(pty),导致以下错误:[127.0.0.1:stderr]sudo:sorry,youmusthaveattytorunsudo根据documentation,可以通过调用channel对象的方法来分配伪终端,但是,以下代码不起作用:它会生成上面的“notty”错误:require'net/ssh'require'net/ssh/multi'Net::SSH::Mul

  9. (附源码)vue3.0+.NET6实现聊天室(实时聊天SignalR) - 2

    参考文章搭建文章gitte源码在线体验可以注册两个号来测试演示图:一.整体介绍  介绍SignalR一种通讯模型Hub(中心模型,或者叫集线器模型),调用这个模型写好的方法,去发送消息。  内容有:    ①:Hub模型的方法介绍    ②:服务器端代码介绍    ③:前端vue3安装并调用后端方法    ④:聊天室样例整体流程:1、进入网站->调用连接SignalR的方法2、与好友发送消息->调用SignalR的自定义方法 前端通过,signalR内置方法.invoke()  去请求接口3、监听接受方法(渲染消息)通过new signalR.HubConnectionBuilder().on

  10. ruby - Net::SSH sudo 命令在输入密码后挂起 - 2

    我一直在尝试使用Thor编写一个小型库,以帮助我快速创建新项目和站点。我写了这个小方法:defssh(cmd)Net::SSH.start(server_ip,user,:port=>port)do|session|session.execcmdendend只是协助我在需要时在远程服务器上运行快速命令。问题是当我需要在远程端的sudo下运行命令时,脚本似乎卡在我身上。例如当执行这个...ssh("sudocp#{file_from_path}#{file_to_path}")脚本会提示我输入密码[sudo]passwordforuser:但是在输入之后整个事情就挂起。有人会碰巧知道它为

随机推荐