mnesia在运行时提供了大量的统计量,对这些统计量进行监控,有助于正确使用mnesia,以及对mnesia进行调优,这些统计量包括:
代码版本R15B03
1.启动与运行时参数:
运行相关参数:
mnesia是否在运行中:mnesia:system_info (is_running)
信息输出级别:mnesia:system_info (debug)
是否使用数据存储目录:mnesia:system_info (use_dir)
数据存储目录位置:mnesia:system_info (directory)
初始schema位置:mnesia:system_info (schema_location)
自动修复:mnesia:system_info (auto_repair)
是否激活fallback:mnesia:system_info (fallback_activated)
包含master的表的列表:mnesia:system_info (master_node_tables)
mnesia可等待unclear事务的未决期限,默认为infinity:mnesia:system_info (max_wait_for_decision)
mnesia的coredump文件产生的位置:mnesia:system_info (core_dir)
启动时的并行表加载器的数量:mnesia:system_info (no_table_loaders)
向远程节点发送表数据时的压缩级别:mnesia:system_info (send_compressed)
访问模块相关参数:
事务操作模块:mnesia:system_info (access_module)
备份操作模块:mnesia:system_info (backup_module)
事件模块:mnesia:system_info (event_module)
节点相关参数:
集群所有节点,包括非在线的节点:mnesia:system_info (db_nodes)
本节点可从哪些节点处同步数据:mnesia:system_info (extra_db_nodes)
集群在线节点:mnesia:system_info (running_db_nodes)
日志刷写相关参数:
定时刷写日志间隔,默认3分钟:mnesia:system_info (dump_log_time_threshold)
定量刷写日志间隔,默认1000:mnesia:system_info (dump_log_write_threshold)
是否使用原数据文件进行数据dump,true为使用原数据文件,false为新建一个临时文件:mnesia:system_info (dump_log_update_in_place)
表dump频繁程度,值越大dump表越频繁:mnesia:system_info (dc_dump_limit)
版本相关:
版本:mnesia:system_info (version)
日志版本:mnesia:system_info (log_version)
协议版本:mnesia:system_info (protocol_version)
schema版本:mnesia:system_info (schema_version)
2.表相关:
所有表(包括schema):TableList = mnesia:system_info (tables)
表定义:PropList = mnesia:table_info(Table, all)
PropList包含了表的所有相关信息,每个Prop为{Key, Value}形式,重点包括:
active_replicas:当前活动副本节点,可求其长度
disc_copies:磁盘副本节点,可求其长度
ram_copies:内存副本节点,可求其长度
index:索引
majority:是否使用majority事务
master_nodes:是否有master副本节点
memory:占用内存
type:表类型
storage_type:表在本节点的副本类型
where_to_commit:事务需向哪些副本节点提交,可求其长度
where_to_read:可从哪个副本节点读取数据
where_to_wlock:为{NodeList, Majority},NodeList表明事务需向哪些副本节点申请写锁,可求其长度,Majority表明是否为majority写
where_to_write:事务需向哪些副本节点写,可求其长度
对表定义监控时,可列出表定义所有信息,并对重点信息突出显示或聚合
3.锁相关:
锁被哪个事务持有:mnesia:system_info (held_locks)
排队等待的锁:mnesia:system_info (lock_queue)
一个事务持有的锁:没有直接函数,但可以通过以下方法获取:
TidLock = fun() ->
mnesia_locker ! {get_table, self(), mnesia_tid_locks},
receive {mnesia_tid_locks, Ls} -> Ls after 5000 -> [] end
end,
TidLock().
注意:上述锁信息的获取均需要干扰mnesia_locker进程的执行,其工作原理为向mnesia_locker发送请求消息,mnesia_locker读出相关ets表的所有内容,这些ets表均为private,将这些内容通过消息返回给请求进程,负载大时尽量避免使用
4.事务相关:
活动事务:{info, Participants, Coordinators} = mnesia_tm:get_info(10000)
节点参与的事务:活动事务中,Participants包含的事务,可求其长度
节点协调的事务:活动事务中,Coordinator包含的事务,可求其长度
其中节点协调的事务为本地事务,节点参与的事务为远程事务
注意:上述事务信息的获取均需要干扰mnesia_tm进程的执行,其工作原理为向mnesia_tm发送请求消息,mnesia_tm取出进程本地变量,将这些内容通过消息返回给请求进程,负载大时尽量避免使用
未决事务:这些事务处于提交阶段的中途(而非事务执行中途),可以通过mnesia:system_info()或mnesia:info()的输出得到,但不能直接取得其返回结果,可以通过如下方法获取:
ets:match_object(mnesia_decision, {'_', unclear, '_', '_'}).
注意:
mnesia在获取该项信息时,使用的匹配模式为{'_', unclear, '_'},但经对比mnesia.hrl中对decision的定义,以及mnesia_tm中写入decision的位置,发现应该为{'_', unclear, '_', '_'}
上述事务信息的获取需要扫描整个mnesia_decision表,可能会花费较多时间,负载大时尽量避免使用
事务计数器:
总成功事务数:mnesia:system_info(transaction_commits)
总失败事务数:mnesia:system_info(transaction_failures)
总重启事务数:mnesia:system_info(transaction_restarts)
事务可能因节点down/mnesia down/无法立即获取锁而执行失败,此时mnesia_tm可以将事务进行重启,通常的mnesia:transaction(Fun)会无限重启事务。
成功事务tps:可计算一段时间间隔内的成功事务数,这将成为成功事务tps,该tps为有效tps
失败事务tps:可计算一段时间间隔内的失败事务数,这将成为失败事务tps,该tps为
重启事务tps:可计算一段时间间隔内的重启事务数,这将成为重启事务tps,当事务申请锁失败时,将进行重启执行,观察该tps的频繁程度也可以得到当前
5.事件订阅相关:
mnesia事件订阅者进程:mnesia:system_info(subscribers)
订阅系统事件:mnesia:subscribe(system)
出现系统事件后,mnesia将向订阅进程发出消息
需要关注的系统事件:
过载事件:{mnesia_overload, Detail},其中Detail为产生过载的上下文,上下文见下段所述
数据库不一致事件:{inconsistent_database, Context, Node},其中Context为产生不一致的上下文,上下文见
6.过载事件相关:
进行过载检查的上下文及条件:
{mnesia_tm, message_queue_len, [Prev, Len]}:
mnesia_recover每隔10s检查mnesia_tm的消息队列长度,若10s的首尾均发现消息队列长度超过100,则报告该过载事件
schema_prepare:
schema操作为同步下刷日志,下刷日志上下文为schema_prepare
time_threshold:
每隔dump_log_time_threshold个ms,将异步下刷日志,下刷日志上下文为time_threshold
write_threshold:
每产生dump_log_write_threshold个写操作,将异步下刷日志,下刷日志上下文为write_threshold
user:
用户可以通过mnesia:dump_log()进行同步下述日志,下刷日志上下文为user
对于同步/异步下刷日志,若连续两次遭遇相同上下文的下刷日志,mnesia_controller将报告该上下文的过载事件。
当有大量的日志写请求产生,而日志不能及时下刷时,通常会有write_threshold上下文的过载事件,此时通常为并发事务提交太快,而日志下刷过慢或过于频繁导致,可以适当调高dump_log_write_threshold参数
7.数据库不一致事件相关:
数据库不一致事件的上下文:
bad_decision:启动时从对端同步数据,发现事务决议不一致
starting_partitioned_network:启动时从对端同步数据,发现对端节点曾经down过
running_partitioned_network:运行时对端节点up或启动完成同步数据后,发现对端节点曾经down过
不一致事件通常发生在脑裂时,但当前有majority保护,可以仅仅监控该事件
8.日志相关:
日志计数器:
已记入日志的写操作数:mnesia:system_info(transaction_log_writes)
该值为启动以来,已记入日志的写操作数,包括dirty写
计算日志写操作qps:可计算一段时间间隔内的日志写操作数,这将成为日志写操作数qps
日志进程信息:
{info, State} = mnesia_controller:get_info(10000)
State包含的内容包括:
{
supervisor,
schema_is_merged,
early_msgs,
loader_pid,%进行远程/本地加载的进程列表,可求长度,可监控
loader_queue,%进行远程/本地加载的任务列表,可求长度,可监控
sender_pid,%向远程节点发送数据的进程列表,可求长度,可监控
sender_queue,%向远程节点发送数据的任务列表,可求长度,可监控
late_loader_queue,
dumper_pid,%进行本地日志下刷的进程,可为undefined,可监控
dumper_queue,%进行本地日志下刷的任务列表,可求长度,可重点监控
others,
dump_log_timer_ref,
is_stopping
}
具体结构需参照mnesia_controller.erl的定义,不同版本可能变动,可监控项目如上注释
注意:上述日志下刷进程信息的获取均需要干扰mnesia_controller进程的执行,其工作原理为向mnesia_controller发送请求消息,mnesia_tm取出本地状态,将这些内容通过消息返回给请求进程,负载大时尽量避免使用
日志进程工作队列信息:
{workers, Loaders, Senders, Dumper } = mnesia_controller:get_workers(10000)
Loaders为从远程/本地加载数据的worker进程的列表
Senders为向远程节点发送数据的worker进程的列表
Dumper为进行本地日志下刷的worker进程,也可以为undefined
其包含的信息较少,要获得全面的信息,可通过日志进程信息获取
注意:上述日志下刷进程信息的获取均需要干扰mnesia_controller进程的执行,其工作原理为向mnesia_controller发送请求消息,mnesia_tm取出本地状态,将这些内容通过消息返回给请求进程,负载大时尽量避免使用
9.检查点相关:
当前活动检查点:mnesia:system_info(checkpoints)
活动检查点是指通过mnesia_checkpoint:activate激活且未被mnesia_checkpoint:deactivate失活的检查点
10.其它:
待补充
相关推荐
session, specify a Mnesia database directory, initialize a database schema, start Mnesia, and create tables. Initial prototyping of record definitions is also discussed. • Build a Mnesia Database ...
AMNESIA支持多种关系数据库,包括MySQL、PostgreSQL、SQLite等,这为开发者提供了灵活性,可以根据项目需求选择合适的数据库引擎。它通过一个统一的接口隐藏了不同数据库之间的差异,使得代码更具有可移植性。 在A...
B站视频地址: 做了文字校验,已经成功上线,有兴趣的小伙伴可以扫码体验:可以微信搜索:失忆备忘录一、失忆的由来之所以开发这款软件,是因为在那段时间事情很多,但是经常忘记。虽然市面上类似的功能很多,我之前...
Api-Social-Amnesia.zip,忘记过去。社交健忘症确保你的社交媒体帐户只显示你最近的历史,而不是5年前“那个阶段”的帖子。,一个api可以被认为是多个软件设备之间通信的指导手册。例如,api可用于web应用程序之间的...
语言:English (United States) 遗忘的延伸 Chrome失忆症是一个Chrome扩展程序,可让您有选择地不记得自己的任何浏览历史记录。...有关更多信息,请访问https://github.com/DanielBok/chrome-amnesia。
失忆症是一种提醒,允许您定义警报,贴纸(贴子)以提醒您一些重要的内容以及有关所需内容的注释。 可以将警报编程为在给定时间显示,可以在桌面上放置贴纸以随时查看。
"Amnesia_CCK"是一个基于开源系统开发的项目,它主要关注的是"失忆症"游戏的源代码,经过特定的调整和优化,以便在CCK(Content Creation Kit)平台上进行展示。CCK通常是一个工具集,允许用户创建、修改和扩展游戏...
- 电信系统:如交换机、网络管理和监控系统。 - 实时交易系统:如股票交易平台、在线支付系统。 - 分布式缓存:用于加速数据访问和减少主数据库的负载。 - 游戏服务器:处理大量玩家的在线状态和游戏数据。 #### ...
《Mnesia用户手册》是专为理解和操作Erlang编程语言中的Mnesia数据库管理系统而编写的详尽指南。Mnesia是Erlang OTP (Open Telephony Platform) 库中的一个核心组件,它是一个强大的分布式数据库系统,特别适用于...
"Amnesia"是一个可能与计算机安全或数据丢失相关的主题,暗示了系统或用户可能遭遇了某种形式的记忆丧失,即数据无法访问或丢失的情况。在IT领域,这种情况通常涉及到磁盘故障、病毒攻击、误操作或者软件错误。"Post...
8.附录.A:Mnesia.错误信息 8.1.Mnesia.中的错误 9.附录.B:备份回调函数接口 9.1.Mnesia.备份回调行为 10.附录.C:作业存取回调接口 10.1.Mnnesia.存取回调行为 11.附录.D:分片表哈希回调接口 11.1....
需要根据业务的具体情况来确定分片的策略,这可能包括对热点数据的识别和特殊处理,对数据分布的监控,以及如何有效地进行数据迁移和维护。同时,系统的设计要能够灵活应对未来的增长和变化。 Mnesia 的 table ...
8 附录 A : Mnesia 错误信息 . . .. . . 75 8.1 Mnesia 中的错误 . . . . .. . 75 9 附录 B :备份回调函数接口 . . .. . .. . . .. . 76 9.1 Mnesia 备份回调行为 . . .. . . . .. . 76 10 附录 C :作业存取...
Mnesia 是一个强大的分布式数据库管理系统(DBMS),专门为Erlang编程语言设计,特别适用于需要高可用性、持续运行和软实时特性的电信和其他关键业务应用。这个系统允许在多个节点间同步数据,提供了一种在分布式...