【Linux】文件创建与写入系统调用流程摸索

在终端运行测试的Shell脚本test.sh内容如下:

bash 复制代码
touch log_default.txt
echo "5678" > /var/1234.txt
touch log_none.txt
#grep -Hrn "read" /var/log/syslog
grep -Hrn "5 6 7 8" /var/log/syslog
grep -Hrn "1234" /var/log/syslog

第一行是打开日志输出(其实操作系统运行时日志是输出到/var/log/kern.log和/var/log/syslog里了,这也即是为什么我们老是去syslog文件搜索我们在内核源代码的打印信息);

第二行是把字符串写入到一个文件,这个文件原来是没有的,其实就是创建文件,写入文件;

第三行是关闭日志输出,防止日志打印太多,也防止其他无效日志打印干扰;

第四行是搜索我们向文件写入的字符串,这里为什么多加了个空格呢?是因为源代码里有空格:

详细合入hash点,这里用到了指针:

登录 - Gitee.comhttps://gitee.com/r77683962/linux-6.9.0/commit/a32dbde7098af9efea112f61c47ec43e525a6f7e

第五行是搜索我们操作的文件名,看看在操作系统层面对文件的操作,内核里边源代码对应函数的打印的流程是否正确,因为有些函数同名函数很多,不一定是我们找到的,而且代码中函数里还有各种分支,判断等等,所以也有点点难度。

grep字符串搜索日志的结果如下:

这基本上就找到了内核对文件写入的入口附近了。

相关推荐
Nick.Q9 小时前
vim插件的管理与离线安装
linux·编辑器·vim
头发还没掉光光11 小时前
HTTP协议从基础到实战全解析
linux·服务器·网络·c++·网络协议·http
小白同学_C11 小时前
Lab2-system calls && MIT6.1810操作系统工程【持续更新】
linux·c/c++·操作系统os
物理与数学11 小时前
linux内核 struct super_block
linux·linux内核
Getgit11 小时前
Linux 下查看 DNS 配置信息的常用命令详解
linux·运维·服务器·面试·maven
zhangrelay12 小时前
Linux(ubuntu)如何锁定cpu频率工作在最低能耗模式下
linux·笔记·学习
_OP_CHEN12 小时前
【Linux系统编程】(二十)揭秘 Linux 文件描述符:从底层原理到实战应用,一篇吃透 fd 本质!
linux·后端·操作系统·c/c++·重定向·文件描述符·linux文件
chem411113 小时前
玩客云 边缘AI模型 本地搭建部署 llama.cpp qwen
linux·人工智能·llama
一个平凡而乐于分享的小比特13 小时前
Linux内核中的BogoMIPS详解
linux·bogomips
橘颂TA13 小时前
【Linux 网络】TCP 拥塞控制与异常处理:从原理到实践的深度剖析
linux·运维·网络·tcp/ip·算法·职场和发展·结构与算法