首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

精致全景图 | linux内核输出日志去哪里了

熟悉linux内核,或者看过linux内核源码的同学就会知道,在内核中,有一个类似于c语言的输出函数,叫做printk,使用它,我们可以打印各种我们想要的信息,比如内核当前的运行状态,又或者是我们自己的调试日志等...但这种方式和前面讲的三种方式都不一样,它是完全被动的,是内核在调用printk函数,将日志信息放到ring buffer后,再去通知系统控制台,告知其可以输出这些日志。...系统控制台也是通过一个console_seq变量,记录下一条要输出内核日志的所在位置。...系统控制台输出的内容,是被日志级别过滤过的,内核默认的日志过滤级别是7,即debug级别以上的日志,比如info / err 等,这些都会输出,但debug级别不会输出。...比如,linux内核在kill掉进程时,会用pr_err记录一行日志: 如果我们发现一个进程跑着跑着就没有了,就可以通过dmesg命令,查看是否有这个日志,如果有,说明该进程因为系统内存不足,被操作系统

2.8K30

Linux 内核 内存管理】Linux 内核内存布局 ③ ( Linux 内核 动态分配内存 系统接口函数 | 统计输出 vmalloc 分配的内存 )

文章目录 一、Linux 内核 动态分配内存 系统接口函数 二、统计输出 vmalloc 分配的内存 一、Linux 内核 动态分配内存 系统接口函数 ---- Linux 内核 " 动态分配内存 "...是通过 " 系统接口 " 实现的 , 下面介绍几个重要的 接口函数 ; ① 以 " 页 " 为单位分配内存 : alloc_pages , __get_free_page ; ② 以 " 字节 " 为单位分配...虚拟地址连续的内存块 " : vmalloc ; ③ 以 " 字节 " 为单位分配 " 物理地址连续的内存块 " : kmalloc ; 注意 该 " 物理地址连续的内存块 " 是以 Slab 为中心的 ; 二、统计输出...vmalloc 分配的内存 ---- 执行 grep vmalloc /proc/vmallocinfo 命令 , 可以统计输出 通过 vmalloc 函数分配的 " 虚拟地址连续的内存块 " ; 参考输出内容

5.2K30
您找到你想要的搜索结果了吗?
是的
没有找到

Linux系统内核升级

Linux 内核版本管理 Linux kernel官网:https://kernel.org/ Active kernel releases(查看EOL信息):https://kernel.org/category...Prepatch Prepatch 或 “RC” 内核是主要的内核预发行版本,主要针对内核开发人员和 Linux 爱好者。必须从源代码进行编译,并且通常包含必须在可以放入稳定版本之前进行测试的新功能。...-5.15.26.tar 配置内核功能 # 拷贝原有的内核配置文件,后续可在原有基础之上进行内核功能删减 [root@boy ~]# cd linux-5.15.26/ [root@boy linux...,开启文本界面的编译选项菜单窗口,可以对内核加载的模块编译选项进行调整,如修改编译后的内核名称、新添加之前系统缺少的模块等。...0 #0表示 /boot/grub2/grub.cfg 文件中排在第一位的 menuentry 段 # 重启系统 [root@boy ~]# reboot # 查看重启后的内核版本 [root@boy

3.7K30

Linux】项目日志——输出重定向

项目日志——输出重定向 前言 在通常情况下,Linux/UNIX每个程序在开始运行的时候,都会自动打开三个标准stream(流),分别为标准输入流stdin(文件描述符0),标准输出流stdout(文件描述符...1),标准错误输出流stderr(文件描述符2)。...Linux的本质就是一切皆文件,输入输出设备也是以文件形式存在和管理的。 stderr是不缓存的,stdout则进行行间缓存,即遇到\n才打印输出。...> 将标准输出重定向到文件 ./test > test.txt 将标准输入和标准出错重定向到文件 ./test 1 > testout.txt ....日志中最好加上日期、时间、文件等信息。 printf涉及到文件,可能会引起IO中断(会进行一系列的系统调用),因此执行printf比一般指令的效率要低很多。一般情况下不建议用printf。

1.2K20

Linux 内核系统架构

