[发明专利]一种Erlang进程超时管理方法有效
申请号: | 202011408673.2 | 申请日: | 2020-12-04 |
公开(公告)号: | CN112527545B | 公开(公告)日: | 2022-04-29 |
发明(设计)人: | 汪兴 | 申请(专利权)人: | 厦门极致互动网络技术股份有限公司 |
主分类号: | G06F11/07 | 分类号: | G06F11/07 |
代理公司: | 厦门致群财富专利代理事务所(普通合伙) 35224 | 代理人: | 刘兆庆 |
地址: | 361000 福建省厦门市火*** | 国省代码: | 福建;35 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 erlang 进程 超时 管理 方法 | ||
本发明公开了一种Erlang进程超时管理方法,包括如下步骤:S1、创建与CPU的核心数目相等的N个超时监督进程;S2、每个超时监督进程启动时,创建一个有序的ets表;S3、使用代理函数作为待监督Erlang进程的入口,代理函数随机选择一个ets表,并在该ets表中放入进程执行到期时间end‑time和进程身份pid,形成主键{end‑time,pid};S4、代理函数执行真实入口点函数及参数;S5、每个超时监督进程以设定的间隔扫描出ets表中end‑time小于当前时间的主键,对该主键对应的进程身份pid执行结束操作,并从ets表中移除该主键;S6、代理函数移除主键为{end‑time,pid}的进程的超时数据。本发明提供了一种性能损耗极少、无单点瓶颈、充分利用多核CPU的进程超时监督方法,避免了死循环等异常进程对系统性能的毁灭性影响。
技术领域
本发明涉及计算机技术领域,特别涉及一种Erlang进程超时管理方法。
背景技术
Erlang提供了一种超轻量级进程机制用于执行函数,根据硬件性能可并行执行的超轻量级进程可达上千到数十万、上百万不等。Erlang虚拟机虽然支持同时创建大量轻量级进程,但不支持对进程的执行设置时限。如果进程执行过程中出现死循环、异常大量、超长时间的计算等情况,将对系统性能造成毁灭性的影响,因此需要有进程超时监督机制,以对Erlang超时进程进行管理。
发明内容
为解决上述问题,本发明提供了一种Erlang进程超时管理方法。
本发明采用以下技术方案:
一种Erlang进程超时管理方法,包括如下步骤:
S1、Erlang节点启动后,创建与CPU的核心数目相等的N个超时监督进程;
S2、每个超时监督进程启动时,创建一个有序的ets表;
S3、使用代理函数作为待监督Erlang进程的入口,所述代理函数采用随机方法从N个超时监督进程中选择一个ets表,并在该ets表中放入进程执行到期时间end-time和进程身份pid,形成主键{end-time,pid};
S4、所述代理函数执行真实入口点函数及参数;
S5、每个超时监督进程以设定的间隔扫描出所述ets表中end-time小于当前时间的主键,对该主键对应的进程身份pid执行结束操作,并从所述ets表中移除该主键;
S6、所述代理函数移除主键为{end-time,pid}的进程的超时数据。
进一步地,步骤S2中的所述ets表可被其他进程访问,用于存储进程超时信息,且所述ets表的主键为{end-time,pid},其中end-time表示进程执行到期时间,pid表示进程身份。
进一步地,所述ets表采用有序分组的类型,即所述ets表内按所述主键从小到大排序。
进一步地,步骤S3中所述使用代理函数作为待监督Erlang进程的入口时需向所述代理函数传入相应的真实入口点函数及参数。
进一步地,步骤S3中所述代理函数还可采用哈希算法从N个超时监督进程中选择一个ets表。
进一步地,所述步骤S5中对ets表扫描的流程具体为:
S51、先获取所述有序分组中的第一个主键数据,即end-time最小的数据;
S52、将获取的所述第一个主键数据中的end-time与当前时间对比,若小于,则移除所述第一个主键数据,然后重复执行步骤S51,否则,结束本次扫描。
采用上述技术方案后,本发明与背景技术相比,具有如下优点:
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于厦门极致互动网络技术股份有限公司,未经厦门极致互动网络技术股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202011408673.2/2.html,转载请声明来源钻瓜专利网。
- 上一篇:一种穿舱密封电连接器
- 下一篇:一种混凝土固化剂及其制备工艺