NET-SNMP开发——日志输出

时间:2023-01-14 10:22:57

NET-SNMP开发——日志输出

net-snmp的日志输出功能是很强大的,与日志输出相关函数声明在net-snmp-5.7.3\include\net-snmp\library\snmp_logging.h文件中,定义在net-snmp-5.7.3\snmplib\snmp_logging.c文件中。

具体实现就不说了,可以自己看源码。

net-snmp的日志功能默认将日志写入到/var/log/snmpd.log文件中(linux/unix下,windows下没有)

snmp log 类型

net-snmp中将日志分为8个类型(一个警告warning,三个信息information,四个错误error),具体的宏定义如下

/* error types */
#define LOG_EMERG 0 /* system is unusable */
#define LOG_ALERT 1 /* action must be taken immediately */
#define LOG_CRIT 2 /* critical conditions 临界条件*/
#define LOG_ERR 3 /* error conditions 错误条件*/
/* warning type */
#define LOG_WARNING 4 /* warning conditions 预警条件*/
/* information types */
#define LOG_NOTICE 5 /* normal but significant condition 正常但意义重大*/
#define LOG_INFO 6 /* informational 信息*/
#define LOG_DEBUG 7 /* debug-level messages 调试级别的消息*/

注意:这些严重等级的分类是与标准的 UNIX/LINUX 中的 syslog 一致的。

System is unusable emergencies alerts 极其紧急的错误 Action must be taken immediately 需立即纠正的错误 Critical conditions 关键信息 Error conditions 需关注但不关键的错误 Warning conditions警告,可能存在某种差错 Normal but significant condition 需注意的信息 Informational 一般提示信息 Debug-level messages调试信息

日志输出函数

snmp_log

int snmp_log(int priority, const char *format, ...)

这个函数实际上调用的是snmp_vlog函数,这个函数成功返回0,当不能格式化日志字符串时返回1,当动态内存不能分配返回2,如果日志缓冲区的长度大于1024字节。这些消息将以LOG_ERR类型直接写入日志文件。

调用示例

snmp_log(LOG_ERR, "%s: Error %d out-of-range\n", s, errno);

snmp_log_perror

void snmp_log_perror(const char *s)

实际上是先调用char* error = strerror(errno);获取errno的信息,然后使用snmp_log来输出参数serror字符串。 调用示例

snmp_log_perror("init error");

snmp_log_string

void snmp_log_string(int priority, const char *str)

调用示例

snmp_log_string(LOG_ERR, "Could not format log-string\n");