这篇文章从进程调度,内存管理,设备驱动,文件系统,网络等方面讲解Linux内核系统架构。...Linux系统架构是一个经典的设计,它优秀的分层和模块化,融合了数量繁多的设备和不同的物理架构,让世界各地的内核开发者能够高效并行工作。先来看看Linus在多年前公开Linux的邮件。...Linux系统架构图 架构非常清晰,从硬件层,硬件抽象层,内核基础模块(进程调度,内存管理,网络协议栈等)到应用层,这个基本上也是各类软硬件结合的系统架构的基础设计,例如物联网系统(从单片机,MCU等小型嵌入式系统...另外,在内核中,实现设备驱动时,外设(外部设备)的输入和输出区域可以被映射到虚拟地址空间,读写这些空间会被系统重定向到设备,从而对设备进行操作,极大地简化了驱动的实现。...大多数的内核提供的函数都能通过VFS(Virtual File System)定义的文件接口访问。例如内核系统:字符和块设备,管道,网络Socket,交互输入输出终端等。

5.1K72

Linux系统内核笔记

三大衍生版本 System V:银行、电信在使用的服务器系统 Berkley:MacOS iOS带界面的 Hybrid:Minix、Linux 三、Linux操作系统 类Uinx系统,免费开源...,它指的是系统内核,凡是使用这种内核的操作系统都叫作 Linux系统(发行板),严格意义上讲Linux指的是内核,隶属于GNU工程。...UNIX系统、免费开源,而Linux之父就是在参照这款操作 ,才写出第一个版本的Linux内核代码 GNU工程:是自由软件基金会所创立的一个开源组织,基本原则就是共享,主旨是发展出 一个有别于商业UNIX...目前Linux内核由它进行维 护,所以Linux也叫GNU Linux GPL通用公共许可证:允许对某些成果及派生成果重用、修改、复制,对所有人都是自 由的,但不能声明做了原始工作,或声明由他人所作。...系统接口 mmap/munmap Linux 调用内核 Kmalloc/vmalloc 内核 调用驱动 get_free_page 驱动 … 四、进程映像 程序是保存在磁盘上的可执行文件,加载到内存中被操作系统调用执行的程序叫进程

1.5K20

Cephfs 操作输出日志查询系统

前言 文件系统当中如果某些文件不见了,有什么办法判断是删除了还是自己不见了,这个就需要去日志里面定位了,通常情况下是去翻日志,而日志是会进行压缩的,并且查找起来非常的不方便,还有可能并没有开启 这个时候就需要日志系统了...,最近正好看到一篇最佳日志实践(v2.0),一篇非常好的文章,本篇日志属于文章里面所提到的统计日志,统计客户端做了什么操作 对于日志系统来说,很重要的一点,能够很方便的进行查询,这就需要对日志信息进行一些处理了...,filter是处理日志的模块,output是输出的模块,这里我们需要使用的是gelf的输出模式,在本地进行调试的时候,可以开启stdout来进行调试 采用grok进行正则匹配,这个里面的匹配正则可以用...通过graylog系统就可以很方便的看到日志里面节获取的内容了 总结 对于一套系统来说,日志系统是一个很重要的组成部分,可以更好的掌握系统内部的运行情况,并不是说出了问题再去找日志,这个日志的需求来源其实很简单...,对于其他日志的提取也可以用类似的方法,提取自己需要的信息,然后进行整合,输出到一个系统当中,剩下的就是在界面上获取信息

1.5K30

Linux 内核】编译 Linux 内核 ⑦ ( 安装内核模块 | 安装内核 | 重启系统 | 查看当前内核版本 )

文章目录 一、安装内核模块 二、安装内核 三、重启系统 四、查看当前内核版本 一、安装内核模块 ---- 确保 Linux 内核编译完成 , 没有任何报错之后 ; 参考 【Linux 内核】编译 Linux...内核 ⑥ ( 安装 OpenSSL | 安装其它依赖库 | 内核编译完成 ) 博客 ; 进入 Linux 内核源码的根目录 , 执行 sudo make modules_install 命令 , 安装编译好的内核模块...-5.6.14# root@ubuntu:~/kernel/linux-5.6.14# 二、安装内核 ---- 内核模块安装完成后 , 执行 sudo make install 命令 , 安装内核...; 下面的内核安装过程会持续很长时间 ; 内核安装过程 : root@ubuntu:~# cd kernel/linux-5.6.14 root@ubuntu:~/kernel/linux-5.6.14...-5.6.14# 三、重启系统 ---- 执行 reboot 命令 , 重启 Ubuntu 操作系统 ; 四、查看当前内核版本 ---- 重启之后 , 在命令行终端执行 uname -a 命令 ,

15.7K50

Linux系统手动更换内核

至于linux内核什么时候开始原生支持的,网上的说法真的是五花八门,很多人文章感觉就是互相抄,连2.6.* 的说法都能蹦出来(我怀疑是一些采集站)。...https://www.elrepo.org/elrepo-release-7.0-4.el7.elrepo.noarch.rpm 安装新内核啦 查看ELRepo仓库下,在当前系统支持的内核包 ELRepo...会提供he Linux Kernel Archives用资源。...install kernel-ml 更改grub配置 在安装完新的 Kernrl 之后,系统是不会帮你切换到新内核的,重启也不行,需要我们自己设置,将新内核设置为默认启动选项。...我们可以看到,安装完之后,内核没有切换过去,通过查看得知,新安装的内核位于第一个位置,标记为 0。这是我们需要修改/etc/default/grub文件,以便于让系统在启动时让新内核成为默认选项。

5.7K10

Linux系统内核如何升级

有些小伙伴在使用Linux系统时可能会遇到网卡不能使用,亮度不能调节,触摸板不能识别,等等问题,这些都是内核版本过低而导致,只需要把内核升级一下就可以, 下面为大家分享一下Linux系统内核升级方法。...下载内核 目前下载有很多地址,我主要使用以下两个: github上下载linux kernel ubuntu的仓库中下载linux kernel 内核需要下载那些文件?...目前ubuntu 18.04已经使用4.15版本内核linux mint 19也使用4.15版本内核。...查看当前系统安装的内核  dpkg --get-selections| grep linux1  console-setup-linux install  libselinux1:amd64 install...卸载内核 可以看到系统已经安装了多个内核版本,包括 headers 和 image ,可以删除这些来卸载旧的内核

8.6K30

十.Linux日志系统

Linux 系统中,日志文件记录了系统中包括内核、服务和其它应用程序等在内的运行信息。 在我们解决问题的时候,日志是非常有用的,它可以帮助我们快速的定位遇到的问题。...在 Cent OS 7中,日志是使用rsyslogd守护进程进行管理的,该进程是之前版本的系统中syslogd的升级版,对原有的日志系统进行了功能的扩展,提供了诸如过滤器,日志加密保护,各种配置选项,输入输出模块...使用范例 kern.* # 选择所有优先级的内核日志 mail.crit # 选择所有mail 的优先级高于crit的日志 cron...PHP 使用 syslog 输出日志 在PHP 中,调用系统日志系统的函数有三个 bool openlog ( string $ident , int $option , int $facility )...$ident是一个字符串,syslog 会将该字符串自动加到使用syslog函数输出的所有日志消息的前面。

8.7K32

10.34 linux系统日志

linux系统日志 /var/log/messages //是linux系统一个总的日志——>除非某些服务,有定义单独的日志 /etc/logrotate.conf 日志切割配置文件 参考日志文件文章...系统日志 /var/log/messages //是linux系统一个总的日志——>除非某些服务,有定义单独的日志 系统中存有一个日志切割机制,日志的滚动,在增长到一定级别了,就会自动切割...$ du -sh /var/log/messages 388K /var/log/messages 在查看日志的时候,会发现日志自动切割了 linux系统中有一个logrotate服务,会自动切割日志...日志是由 syslogd 服务决定的,所以 kill -HUP 就会重新加载这个日志 还有一个脚本,shell命令行,在把日志切割后(挪走),改名字生成新的日志 Linux系统有一个特点,一个服务写一个文件的时候...但是一重启这个系统,又会生成这些日志 /var/log/dmesg日志文件 /var/log/dmesg //这是一个日志文件 这个日志文件和 dmesg命令 没有任何关联 它是系统启动的一个日志

12.4K61

Linux系统日志介绍

默认日志类型可以分为三类:系统日志、登录日志和程序日志。不同类型的Linux系统对各日志存放路径及文件名页不尽相同,对于ubuntu和Centos系统默认将生成的日志保存在“/var/log”目录。...如表下所示为Linux系统的默认日志类型及其存放信息如下所示: 系统默认日志类型 ‍/var/log/messages 记录Linux内核消息及各种应用程序的公共日志信息 /var/log/cron 记录...crond 计划任务产生的事件信息 var/log/dmesg 记录 Linux 操作系统在引导过程中的各种事件信息 /var/log/lastlog 记录每个用户最近的登录事件 /var/log/secure...记录系统启动有关的日志文件 wtmp日志文件用于记录每个用户登录、注销及系统的启动、停机事件。...可以利用wtmp日志文件来查看用户登录系统记录的信息。

17.6K30

Linux pstore 实现自动“抓捕”内核崩溃日志

作者简介 廖威雄,就职于珠海全志科技股份有限公司,负责Linux IO全栈研发、性能优化、开源社区开发交流、Linux 内核开源社区pstore/blk,mtdpstore模块的作者、大客户存储技术支持...简介 pstore文件系统(是的,这是个文件系统)是Persistent Storage的缩写,最早在2010年由 Tony Luck 设计并合入Linux主分支,设计的初衷是在内核Panic/Oops...时能自动转存内核日志(log_buf),在Panic重启后,把转存的日志以文件形式呈现到用户空间以分析内核崩溃问题。...在linux 2.6的安卓的内核中找到,却没有提交到社区,后来被放弃维护了。网上找不到放弃的原因,我自己猜测是因为其只适用于mtd nand,然而现在的Android基本用的都是emmc。...目前支持以下几个前端: dmesg:主要是转存Panic/Oops时log_buf里面的内核日志 pmsg:提供给用户空间存储日志的入口,在Android里有看到被用于存储系统日志

5.4K63

浅谈 Linux 内核无线子系统

浅谈 Linux 内核无线子系统 Linux 内核是如何实现无线网络接口呢?数据包是通过怎样的方式被发送和接收呢?...1 全局概览 在开始探索 Linux 无线具体细节之前,让我们先来把握一下 Linux 无线子系统整体结构。如图1,展示了 Linux 无线子系统各个模块之间的抽象关系。 ?...通常我们把 Linux 内核无线子系统看成两大块: cfg80211 和 mac80211 ,它们连通内核其他模块和用户空间的应用程序。...Linux 内核无线子系统统一各种 WiFi 设备,并处理 OSI 模型中最底层的 MAC 、 PHY 两层。 若进一步划分, MAC 层可以分为 MAC 高层和 MAC 底层。...刚才这些发生在图一中的 Data Application 模块中,最终应用程序陷入系统调用,随后在内核空间进行接下来的工作。

3.3K31
领券