每个使用UNIX/LINUX的人都知道日志的用处,那你是否清楚LINUX这些日志信息处理的来龙去脉呢?
 
  我们可以看到LINUX系统信息日志的途径基本有以下2种:
 
  (1)dmesg查看——这个命令比较常见
 
  (2)/var/log/下的文件
 
  那下面我们就从这个2个途径着手,一步步的走下去。
 
  (一)首先,我们来看dmesg这个常见的命令背后隐藏的是什么!!
 
  (1)先让我们来MAN一下这个家伙
 
 -------------man dmesg--------------------------
 
  NAME
 
  dmesg - print or control the kernel ring buffer
 
  SYNOPSIS
 
  dmesg [ -c ] [ -n level ] [ -s bufsize ]
 
  DESCRIPTION
 
  dmesg is used to examine or control the kernel ring buffer.
 
  The program helps users to print out their bootup mes- sages. Instead of copying the messages by hand, the user need only:
 
  dmesg > boot.messages
 
  and mail the boot.messages file to whoever can debug their
 
  problem.
 
  OPTIONS
 
  -c Clear the ring buffer contents after printing.
 
  -sbufsize
 
  Use a buffer of size bufsize to query the kernel ring buffer. This is 16392 by default. (The default kernel syslog buffer size was 4096 at first, 8192 since 1.3.54, 16384 since 2.1.113.) If you have set the kernel buffer to be larger than the default then this option can be used to view the entire buffer.
 
  -nlevel
 
   Set the level at which logging of messages is done to the console. For example, -n 1 prevents all messages, expect panic messages, from appearing on the console. All levels of messages are still written to /proc/kmsg, so syslogd(8) can still be used to control exactly where kernel messages appear.
 
  When the -n option is used, dmesg will not print or clear the kernel ring buffer.
 
  When both options are used, only the last option on the command line will have an effect.
 
  从LINUX提供的手册,我们可以得知一条最重要的信息dmesg是从kernel 的ring buffer(环缓冲区)中读取信息的。
 
  (2)那什么是ring buffer呢?
 
   在LINUX中,所有的系统信息(包内核信息)都会传送到ring buffer中。而内核产生的信息由printk()打印出来。系统启动时所看到的信息都是由该函数打印到屏幕中。 printk()打出的信息往往以 <0><2>……这的数字表明消息的重要级别。高于一定的优先级别会打印到屏幕上, 否则只会保留在系统的缓冲区中(ring buffer)。
 
  至于dmesg具体是如何从ring buffer中读取的,大家可以看dmesg.c源代码。很短,比较容易读懂。
 
  (二)dmesg怎么搞的大家应该很明白了吧。至于/var/log/下的文件更是大家熟悉得不能再熟悉了!
 
  (1)/var/log/……下为什么有这么多文件呢?
 
  一句话解释: 是syslogd这个守护进程根据/etc/syslog.conf,将不同的服务产生的Log记录到不同的文件中。
 
  这里的/etc/syslog.conf我就不细说了,很多这方面的信息(去查吧)。
 
  (2)既然知道了,/var/log/……是由syslogd这个守护进程产生的。那就再顺着这条线走下去。
 
  LINUX系统启动后,由/etc/init.d/sysklogd先后启动klogd,syslogd两个守护进程。
 
  其中klogd会通过syslog()系统调用或者读取proc文件系统来从系统缓冲区(ring buffer)中得到由内核printk()
 
  发出的信息。而syslogd是通过klogd来读取系统内核信息。
 
  我想至此,大家心理应该对log产生,读取等一系列的动作有所感觉。
 
  总结:
 
  (1)所有系统信息是输出到ring buffer中去的。dmesg所显示的内容也是从ring buffer中读取的。
 
  (2)LINUX系统中/etc/init.d/sysklogd会启动2个守护进程:Klogd&&Syslogd
 
  (3)klogd是负责读取内核信息的,有2种方式:
 
  syslog()系统调用(这个函数用法比较全,大家去MAN一下看看)
 
  直接的对/proc/kmsg进行读取(再这提一下,/proc/kmsg是专门输出内核信息的地方)
 
  (4)Klogd的输出结果会传送给syslogd进行处理,syslogd会根据/etc/syslog.conf的配置把log
 
  信息输出到/var/log/下的不同文件中。

转载于:https://blog.51cto.com/bowen/107113

