【操作系统】实验七 显示进程列表

简介: 【操作系统】实验七 显示进程列表

😘欢迎关注:👍点赞🙌收藏✍️留言

🏇码字不易,你的👍点赞🙌收藏❤️关注对我真的很重要,有问题可在评论区提出,感谢支持!!!

实验七 显示进程列表

一、实验目的

掌握进程结构及进程管理原理

二、实验内容

  1. 实验名称:显示进程列表
  2. 实验任务:

编写一个模块,将它作为Linux内核空间的扩展来执行,并报告模块加载时内核的当前进程信息,进一步了解用户空间和内核空间的概念。

三、实验过程记录

部分A

实验任务:查看系统已加载模块。写一个小的模块打印“hello world”。

查看已加载模块,如图所示。

编写小模块打印“hello world”

代码如下:

20191909.c文件

#include<linux/module.h>
int hello_init(void)
{
    printk("\nhello world\n");
    return 0;
}
void hello_exit(void){
    printk("\n bye bye world\n");
}
MODULE_AUTHOR("20191909");//id
MODULE_LICENSE("GPL");
module_init(hello_init);
module_exit(hello_exit);

Makefile文件

obj-m:=20191909.o
KERNELDIR ?= /lib/modules/$(shell uname -r)/build
PWD       := $(shell pwd)
default:
$(MAKE) -C $(KERNELDIR) M=$(PWD) modules

操作如下:

编译 make 如图1所示

图1

加载模块insmod 20191909.ko 如图2所示

图2

查看日志dmesg如图3所示

图3

4) 删除模块rmmod 20191909.ko 如图4所示

图4

查看日志dmesg如图5所示

图5

部分B

实验任务:设计模块遍历进程描述符链表,打印出系统的进程数目、当前进程,并尽量多地打印每个进程的信息。例如:进程PID,进程状态等。

编写代码如下:

20191909.c文件

#include <linux/init.h>
#include <linux/module.h>
#include <linux/proc_fs.h>
#include <asm/uaccess.h>
#include <linux/sched.h>
#include <linux/kernel.h>
MODULE_LICENSE("GPL");
static int num = -1;
module_param(num, int, S_IRUGO);
static __init int exp_init(void){
  struct task_struct *p = NULL;
  // for_each_process宏遍历系统中的每个进程,将其赋值给p
  printk("数量:%d",num);
  for_each_process(p)
  {
    if (num==0 )
      break;
    // 使用printk函数打印当前进程的PID和进程名称,real_parent->pid : 父进程id   __state : 状态
    printk("pid=%d,name=%s,parent_id=%d,state=%d\n", p->pid, p->comm,p->real_parent->pid,p->__state);
    num--;
  }
  return 0;
}
static __exit void exp_exit(void){
  printk("Good bye.\n");
}
module_init(exp_init);
module_exit(exp_exit);

Makefile 文件

obj-m:=20191909.o
KERNELDIR ?= /lib/modules/$(shell uname -r)/build
PWD       := $(shell pwd)
default:
$(MAKE) -C $(KERNELDIR) M=$(PWD) modules

操作如下:

编译make 如图6所示

图6

加载模块insmod 20191909.ko 如图7所示

图7

查看日志 dmesg 可以看到进程的PID、进程名称、父进程id、当前状态 如图8所示

图8

删除模块 rmmod 20191909.ko如图9所示

图9

四、实验小结

本次实验旨在通过编写Linux内核模块来了解用户空间和内核空间的概念,并掌握如何显示进程列表。实验分为两部分进行。

在实验的第一部分中,我们成功编写了一个简单的内核模块,用以打印“hello world”信息。通过编译、加载模块、查看日志和删除模块的步骤,我们确认了模块的正确加载和工作。这个过程加深了我们对内核模块生命周期管理的理解。

在实验的第二部分中,我们设计了一个更复杂的内核模块,用于遍历进程描述符链表,打印出系统的进程数目、当前进程以及尽可能多的进程信息(例如:进程PID,进程状态等)。通过这个过程,我们不仅学习了如何访问和操作内核中的进程信息,还加深了对Linux内核进程管理机制的了解。

存在的问题和注意事项:

  1. 在编写内核模块时,需要确保代码的稳定性和安全性,因为任何错误都可能导致系统崩溃或安全漏洞。
  2. 在使用printk进行调试时,应该注意其输出级别,以免产生大量的日志信息影响系统性能。
  3. 在遍历进程时,我们使用了for_each_process宏,需要了解其工作原理及如何正确使用它。
  4. 模块参数的使用提供了灵活性,但也需要注意确保传入的参数是合法的,防止模块运行时出现异常。
    有待提高的能力:
  5. 对内核编程的熟练度,包括更深入地理解内核API和内核编程的最佳实践。
  6. 对Linux内核的整体架构和机制的理解,特别是进程管理、内存管理和模块管理等方面。
  7. 调试技能的提高,包括使用更高级的内核调试工具和技术。
  8. 编写更加健壮和高效的内核代码的能力。
  9. 总体而言,本次实验不仅帮助我们实践了内核模块的编写和操作,还增进了我们对Linux内核的理解,为今后深入学习Linux内核打下了良好的基础。
