我正在设计一个Perl的多层应用程序,我想知道各种IPC机制的优缺点.我正在考虑处理中等大小的数据,通常是几十千字节,但高达几兆字节,负载非常轻,每分钟最多几百个请求.

我主要关注的是可维护性和性能(按此顺序).我不认为我需要扩展到多个服务器,或者从我们的主平台(RHEL)移植,但我认为这是需要考虑的事情.

我可以想到以下选项:

>临时文件 – 简单,可能是速度和存储要求方面最糟糕的选择
> UNIX域套接字 – 不可移植,不可扩展
>互联网套接字 – 便携,可扩展
>管道 – 便携式,不可扩展(?)

考虑到可扩展性和可移植性不是我主要关注的问题,我需要了解更多信息.什么是最好的选择,为什么?如果您需要其他信息,请发表评论.

编辑:我将尝试提供更多细节以回应ysth’s questions(警告,文本墙随后):

>读者/作者是一对一的关系,还是更复杂的东西?
>如果读者不再在那里或忙碌,你想对作家发生什么?
>反之亦然?
>您对所需用途有哪些其他信息?

在这一点上,我正在考虑采用三层方法,但我不确定每层中有多少个进程.我认为我需要在左侧有更多的流程,在右侧有更少的流程,但也许我应该全面拥有相同的数字:

 .---------.          .----------.        .-------.
 | Request |  ----->  | Business | -----> | Data  |
 | Manager |  <-----  |  Logic   | <----- | Layer |
 `---------'          `----------'        `-------'

这些名称仍然是通用的,可能不会以这些形式进入实现.

请求管理器负责监听来自不同接口的请求,例如Web请求和CLI(响应时间很重要)和电子邮件(响应时间不太重要).它执行日志记录并管理对请求的响应(以适合请求类型的格式呈现).

它将有关请求的数据发送到业务逻辑,业务逻辑根据业务规则执行日志记录,授权等.

业务逻辑(如果需要)然后从数据层请求数据,数据层可以与(最常见的)内部MysqL数据库或我们团队控制之外的某些其他数据源(例如,我们组织的主LDAP服务器,或我们的DB2员工信息数据库等).这主要是一个包装器,它以统一的方式格式化数据,以便在业务逻辑中更容易处理.

然后,该信息将流回请求管理器以进行演示.

如果,当数据向右流动时,阅读器正忙,对于交互式请求,我只想等待一段合适的时间,如果我在这段时间内无法访问,则返回超时错误(例如“稍后再试”).对于非交互式请求(例如电子邮件),轮询系统可以简单地退出并在下次调用时再次尝试(可能每1-3分钟一次).

当数据向另一个方向流动时,不应有任何等待情况.如果其中一个进程在尝试返回左侧时已经死亡,我所能做的就是登录并退出.

无论如何,这是非常冗长的,因为我还处于早期设计阶段,我可能仍然有一些混乱的想法.我提到的一些内容可能与使用哪种IPC系统的问题相关.我对设计的其他建议持开放态度,但我试图将问题限制在范围内(例如,也许我应该考虑折叠到两层,这对IPC来说要简单得多).你的想法是什么?

解决方法

临时文件(以及相关内容,如共享内存区域)可能是一个不好的选择.如果您想在一台计算机上运行服务器而在另一台计算机上运行客户端,则需要重写应用程序.如果您选择任何其他选项,至少语义基本相同,如果您需要在以后切换它们.

不过,我唯一真正的建议是不要自己写这个.在服务器端,您应该使用POE(或Coro等),而不是自己选择套接字.此外,如果您的接口将是RPC-ish,请使用CPAN中的JSON-RPC-Common/.

最后,有IPC :: PubSub,它可能适合你.

