rsyslogd-学习&使用

rsyslogd-学习&使用简介【这一篇博客不是完整的解释rsyslogd的运行原理,只是一个自己查找资料的记录】rsyslog是一个syslogd的多线程增强版。现在Fedora和Ubuntu,rhel6默认的日志系统都是rsyslog了。rsyslog负责写入日志,logrotate负责备份和删除旧日志,以及更新日志文件学习资料1.官方网站官方网站:http://www.rsyslog.com/这是官

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

简介

【这一篇博客不是完整的解释 rsyslogd的运行原理,只是一个自己查找资料的记录】

rsyslog 是一个 syslogd 的多线程增强版。现在Fedora和Ubuntu, rhel6默认的日志系统都是rsyslog了。rsyslog负责写入日志, logrotate负责备份和删除旧日志, 以及更新日志文件

学习资料

1. 官方网站

官方网站: http://www.rsyslog.com/
这是官网的一张图片,可以看出来支持的功能还是非常多的,支持各种各样的传输方式,支持各种各样的数据库。

这里写图片描述

如果想全面的了解 rsyslogd,还是好好看看这个网站的内容的。但是我要功能比较简单,就是把我的程序日志放到指定的文件就行了,为了就是不用开发自己的日志系统,所以暂时没有看这些东西。搜了一些中文博客,就可以了。

2. 博客

找了几篇博客,这一篇是我最喜欢的。 http://blog.csdn.net/needle2/article/details/6826523
写的有条理,清楚简单,不想其它乱糟糟的博客内容,我也不需要安装,我使用的环境都默认都默认安装了 rsyslogd。
这篇博客写了我需要知道的方方面面,足以让我了解 rsyslogd。

3. 社区

还有一个问题没有解决,就是怎么配置 rsyslogd,让我的程序的日志输出到指定的文件,而不是输出到/var/log/message。所以搜索之,最后在一个社区里面找到了,这样的问题肯定会有人讨论,所以不出所料,找到了 http://www.newsmth.net/nForum/#!article/LinuxDev/34880

发信人: closer2me (木杉), 信区: LinuxDev
标  题: Re: 怎样用syslog写到自定义的log文件?
发信站: 水木社区 (Sun Aug 23 21:09:27 2009), 站内

APUE里面说
facility的 LOG_LOCAL0 ~ LOG_LOCAL7 是保留由本地使用,我程序里面用了也没用效果。

自己的程序就没法用syslog输出到自定义的log文件了吗?
【 在 saphires (萝卜) 的大作中提到: 】
: 定义的方法应该是错的
: syslog.conf里面的selector应该是facility.priority
: facility默认就只有那么几个,不过它是数字定义,可以自己整.
: ...................

-- 
Stay hungry, stay foolish. 

在这个帖子里,有这么一段讨论,我就猜到要怎么使用了

使用方法

因为 rsyslogd 预留了8个facility,LOG_LOCAL0 ~ LOG_LOCAL7。我们使用这个就足够了。
下面我在 centos6.6中做样例。

1. 首先修改配置文件

rsyslogd 的配置文件放为/etc/rsyslogd.conf
修改 这个文件,在这个文件里面添加下面这一行

 local5.*                                                /var/log/dpi.log

意思就是 local5的所有日志都存入/var/log/dpi.log文件中。

2. 重启 rsyslogd

使用这个命令重启就行了 /etc/init.d/rsyslog restart

3. 写代码

代码很简单,如下

#include <syslog.h>
#include <stdio.h>
#include <stdlib.h>

int main()
{
     syslog(LOG_ERR|LOG_LOCAL5,"syslog test\n");
}

具体参数的意义看学习资料里面的博客,只需要注意,这一条日志是发给LOG_LOCAL5的,也就是之前设置过的那个。

编译运行后,可以看到如下的内容

[zhijia@localhost log]$ sudo cat /var/log/dpi.log 
[sudo] password for zhijia: 
Feb 29 15:48:32 localhost a.out: syslog test
[zhijia@localhost log]$ 

因为这个log目录属于 root 的,所以想看这个文件,还是需要 root 权限的。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/170600.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • pytest报错_eclipse提交代码到git

    pytest报错_eclipse提交代码到git前言我们每天写完自动化用例后都会提交到git仓库,随着用例的增多,为了保证仓库代码的干净,当有用例新增的时候,我们希望只运行新增的未提交git仓库的用例。pytest-picked插件可以

    2022年7月28日
    19
  • c++禁止隐式转换_无法将int隐式转换为类

    c++禁止隐式转换_无法将int隐式转换为类C++有一个很方便的功能—隐式转换,比如有一个函数voidfunc(doublef);调用它的时候func(5);func(5.0);都是有效的。但有时候,这个功能就很麻烦了。比如:classA{public:A(conststring&amp;v){///…}}void…

    2022年10月11日
    2
  • [原创]-数据仓库ETL开发

    [原创]-数据仓库ETL开发ETL开发概述ETL是数据仓库的后台,主要包含抽取、清洗、规范化、提交四个步骤,传统数据仓库一般分为四层模型。分层的作用:1.划分ETL阶段工作重心,便于管理2.降低开发和维护成本3.减…

    2022年6月4日
    35
  • linux查看udp端口占用命令,详解Linux查看端口占用「建议收藏」

    linux查看udp端口占用命令,详解Linux查看端口占用「建议收藏」在使用计算机的过程中,有时会碰到端口被占用的情况,这时候需要查看端口占用情况进行问题排查。在linux系统中,端口占用的情况也时有发生,一般情况下可以使用lsof和netstat两个命令来查看端口占用情况。下面我们就分别介绍Linux查看端口占用用到的lsof和netstat命令:1、lsof命令lsof(listopenfiles)命令功能:列出当前系统打开文件。在linux系统中,一切皆文…

    2022年7月27日
    5
  • 树莓派是什么?能干什么?

    树莓派是什么?能干什么?树莓派是什么?能干什么?一、什么是树莓派?二、树莓派和单片机的区别?三、树莓派使用的什么系统?四、树莓派的最基本操作方法?五、树莓派能干什么?六、玩树莓派能学到什么?一、什么是树莓派?树莓派是由树莓派基金会发布的卡片式电脑,起初的目的是为了让更多的孩子们可以学习计算机编程,但是发布以后受到了广大计算机爱好者的喜爱树莓派被称为卡片式电脑,顾名思义它可以安装操作系统,并且接上显示屏鼠标键盘就可以正常使用,在上面可以用python或者C语言编程并运行。二、树莓派和单片机的区别?树莓派是卡片式电脑可以装

    2022年6月8日
    27
  • 银行家算法c语言加注释,银行家算法 C语言编程[通俗易懂]

    银行家算法c语言加注释,银行家算法 C语言编程[通俗易懂]匿名用户1级2011-06-02回答银行家算法程序代码#include#include#include#defineFALSE0#defineTRUE1#defineW10#defineR10intM;//总进程数intN;//资源种类intALL_RESOURCE[W];//各种资源的数目总和intMAX[W][R];//M个进程对N类资源最大资…

    2022年7月22日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号