NET-SNMP开发——日志输出的更多相关文章

  1. odoo开发笔记 -- 后台日志输出及分析

    odoo开发笔记 -- 后台日志输出及分析 附:日志分析软件

  2. [iOS开发系列]根据Debug和Release状态的变化来屏蔽日志输出

    今天在这里分享一个很实用的小技巧. 我们平时在开发应用的时候,经常会用到NSLog来调试我们的程序,而随着项目越来越大,这些用于调试的日志输出就会变得很难管理. 我们在发布正式版的时候一定要屏蔽掉所有 ...

  3. iOS开发进阶 - 日志输出框架CocoaLumberjack与XcodeColors插件的简单使用(swift版)

    CocoaLumberjack是Mac和iOS上一个集快捷.简单.强大和灵活于一身的日志框架.XcodeColors是用于控制台着色的工具,配合着CocoaLumberjack用有更好的效果,不废话, ...

  4. Java学习-046-日志抓取合并后排序问题解决方案之 --- log4j 二次定制,实现日志输出添加延时10ms

    自3月25至今,已经好久没有写学习日志了,今天在写日志抓取合并的小方法,发现抓取后的日志并米有依据系统执行的日志顺序排序.日志抓取排列逻辑如下: 通过日志标识,从各个日志文件(例如 use.log,e ...

  5. log4j日志输出使用教程

    Log4j是帮助开发人员进行日志输出管理的API类库.它最重要的特点就可以配置文件灵活的设置日志信息的优先级.日志信息的输出目的地以及日志信息的输出格式.Log4j除了可以记录程序运行日志信息外还有一 ...

  6. 【Android】pidcat 不显示日志输出

    问题: 直接安装了 pidcat :  brew install pidcat ,装完以后执行 pidcat <package name> ,发现没有日志输出,adb devices 也能 ...

  7. springboot 学习之路 4(日志输出)

    目录:[持续更新.....] spring 部分常用注解 spring boot 学习之路1(简单入门) spring boot 学习之路2(注解介绍) spring boot 学习之路3( 集成my ...

  8. ELK实战(Springboot日志输出查找)

    需求 把分布式系统,集群日志集中处理快速查询 搭建ELK并与springboot日志输出结合 搭建ELK 基于我前面的elasticsearch搭建博客文档docker-compose.yml基础上进 ...

  9. Redis 自定义 RedisAppender 插件&comma; 实现日志缓冲队列&comma;集中日志输出&period;

    因为某些异步日志设置了即使队列满了,也不可丢弃,在并发高的时候,导致请求方法同步执行,响应变慢. 编写这个玩意,除了集中日志输出以外,还希望在高并发的时间点有缓冲作用. 之前用Kafka实现了一次入队 ...

随机推荐

  1. 曲线拟合的最小二乘法(基于OpenCV实现)

    1.原理 在现实中经常遇到这样的问题,一个函数并不是以某个数学表达式的形式给出,而是以一些自变量与因变量的对应表给出,老师讲课的时候举的个例子是犯罪人的身高和留下的脚印长,可以测出一些人的数据然后得到 ...

  2. ORA-01033&colon; ORACLE 正在初始化或关闭 进程 ID&colon; 0 会话 ID&colon; 0 序列号&colon; 0

    用了很长时间的数据库,一直都挺好,今天早上一来报这个错,开始追究原因. 1.用SYS用户登录: 2.将数据库修改为打开状态,alter database open,出现如下的错误提示: ORA-160 ...

  3. Python 基礎 - 認識模塊

    什麼是模塊?簡單說就是別人寫好了一堆功能,封裝在一起. 模塊有分二種,一個是之前有提到的 標準庫,就是不需要透過額外的安裝就有的模塊 ,另一個叫 第三方庫,需要另外安裝才能使用的模塊 #!/usr/b ...

  4. 模板 树链剖分BFS版本

    //点和线段树都从1开始 //边使用vector vector<int> G[maxn]; ],num[maxn],iii[maxn],b[maxn],a[maxn],top[maxn], ...

  5. POJ 2127 Greatest Common Increasing Subsequence -- 动态规划

    题目地址:http://poj.org/problem?id=2127 Description You are given two sequences of integer numbers. Writ ...

  6. Case swapping

    Case swapping Description: Given a string, swap the case for each of the letters. e.g. CodEwArs --&g ...

  7. 查看当前正在被执行的sql

    由于在公司服务器上在某个时段查询某个sql执行比较慢,由来查询当前正在被执行的sql Select t.text,SUBSTRING(t.text, (r.statement_start_offset ...

  8. 自定义key解决zabbix端口监听取值不准确的问题

         今天有一个朋友问到我一个关于zabbix监控tcp端口的问题,明明端口在监听,但是通过net.tcp,listen取值取到的却是0. 经过简单的goole发现这已经是一个历史悠久的问题: 问 ...

  9. 从客户端&lpar;Content&equals;&quot&semi;&lt&semi;p&gt&semi;666&lt&semi;&sol;p&gt&semi;&quot&semi;&rpar;中检测到有潜在危险的 Request&period;Form 值。

    出现:从客户端(Content="<p>测试</p>")中检测到有潜在危险的 Request.Form 值. 一般是在线编辑器有HTML标签的,我是用的MV ...

  10. TCP的三次握手和四次挥手图解

     1. TCP建立连接的三次握手 (1)第一次握手:Client将标志位SYN置为1,随机产生一个值seq=J,并将该数据包发送给Server,Client进入SYN_SENT状态,等待Server确 ...