相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
2天前
|
供应链 安全 数据处理
操作系统高级议题:并发控制与进程互斥技术
操作系统高级议题:并发控制与进程互斥技术
17 0
|
7天前
|
安全 Linux 应用服务中间件
操作系统引导过程 与 服务进程的控制
操作系统引导过程 与 服务进程的控制
|
7天前
|
算法 调度 UED
深入理解操作系统之进程调度策略
【5月更文挑战第30天】 在操作系统的核心功能中,进程调度策略扮演着至关重要的角色。它决定了处理器资源如何高效合理地分配给众多竞争的进程。本文将深入探讨几种常见的进程调度算法,包括先来先服务(FCFS)、短作业优先(SJF)以及多级反馈队列(MLQN),并分析它们在不同场景下的性能表现和适用性。通过模拟实验数据和性能对比,我们将揭示各调度策略的优势与局限,为系统设计者提供选择指南。
|
7天前
|
监控 算法 调度
深入理解操作系统的进程调度策略
【5月更文挑战第30天】 在现代操作系统中,进程调度策略是其核心功能之一,它直接关系到系统资源的利用效率和用户体验。本文将详细解析几种常见的进程调度算法——从简单的先来先服务(FCFS)到复杂的多级反馈队列(MLFQ),并探讨各自的优劣及适用场景。通过比较它们在不同工作负载下的表现,我们旨在为系统设计者提供选择合适调度策略的参考依据。
|
7天前
|
算法 API 调度
深入理解操作系统:进程调度与性能优化
【5月更文挑战第30天】在多任务操作系统中,进程调度是核心功能之一,它直接影响系统的整体性能和用户体验。本文深入探讨了操作系统中的进程调度机制,包括调度策略、调度算法以及它们对系统性能的影响。同时,提出了几种性能优化技术,旨在提高系统的响应速度和资源利用率。通过分析不同场景下的调度需求,本文还讨论了如何根据具体应用定制进程调度策略,以达到最优的系统表现。
|
8天前
|
算法 Linux 调度
深入理解操作系统:进程管理与调度策略
【5月更文挑战第30天】 在现代计算环境中,操作系统的进程管理是确保多任务高效运行的关键。本文将详细探讨操作系统中进程的概念、进程状态转换以及进程调度策略。通过对这些概念的分析,我们能够更好地理解操作系统如何协调和管理多个进程,以实现资源的有效利用和系统的稳定运行。
|
8天前
|
存储 缓存 监控
深度解析操作系统中的核心组件:进程管理与内存优化
【5月更文挑战第29天】 在现代计算技术的心脏,操作系统扮演着至关重要的角色。它不仅管理和控制计算机硬件资源,还为应用程序提供了一个运行环境。本文将深入探讨操作系统中的两个核心组件——进程管理和内存管理,并分析它们对系统性能的影响以及如何通过技术手段实现优化。通过对操作系统内部机制的剖析,我们将揭示这些组件是如何相互作用,以及它们如何共同提升系统的响应速度和稳定性。
|
8天前
|
负载均衡 算法 Linux
深入理解操作系统:进程调度的策略与实现
【5月更文挑战第29天】在多任务操作系统中,进程调度是核心功能之一,它决定了哪个进程将获得CPU时间以及何时获得。有效的调度策略能够显著提升系统性能、降低响应时间并增强用户体验。本文将探讨操作系统中常用的几种进程调度算法,包括先来先服务(FCFS)、短作业优先(SJF)、轮转调度(RR)以及多级反馈队列,分析各自的优势和局限性。同时,文章还将讨论如何在现代操作系统如Linux中实现这些调度策略,并通过实际案例展示调度策略对系统行为的影响。
|
8天前
|
负载均衡 算法 调度
深入理解操作系统之进程调度策略
【5月更文挑战第29天】 在多任务操作系统中,进程调度策略是核心机制之一,负责决定哪些可运行的进程将获得处理器时间以及分配多少时间。本文深入探讨了几种经典的进程调度算法,包括先来先服务(FCFS)、短作业优先(SJF)、轮转调度(RR),并分析了各自的性能指标如响应时间、等待时间和吞吐量。文章还将讨论现代操作系统中实现这些策略时的优化技术,如多级队列和多核处理。最后,我们评估了各种策略在现实世界操作系统中的应用与表现,为系统设计者提供理论参考。
|
15天前
|
存储 缓存 Linux
【Linux】进程概念(冯诺依曼体系结构、操作系统、进程)-- 详解
【Linux】进程概念(冯诺依曼体系结构、操作系统、进程)-- 详解