设为首页 收藏本站
查看: 1927|回复: 0

[经验分享] keepalived源码浅析——日志

[复制链接]

尚未签到

发表于 2015-11-19 15:37:28 | 显示全部楼层 |阅读模式
  源码:
  #include <syslog.h>
#include <stdio.h>
#include <stdarg.h>
/* Boolean flag - send messages to console as well as syslog */
static int log_console = 0;  //是否发送信息到控制台
void
enable_console_log(void) {
log_console = 1;
}
void
log_message(const int facility, const char *format, ...) //可变参数
{
va_list args;
char buf[256];
va_start(args, format);
vsnprintf(buf, sizeof(buf), format, args);
va_end(args);
if (log_console) {
fprintf(stderr, &quot;%s\n&quot;, buf);
}
syslog(facility, &quot;%s&quot;, buf);  // syslog日志
}


  
  
  


  调用方式:
  log_message(LOG_INFO, &quot; SNMP Trap enabled&quot;);

  
  


  
  在主函数main.c中:
  


  

if (debug & 1)
enable_console_log();


关于syslog相关代码:  
  
  打开
  

openlog(PROG, LOG_PID | ((debug & 1) ? LOG_CONS : 0), log_facility);


其中:  
  

#define PROG    &quot;genhash&quot;
int log_facility = LOG_DAEMON;

  


  
  void openlog(const char *ident, int option, int facility);

此函数用来打开一个到系统日志记录程序的连接,打开之后就可以用syslog或vsyslog函数向系统日志里添加信息了。




  openlog的第一个参数ident将是一个标记,ident所表示的字符串将固定地加在每行日志的前面以标识这个日志,通常就写成当前程序的名称以作标记。也就是区分日志的一个标记字符,可以由我们自己来设定。
  第二个参数option应该是日志消息&#26684;式内容的配置选项。是下列&#20540;取与运算的结果:LOG_CONS, LOG_NDELAY, LOG_NOWAIT, LOG_ODELAY, LOG_PERROR, LOG_PID,各&#20540;意义请参考man openlog手册



第三个参数指明记录日志的程序的类型,我们都只用LOG_LOCAL0 到 LOG_LOCAL7中的任意一个。可选的程序有很多

关闭
  closelog();


  
  


  

版权声明:本文为博主原创文章,未经博主允许不得转载。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-141267-1-1.html 上篇帖子: ubuntu下配置nginx+keepalived做HA(续) 下篇帖子: keepalived源码浅析——sock
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表