Perl中中型数据的最佳IPC机制是什么?的更多相关文章

  1. ios – 从不兼容类型’ViewController * const__strong’分配给’id’

    我的应用程序中有一个ImagePickerController.它效果很好,但除了ipc.delegate=self之外;出现错误消息:Assigningto‘id’fromincompatibletype‘ViewController*const__strong’该应用程序运行良好,所以我忽略了错误消息,但我想我需要知道原因.为什么会出现错误消息?解决方法如果你看一下UIImagePickerC

  2. android – 来自Parcel.readException的NullPointerException(等)

    解决方法这里发生的是readException()正在检查IPC字节流中是否有一个标题,表明发生了异常;如果它找到一个,那么它会抛出该类型的新异常,并使用相同的消息,但是缺少原始堆栈跟踪.那么最初的例外来自哪里?

  3. Android IPC机制ACtivity绑定Service通信代码实例

    这篇文章主要介绍了Android IPC机制ACtivity绑定Service通信代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

  4. 浅谈并发处理PHP进程间通信之System V IPC

    对于进程间通信,每一个完备的语言都应该有对应的处理方式,而 PHP 对应的则是一族对 UNIX SYSTEM V包装的函数,包括信号量(semaphore)、共享内存(shared memory)和消息队列(msg queue)的操作。

  5. Android中Binder IPC机制介绍

    大家好,本篇文章主要讲的是Android中Binder IPC机制介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览

  6. 浅谈Android IPC机制之Binder的工作机制

    IPC机制即为跨进程通信,是inter-Process Communication的缩写。是指两个进程之间进行通信。在说进程通信之前,我们的弄明白什么是线程,什么是进程。进程和线程是两个截然不同的概念。本文将介绍Android IPC机制之Binder的工作机制。

  7. 如何使用boost连接到另一个进程的控制台

    Ferst进程创建控制台窗口,第二个进程将在Ferst进程控制台中打印一些simbol。如果我使用WinApi,我有AttachConsole函数,是否可以使用boost执行类似的操作?进程间库和进程库具有附加到进程的功能,但我不知道如何将一个控制台用于两个进程。使用boost::asio可能可以做类似的事情,但我认为这不是我需要的

  8. Windows尝试在提供的之前访问IPC $共享

    我有一个samba服务器,我出于安全原因(用户和共享枚举,用户信息查询,…或者至少如何在IPC$one返回Access拒绝后强制Windows访问真实共享?提前感谢您的帮助和节日快乐!海绵宝宝[1]https://www.samba.org/samba/docs/man/Samba-HOWTO-Collection/securing-samba.html#id2618877所以我的问题是如何阻止Windows执行这个无用的请求……?或者至少我怎么能强迫Windows访问真正的份额后…?答案是,你做不到!

  9. 窗口 – 管道输出(stdout)从运行进程Win32Api

    我需要使用windowsapi获取(或管道)已经运行的进程的输出.基本上我的应用程序应该允许用户选择一个窗口来管道输入,所有输入将显示在控制台中.我也会考虑如何在stderr之后得到一个管道.重要提示:我没有使用CreateProcess()或其他方式启动该过程.该进程已经在运行,我所有的都是进程的句柄(从GetwindowThreadProcessId()返回).无论你想做什么,你都做错了.如果

  10. windows-mobile – Windows Mobile上的简易IPC?

    在WindowsMobile上的C项目(即没有.NET)中,我正在寻找一种在两个独立运行的应用程序之间轻松通信的方法.应用程序A将运行服务,而应用程序B将为用户提供一些功能–B必须为其调用A的某些功能.我宁愿不在COM中实现任何东西.事实上,我宁愿不做任何类型的序列化或类似(即这将排除使用套接字/管道/文件),而是让B将所有参数和指针传递给A,就像A是B的一部分一样.此外,应用程序C,D和E应该能

随机推荐

  1. 数组 – Perl中有什么神奇的数组?

    在Perldocumentationforreverse中,我发现:“请注意,将数组反转到自身(如@a=reverse@a)将尽可能保留不存在的元素;即对于非魔法数组或具有EXISTS和DELETE方法的绑定数组.什么属性区分神奇和非魔法阵列?解决方法一个神奇的阵列是一个执行它的操作不仅仅是改变内容.只有内置的魔术阵列是@ISA,而且这是非常不明显的.正如句子所暗示的,魔术阵列主要是一个绑定的阵列

  2. perl – 使用“isa”方法的最佳方式?

    什么是“最好的”使用方式“isa()”可靠?解决方法Scalar::Util实现明确更好.它避免了eval{}的开销,它总是导致设置一个附加变量.Scalar::Util实现更容易阅读.如果eval也失败了,我相信发生的是你在树之前向后走到eval之前的状态–这是如何实现复位状态.这带来了额外的故障开销.基准根本不是一个对象对象传递isa检查对象出现故障现象检查测试代码:我使用这是为i486-linux-gnu-thread-multi建立的perl,v5.10.1(*),以及Scalar::Util,1

  3. 在CORE :: GLOBAL中哪些Perl内置函数不能被覆盖?

    解决方法toke.c中任何值为负的值都可以被覆盖;所有其他人可能不会.你可以看源码here.例如,我们来看看第10,396行的waitpid:由于waitpid为负数,因此可能会被覆盖.grep怎么样?这是积极的,所以不能被覆盖.这意味着以下关键字不能被覆盖:chop,defined,delete,do,dump,each,else,elsif,eval,exists,for,foreach,format,glob,goto,grep,if,keys,last,local,m,map,my,next,no

  4. 如何在Perl中打印由换行符分隔的列表元素?

    什么是最简单的打印所有列表的元素以Perl中的换行符分隔的元素?解决方法在Perl5.10中:其他方式:或:或者怎么样?

  5. 使用Perl如何获取文件大小(以兆字节为单位)?

    我想以磁盘的形式获取磁盘上的文件大小.使用-s运算符给出了以字节为单位的大小,但是我将假设,然后将其除以魔术数字是一个坏主意:我应该使用只读变量来定义1024,还是有一种编程方式来获取一千字节的字节数?

  6. perl – 如何测试/分类CPAN模块的utf8正确性

    例如:File::Slurp,如果你将读取该文件您将根据命令行开关获得不同的结果,并且perl-CSDA将无法正常工作.伤心.(是的,我知道比Encode::decode(“utf8”,read_file($file,binmode=>’:raw’));将帮助,但是SAD.我的问题:>在这里任何首选方式,如何测试/分类什么CPAN模块是utf8安全/准备/正确?>这里是像Perl::Criticforutf8这样的东西–什么将检查模块源可能的utf8不正确?总结以上是DEVMAX为你收集整理的perl–如

  7. 如何删除Perl字符串中的空格?

    如果我声明一个值为’3’的变量$myString.是否有任何功能来删除返回值的空格.有点像SomeFun然后返回’3′.输出:你可以注意到’vid’=>‘0’,上面的代码从theanswer.我正在研究它.总结以上是DEVMAX为你收集整理的如何删除Perl字符串中的空格?如果觉得DEVMAX网站内容还不错,欢迎将DEVMAX网站推荐给好友。

  8. 如何在mod_perl2下运行Devel :: Cover?

    Unfortunately,Devel::Coverdoesnotyetworkwiththreads.它也不适用于prefork.在startup.pl中使用,Devel::Cover问题perl5.8.9,Apache2.2.13.我的操作系统是FreeBSD,如果重要.同样的问题是reportedforwin32.更新:PerlTrace全部输出解决方法邪恶之源似乎是Apache::DBI.

  9. 如何使用Perl中的C类?

    我有一套用C写的课.从Perl脚本中调用它们的最佳方法是什么?

  10. perl – 在Emacs中以双模式更好的缩进

    我正在使用Emacs来修改Perl和Verilog交织的代码.我正在使用two-mode-mode在两者之间切换,这样可以预期.问题是perl代码与//一行一行地表示;如下图所示:而双模式则认识到它是Perl,它是逐行的,所以缩进等在线上无意义.我想做的是使Perl代码像往常一样格式化,但忽略//;字符.有什么想法吗?我刚刚开始偷看模式文件,它们是可以理解的复杂的,所以任何提示都不会感激!

返回
顶部