目录
整体分类
该模块包含用于检查硬件状态和监视系统运行状况的代码等系统级软件。
在Apollo 5.5中,监视模块现在执行以下检查:
前三项功能是可以自主配置的。
属性分类
从属性上来分类的话,apollo 的monitor 基本上可以分为硬件状态监控和软件状态监控。

硬件状态监控基本上可以分为:
软件状态监控可以分为:
然后由Summary 模块将上述的状态打包发出。
├── BUILD
├── README.md
├── common
│ ├── BUILD
│ ├── monitor_manager.cc
│ ├── monitor_manager.h
│ ├── recurrent_runner.cc
│ ├── recurrent_runner.h
│ └── recurrent_runner_test.cc
├── hardware
│ ├── BUILD
│ ├── esdcan_monitor.cc
│ ├── esdcan_monitor.h
│ ├── gps_monitor.cc
│ ├── gps_monitor.h
│ ├── resource_monitor.cc
│ ├── resource_monitor.h
│ ├── socket_can_monitor.cc
│ └── socket_can_monitor.h
├── monitor.cc
├── monitor.h
├── proto
│ ├── BUILD
│ └── system_status.proto
└── software
├── BUILD
├── camera_monitor.cc
├── camera_monitor.h
├── channel_monitor.cc
├── channel_monitor.h
├── functional_safety_monitor.cc
├── functional_safety_monitor.h
├── latency_monitor.cc
├── latency_monitor.h
├── localization_monitor.cc
├── localization_monitor.h
├── module_monitor.cc
├── module_monitor.h
├── process_monitor.cc
├── process_monitor.h
├── recorder_monitor.cc
├── recorder_monitor.h
├── summary_monitor.cc
└── summary_monitor.h
主要包含4个部分:
整体流程
Monitor 运行时,先扫描不同的子 Monitor,然后通过 SummaryMonitor 做整体状态的监控报告,产生 4 类状态:
之后由FunctionalSafetyMonitor根据状态做两个行为:
代码分析
Monitor 类结构分析:monitor.h/.cc
class Monitor : public apollo::cyber::TimerComponent {
public:
bool Init() override;
bool Proc() override;
private:
std::vector> runners_;
};
Monitor 是一个继承了TimerComponent的定时器组件,init要负责初始化,proc负责实际执行。
Monitor 初始化分析
MonitorManager::Instance()->Init(node_); // Only the one CAN card corresponding to current mode will take effect. runners_.emplace_back(new EsdCanMonitor()); runners_.emplace_back(new SocketCanMonitor()); // To enable the GpsMonitor, you must add FLAGS_gps_component_name to the // mode's monitored_components. runners_.emplace_back(new GpsMonitor()); // To enable the LocalizationMonitor, you must add // FLAGS_localization_component_name to the mode's monitored_components. runners_.emplace_back(new LocalizationMonitor()); // To enable the CameraMonitor, you must add // FLAGS_camera_component_name to the mode's monitored_components. runners_.emplace_back(new CameraMonitor()); // Monitor if processes are running. runners_.emplace_back(new ProcessMonitor()); // Monitor if modules are running. runners_.emplace_back(new ModuleMonitor()); // Monitor message processing latencies across modules const std::shared_ptrlatency_monitor(new LatencyMonitor()); runners_.emplace_back(latency_monitor); // Monitor if channel messages are updated in time. runners_.emplace_back(new ChannelMonitor(latency_monitor)); // Monitor if resources are sufficient. runners_.emplace_back(new ResourceMonitor()); // Monitor all changes made by each sub-monitor, and summarize to a final // overall status. runners_.emplace_back(new SummaryMonitor()); // Check functional safety according to the summary. if (FLAGS_enable_functional_safety) { runners_.emplace_back(new FunctionalSafetyMonitor()); } return true;
runners_ 是 类中的一个成员容器:std::vector
init 函数流程:
Monitor 执行函数分析
bool Monitor::Proc() {
const double current_time = apollo::cyber::Clock::NowInSeconds();
if (!MonitorManager::Instance()->StartFrame(current_time)) {
return false;
}
for (auto& runner : runners_) {
runner->Tick(current_time);
}
MonitorManager::Instance()->EndFrame();
return true;
}
流程