当前位置: 首页 > news >正文

【linux】操作系统使用wget下载网络文件,内核tcpv4部分运行日志

打印日志代码及运行日志(多余日志被删除了些):

登录 - Gitee.comicon-default.png?t=N7T8https://gitee.com/r77683962/linux-6.9.0/commit/55a53caa06c1472398fac30113c9731cb9e3b482

测试步骤和手段:

1、清空 kern.log;

2、使用wget 下载linux-6.9.tar.gz,这里需要注意基于url 解析出来的202.120.58.157:443,因为需要基于打印的日志来验证

root@a-VMware-Virtual-Platform:/var/log# echo "" > kern.log 
root@a-VMware-Virtual-Platform:/var/log# wget https://ftp.sjtu.edu.cn/sites/ftp.kernel.org/pub/linux/kernel/v6.x/linux-6.9.tar.gz
--2024-06-18 10:56:47--  https://ftp.sjtu.edu.cn/sites/ftp.kernel.org/pub/linux/kernel/v6.x/linux-6.9.tar.gz
Resolving ftp.sjtu.edu.cn (ftp.sjtu.edu.cn)... 202.120.58.157, 2001:da8:8000:6023::230
Connecting to ftp.sjtu.edu.cn (ftp.sjtu.edu.cn)|202.120.58.157|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: 232821653 (222M) [application/octet-stream]
Saving to: ‘linux-6.9.tar.gz’

linux-6.9.tar.gz            100%[===========================================>] 222.04M  1009KB/s    in 3m 48s  

2024-06-18 11:00:36 (995 KB/s) - ‘linux-6.9.tar.gz’ saved [232821653/232821653]

3、在下载的过程中(或者搜索有代码中打印的日志搜索到时备份kern.log)

代码:
    pr_info("sk->sk_family: %u, sk->sk_portpair: %u, sk->sk_dport: %u, sk->sk_daddr: %u,  sk->sk_rcv_saddr: %u", 
                sk->sk_family, 
                sk->sk_portpair, 
                sk->sk_dport, 
                sk->sk_daddr,
                sk->sk_rcv_saddr);

在搜索日志
root@a-VMware-Virtual-Platform:/var/log# grep -Hrn "sk_family" kern.log

10:56:47.643581kernel: net/ipv4/tcp.c tcp_sendmsg TCP: sk->sk_family: 2, sk->sk_portpair: 3157441281, sk->sk_dport: 47873, sk->sk_daddr: 2637854922,  sk->sk_rcv_saddr: 1979754688
10:56:47.721334kernel: net/ipv4/tcp.c tcp_sendmsg TCP: sk->sk_family: 2, sk->sk_portpair: 3157441281, sk->sk_dport: 47873, sk->sk_daddr: 2637854922,  sk->sk_rcv_saddr: 1979754688
10:56:47.742188kernel: net/ipv4/tcp.c tcp_sendmsg TCP: sk->sk_family: 2, sk->sk_portpair: 3157441281, sk->sk_dport: 47873, sk->sk_daddr: 2637854922,  sk->sk_rcv_saddr: 1979754688
10:59:21.204456kernel: net/ipv4/tcp.c tcp_sendmsg TCP: sk->sk_family: 2, sk->sk_portpair: 3049148416, sk->sk_dport: 20480, sk->sk_daddr: 297696697,  sk->sk_rcv_saddr: 1979754688

在搜索日志的时候,首先看到 sk->sk_daddr: 2637854922和sk->sk_dport: 47873

‭2637854922‬转换成十六进制:0x‭9D3A78CA‬,然后再把每个字节转为十进制
0x9D=157
0x3A=58
0x78=120
0xCA‬=202

同理47873也是一样转换成十六进制0xBB01,把这两个字节换个位置0x01BB,再转为十进制就是443

其实就是网络字节序和主机字节序的转换,在文件系统解析也经常会碰到这样的类似转换。

这上面的结果就是Connecting to ftp.sjtu.edu.cn (ftp.sjtu.edu.cn)|202.120.58.157|:443... connected.这里的信息

这样在操作系统应用层使用wget从网络下载文件的流程,在操作系统内核运行的一部分日志解析大概就是这样的。

日志增长量是非常快的,学习的时候,需要注意。

相关文章:

  • 【ClickHouse】副本、分片集群 (六)
  • 随机产生一些江河上的坐标数据
  • 秋招突击——6/17——复习{整理昨天的面试资料}——新作{删除链表倒数第n个节点}
  • Jmeter多个请求按照比例并发压测的几种方式
  • POI:接收上传上来的excel,解析并导入到数据库
  • Kafka中的时间轮算法
  • 2024广东省职业技能大赛云计算赛项实战——Ansible部署Zabbix
  • error: the type ‘const zjloc::<lambda(const Vec2i, const Vec2i)>’
  • JAVA NIO(二) Buffer和Channel
  • Elasticsearch:倒数排序融合 - Reciprocal rank fusion - 8.14
  • go的有栈和无栈
  • C#开发-集合使用和技巧(一)常用集合和方法介绍
  • 设计模式——访问者模式
  • python从入门到精通1:注释
  • Android 屏幕适配
  • 【译】JS基础算法脚本:字符串结尾
  • 《用数据讲故事》作者Cole N. Knaflic:消除一切无效的图表
  • bootstrap创建登录注册页面
  • FineReport中如何实现自动滚屏效果
  • JAVA之继承和多态
  • Js基础——数据类型之Null和Undefined
  • Map集合、散列表、红黑树介绍
  • Python 基础起步 (十) 什么叫函数?
  • Transformer-XL: Unleashing the Potential of Attention Models
  • 从零到一:用Phaser.js写意地开发小游戏(Chapter 3 - 加载游戏资源)
  • 来,膜拜下android roadmap,强大的执行力
  • 通过npm或yarn自动生成vue组件
  • 问:在指定的JSON数据中(最外层是数组)根据指定条件拿到匹配到的结果
  • 我建了一个叫Hello World的项目
  • 一加3T解锁OEM、刷入TWRP、第三方ROM以及ROOT
  • MiKTeX could not find the script engine ‘perl.exe‘ which is required to execute ‘latexmk‘.
  • 函数计算新功能-----支持C#函数
  • 数据库巡检项
  • ​​​【收录 Hello 算法】9.4 小结
  • ​LeetCode解法汇总1276. 不浪费原料的汉堡制作方案
  • #Datawhale X 李宏毅苹果书 AI夏令营#3.13.2局部极小值与鞍点批量和动量
  • #laravel 通过手动安装依赖PHPExcel#
  • #NOIP 2014# day.2 T2 寻找道路
  • #pragam once 和 #ifndef 预编译头
  • (12)目标检测_SSD基于pytorch搭建代码
  • (c语言+数据结构链表)项目:贪吃蛇
  • (PADS学习)第二章:原理图绘制 第一部分
  • (初研) Sentence-embedding fine-tune notebook
  • (免费领源码)Python#MySQL图书馆管理系统071718-计算机毕业设计项目选题推荐
  • (十三)Java springcloud B2B2C o2o多用户商城 springcloud架构 - SSO单点登录之OAuth2.0 根据token获取用户信息(4)...
  • (转)scrum常见工具列表
  • (转)Unity3DUnity3D在android下调试
  • (最全解法)输入一个整数,输出该数二进制表示中1的个数。
  • .NET CORE Aws S3 使用
  • .net 获取某一天 在当月是 第几周 函数
  • .Net 中Partitioner static与dynamic的性能对比
  • .net连接MySQL的方法
  • .NET上SQLite的连接
  • :not(:first-child)和:not(:last-child)的用法
  • @RequestBody的使用