操作系统大赛:基于 eBPF 的容器监控工具 Eunomia 初赛报告(容器信息收集、安全规则与 seccomp)

本文介绍了Eunomia,一个基于eBPF的容器监控工具,涵盖容器追踪模块设计,包括数据结构和实现,以及安全规则设计和seccomp系统调用准入机制。通过安全分析和告警模块,Eunomia能对容器安全风险进行监控和上报。
摘要由CSDN通过智能技术生成

项目仓库:https://github.com/yunwei37/Eunomia

4.5. 容器追踪模块设计

4.5.1. 容器信息数据结构

目前我们的容器追踪模块是基于进程追踪模块实现的,其数据结构为:

struct container_event {
   
	struct process_event process;
	unsigned long container_id;
	char container_name[50];
};

容器追踪模块由container_tracker实现

struct container_tracker : public tracker_with_config<container_env, container_event>
{
   
  struct container_env current_env = {
    0 };
  struct container_manager &this_manager;
  std::shared_ptr<spdlog::logger> container_logger;

  container_tracker(container_env env, container_manager &manager);
  void start_tracker();

  void fill_event(struct process_event &event);

  void init_container_table();

  void print_container(const struct container_event &e);

  void judge_container(const struct process_event &e);

  static int handle_event(void *ctx, void *data, size_t data_sz);
};

同时我们添加了一个manager类来控制tracker。

struct container_manager
{
   
 private:
  struct tracker_manager tracker;
  std::mutex mp_lock;
  std::unordered_map<int, struct container_event> container_processes;
  friend struct container_tracker;

 public:
  void start_container_tracing(std::string log_path)
  {
    
    tracker.start_tracker(std::make_unique<container_tracker>(container_env{
   
      .log_path = log_path,
      .print_result = true,
    }, *this));
  }
  unsigned long get_container_id_via_pid(pid_t pid);
};
4.5.2. 容器追踪实现

容器追踪模块的ebpf代码服用了process追踪模块的ebpf代码,因此这里我们只介绍用户态下对数据处理的设计。
当内核态捕捉到进程的数据返回到用户态时,我们调用judge_container()函数,判断该进程是否归属于一个container,其具体实现为:

void container_tracker::judge_container(const struct process_event &e)
{
   
  if (e.exit_event)
  {
   
    this_manager.mp_lock.lock();
    auto event = this_manager.container_processes.find(e.common.pid);
    // remove from map
    if (event != this_manager.container_processes.end())
    {
   
      event->second.process.exit_event = true;
      print_container(event->second);
      this_manager.container_processes.erase(event);
    }
    this_manager.mp_lock.unlock
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值