librdkafka 自定义记录器,函数签名

Posted

技术标签:

【中文标题】librdkafka 自定义记录器,函数签名【英文标题】:librdkafka custom logger, function signature 【发布时间】:2022-01-04 17:18:13 【问题描述】:

我正在使用 librdkafka c++ API,我想更改记录器的默认行为。

在c API中有这个函数rd_kafka_conf_set_log_cb()来设置日志回调。它需要一个带有签名的函数:

void(*)(const rd_kafka_t *rk, int level, const char *fac, const char *buf)

但是我无法弄清楚 const char *fac 在函数签名中的作用。我可以看到使用它时传递了诸如“FAIL”或“BGQUEUE”之类的字符串,但我找不到任何关于它们的含义或如何使用它们的文档。

const char *fac 的用途是什么,是否有关于其使用的文档或定义字典?

【问题讨论】:

【参考方案1】:

设施字符串是发出日志的上下文的半唯一名称。它主要用于帮助 librdkafka 维护者识别日志行的来源,但也可用于过滤目的。

它最初的灵感来自Cisco ios like system logs,其形式为:

FAC-LVL-SUBFAC: Message...

librdkafka 对应项是:

RDKAFKA-7-JOIN: Joining consumer group xyx

其中 JOIN 是 librdkafka 日志记录工具。

【讨论】:

以上是关于librdkafka 自定义记录器,函数签名的主要内容,如果未能解决你的问题,请参考以下文章

错误:匹配 postgis 自定义模式时,函数 postgis_lib_version() 不存在

带有自定义 Malloc 函数的 CppCheck

python中怎么调用自定义函数

librdkafka 源码分析

Android8.0隐式广播和自定义签名权限

SQL自定义函数返回记录