面试笔试--通用事件处理框架编写一个日志缓存插件

1.编程题(40分钟, 写磁盘文件、从磁盘加较数据等底层接口函数可以不用写实现细节, 重点是工程完整性)

请为一个通用事件处理框架编写一个日志缓存插件, 插件功能及要求如下

(1)插件编译成 loopfile. so, 通用插件框架的共享库为 modules_ std. so

(2)在 loopfile插件中, 实现日志缓存功能, 缓存事件 event 中的 s_ip , s_mac, s_user 三个字段(均为字符串类型), 其中s_ip为key

(3) 缓存策略为: 插件每收到一个 event, 就要先查看一下缓存中是否已经有了该事件、如果没有就添加, 否则更新一下缓存中的s_mac, s_user字段: 每隔30秒 , 需要将缓存中的事件“落地” , 写入 /var/ log/ loopfile.log 中; 插件加载时, 要先从文件中加载旧数据。

(4)请写出插件的主要源文件 loopfile. c、 loopfile. h、 Makefile( 或 Makefile, arm) 插件中至少要包括以下三个接口

/**********************
function: module_init,  插件初始化时调用一次。  
@param private:插件私有数据,  可以在init中进行分配, exit中释放
**************************/
int module_init(void ** private);

/*************************
@ function; module_exit,   插件卸载时调用一次
@ param private: 插件私有数据, 这里需要释放
******************/
int module_exit(void ** private);

/***********************
@ function: module_ process,   插件中的事件处理函数,  每个事件都会调用一次
@Param private:  插件私有数据, process中可以读取
@ param event   事件, 是一个KV结构的fmap类型,  key为字符串 , value可以为int、char、list等基本类型
**************************/
int module_process(void *private, fmap * event);

附录: fmap 定义在通用库 module_std.so中, 其中一些参考接口如下


/**************************
@ function:获取str值
@Param map :  要获取的map对象
@Param  kbuf: key值
Param  ksize :key长度
@reurn:成功返回值,  失败返回NULL
*************************/
const unsigned char * fmap_get_str(Fmap * map, const void * kbuf , int size);

/************************
function 添加一个字符串项, 会覆盖旧数据
param map要添加的map对象
param kbuft key值长
appara vhuf  要添加的数据
reun:成功返回0.  失败返回-1
**************************/
int fmap_put_str(Fmap * map, const void * kbuf, int ksize, unsigned char * vbut, int vsizel);

/****************
 @ function:  获取int值, 会覆盖旧数据
param map:  要获取的map对象
param kbut:  key值
param ksize: key长度
@ param find  标识是否找到  1:找到,  0:未找到o
reurn:成功返回值, 失败返回0
*************************/
u_int32_t fmap_get_int(Fmap * map, const void kbuf, int ksize, int *find);

/*******************
@ Function:  从一个map获取一个整数
@ param nap:  要操作的map对象
@ param kbuf: key值
param ksize:  key长度
@ param find:  获取成功后为1, 否则为0
@ Return:  要获取的整数
*************/
int fmap_put_int(Fmap * map, const void * kbuf, int ksize, u_int32_t num);
   
/*************
@ function: 添加一个整数到map里面
 @ param map:  要添加的map对象
 param kbuf: key值
@ param size: key长度
@ param num:  添加的整数
@ 0: 成功  -1: 失败
***************/
void * fmap_dump(fmap * map, int * msize );

/*************
 @ function:加载一个map对象
 param data: 要加载的数据
 @ param len: data的长度
@ return: 返回解析后的map对象
*************/
fmap *fmap_load(void * data, int *len);

/************
② function:  建立新的Fmap对象
@ return:成功返回Fmap对象,   失败返回NULL;
***********/
fmap * fmap_new();
/*******
@ function:释放Fmap对象/
*************/
void fmap_del(Fmap * map);
struct fmap
{
    
};
struct fmap event;

int module_init(void ** private)
{
    
}

int module_exit(void ** private)
{
    
}

int module_process(void *private, fmap * event)
{
    
}

gcc-linux - c loopfile. c、 loopfile. h
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

极客程序设计

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值