摸清Linux日志处理的来龙去脉相关推荐

  1. 《Unix/Linux日志分析与流量监控》书稿完成

    <Unix/Linux日志分析与流量监控>书稿完成 近日,历时3年创作的75万字书稿已完成,本书紧紧围绕网络安全的主题,对各种Unix/Linux系统及网络服务日志进行了全面系统的讲解,从 ...

  2. linux开发log示例,RH124-log Linux日志(示例代码)

    课程笔记 #日志目录 [[email protected] log]$ ls /var/log/ amanda cron-20170531 glusterfs messages #日志管理服务 [[e ...

  3. Linux日志选项详解及日志服务器的实现

    Linux日志服务器的实现   一:基本概念 1: 软件包 syslogd 2: /etc/syslog.conf 配置文件 格式:facility.level action (设备. 优先级动作) ...

  4. rsync服务同步,linux日志,screen工具

    2019独角兽企业重金招聘Python工程师标准>>> 10.32/10.33 rsync通过服务同步 10.34 linux系统日志 10.35 screen工具 扩展 Linux ...

  5. ElasticSearch实战:Linux日志对接Kibana

    本文由云+社区发表 ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎,基于RESTFul web接口.ElasticSearch是用Java开发 ...

  6. linux日志系统分析:rsyslog、syslog、klog

    1. syslogd和rsyslogd syslogd是Linux下的一个记录日志文件服务.从结构来说,可以理解为这个服务下面有一系列的子服务,例如mail.auth.cron.kern等等,这些子服 ...

  7. 位于/var/log目录下的20个Linux日志文件

    位于/var/log目录下的20个Linux日志文件[译] from:http://buptguo.com/2014/01/16/linux-var-log-files/ 原文地址:20 Linux ...

  8. linux tomcat 日志路径,linux日志文件在哪 linux安装tomcat

    linux日志文件在哪 本例使用的是centos6.5版本号 一.首先到官方下载tomcat服务: ? 二.将tomcat上传至linuxserver中 本人在根文件夹下建立了一个rommr文件夹 一 ...

  9. 关于linux的服务器搭建,关于搭建linux日志服务器

    linux日志服务器 作为服务器操作系统,linux下的系统日志对于管理员来说相当重要,可通过日志的查看跟踪系统运行状态. 日志存放位置在  /var/log目录里,主要有 dmeg,maillog ...

最新文章

  1. 骑士人才linux伪静态,骑士人才CMS伪静态规则
  2. 数据结构快速回顾——栈
  3. 怎么修改windows控制台编码?(不改了)
  4. Redis的两种持久化机制RDB和AOF
  5. python读取只读word只读_人生苦短我学Python——Word处理之快速Word转PDF
  6. Android 通过高德地图获取地址的经纬度
  7. STL vector 容器介绍
  8. PHP封装curd,CURD · TookPHP开发手册 · 看云
  9. Python获取电脑硬件信息及状态的实现方法
  10. postgresql定义访问ip与用户_Postgresql-12.1最新版本在线安装以及配置使用全流程
  11. Tensorflow中卷积的padding操作
  12. gridview checkbox从服务器端和客户端两个方面实现全选和反选
  13. 第十五章:交互式界面(十一)
  14. 为什么有时候代码会提示要去掉@override
  15. hdu acm 1241
  16. Java线程同步和锁定
  17. 电工学习通:电路图符号知识大全
  18. Kindle 文言文 古汉语 字典
  19. 为什么要Word转PDF,看完你就懂了
  20. 一纬度横直线等于多公里_【地理】高中地理必修一知识点总结,考前必看

热门文章

  1. ubuntu18.04下 c++安装opencv-3.4.6,c++安装opencv-3.4.9,clion配置opencv-3.4.6与 python安装 opencv-3.4.6
  2. javascript页面刷新与定时跳转页面
  3. 运行控制器方法之前先执行注解@ModelAttribute的方法
  4. Activiti(6.0)任务管理服务TaskaskService
  5. php站中文转码在iis 7.5乱码,iis伪静态中文url出现乱码的解决办法
  6. java 单行文本_Java Swing界面编程(17)---单行文本输入组件:JTextField
  7. 二维数组鞍点问题(C++)
  8. 前置递增运算符(JS)
  9. ubuntu之安装显卡驱动
  10. 朴素贝叶斯-垃圾邮件(中文的)处理