IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

标签:process_monitoring

共 1 篇相关文章

IT 累计浏览 1,372

riak_sysmon使用和源码分析

这篇讲的是 riak_sysmon 这个 Erlang 监控工具的实战与原理拆解。它基于 Erlang VM 内置的 `system_monitor` BIF 函数,专注于捕获四类关键事件:进程堆内存过大、垃圾回收耗时过长、端口(文件或套接字)繁忙,以及节点间网络繁忙。 文章的核心是剖析其内部的两个进程协作。`riak_sysmon_filter` 进程扮演“过滤器”角色:它读取配置的阈值,启动底层监控,并对原始消息进行限流(例如每秒只上报前 N 条),避免告警风暴。过滤后的消息被通知给一个 `riak_sysmon_mgr` 的 `gen_event` 进程,由用户注册的 handler 来具体处理。 作者通过一个制造内存增长的 gen_server 示例,直观展示了当进程堆超过 `heap_word_limit` 后,系统如何触发并报告 `large_heap` 事件。这种 filter + event manager 的设计很巧妙:filter 解决了原生 `system_monitor` 消息洪泛和单一接收者的局限,而 event manager 则将事件处理解耦,允许灵活扩展。