Linux内核-深入理解Linux内核几个概念

简介:
  • 进程切换,调度


    当你用shell启动一个程序时,往往他是在前台工作的。 例如经常用PUTTY连接到远程服务器执行脚本的时候,如果本地网络中断后,这个时候前台进程就结束了,比较的懊恼,必须重新执行。因此有必要进行前后台进程的切换。

    例如直接在终端里输入firefox,那么会打开firefox,但当你关闭此终端或者ctrl+c强制终止时,firefox也随机关闭了。你可以在执行时后面加一个&,这样就在后台工作了。

    Shell支持作用控制,有以下命令:

    1. command  &让进程在后台运行 
    2. jobs –l 查看后台运行的进程 
    3. fg %n 让后台运行的进程n到前台来 
    4. bg %n 让进程n到后台去; 
    PS:"n"为jobs查看到的进程编号。

    1、执行命令&切换至后台 
    在Linux终端运行命令的时候,在命令末尾加上&符号,就可以让程序在后台运行 
    root@Ubuntu$ ./tcpserv01& 
    2、切换正在运行的程序到后台 
    如果程序正在前台运行,可以使用Ctrl+z 选项把程序暂停,然后用 bg %[number]命令把这个程序放到后台运行,这个步骤分为3步,如下: 
    2.1暂停程序运行CTRL+Z 
    ctrl + z跟系统任务有关的,ctrl + z可以将一个正在前台执行的命令放到后台,并且暂停。 
    [Oracle@linuxidc ~]$ sh ins.sh 
    [1]+Stopped                 ins.sh 
    2.2查看暂停的程序 
    察看jobs使用jobs或ps命令可以察看正在执行的jobs。 
    [oracle@linuxidc ~]$ jobs -l 
    [1]+  4524Stopped            ins.sh 
    jobs命令执行的结果,+表示是一个当前的作业,减号表是是当前作业之后的一个作业。 
    jobs -l选项可显示所有任务的PID,jobs的状态可以是running, stopped,Terminated 
    2.3切换程序至后台 
    bg将一个在后台暂停的命令,变成继续执行如果后台中有多个命令,可以用bg %jobnumber将选中的命令调出. 
    [oracle@linuxidc ~]$ bg %1 
    [oracle@linuxidc ~]$ jobs -l 
    [1]+  4524Running           ins.sh 
    2.4切换程序至前台 
    也可以用 fg %[number]指令把一个程序掉到前台运行 
    [oracle@linuxidc ~]$ fg %1 
    ./tcpserv01 
    2.5终止后台程序 
    也可以直接终止后台运行的程序,使用 kill 命令 
    [oracle@linuxidc ~]$ kill %1 
    但是如果任务被终止了(kill),shell 从当前的shell环境已知的列表中删除任务的进程标识;也就是说,jobs命令显示的是当前shell环境中所起的后台正在运行或者被挂起的任务信息

    http://blog.csdn.net/xiaoxiaomuyu2010/article/details/11935393 内核层面调用进程切换策略。

    http://www.cnblogs.com/zhaoyl/archive/2012/09/04/2671156.html 进程调度策略,主要与pr+nice的值有关。


  • 内核同步

    http://blog.csdn.net/weiqing1981127/article/details/8293317 其实还是处理进程竞争抢占资源的问题。


  • 内存管理:页框管理,内存区管理,连续非连续内存管理

    http://blog.csdn.net/sdulibh/article/details/26059647 很详细


  • 进程间通信:信号

    http://blog.csdn.net/ljianhui/article/details/10128731

  • VFS:磁盘文件,网络fs,特殊文件fs

    http://blog.csdn.net/heikefangxian23/article/details/51579971


  • 模块加载

    http://blog.chinaunix.net/uid-20568790-id-1632313.html

    https://wenku.baidu.com/view/7579e116581b6bd97f19eab7.html 关于IRQ值






    本文转自UVN2015  51CTO博客,原文链接:http://blog.51cto.com/10851095/1947959,如需转载请自行联系原作者


相关文章
|
9天前
|
Linux C语言
Linux内核队列queue.h
Linux内核队列queue.h
|
28天前
|
存储 Shell Linux
【Shell 命令集合 系统设置 】Linux 生成并更新内核模块的依赖 depmod命令 使用指南
【Shell 命令集合 系统设置 】Linux 生成并更新内核模块的依赖 depmod命令 使用指南
30 0
|
28天前
|
Shell Linux C语言
【Shell 命令集合 系统设置 】⭐Linux 卸载已加载的内核模块rmmod命令 使用指南
【Shell 命令集合 系统设置 】⭐Linux 卸载已加载的内核模块rmmod命令 使用指南
29 1
|
1月前
|
缓存 Ubuntu 网络协议
Linux系统编程之文件I/O函数的使用:介绍文件I/O函数的基本概念、用法和实现方式
Linux系统编程之文件I/O函数的使用:介绍文件I/O函数的基本概念、用法和实现方式
20 1
|
2天前
|
算法 Linux 调度
深入理解Linux内核的进程调度机制
【4月更文挑战第17天】在多任务操作系统中,进程调度是核心功能之一,它决定了处理机资源的分配。本文旨在剖析Linux操作系统内核的进程调度机制,详细讨论其调度策略、调度算法及实现原理,并探讨了其对系统性能的影响。通过分析CFS(完全公平调度器)和实时调度策略,揭示了Linux如何在保证响应速度与公平性之间取得平衡。文章还将评估最新的调度技术趋势,如容器化和云计算环境下的调度优化。
|
7天前
|
算法 Linux 调度
深度解析:Linux内核的进程调度机制
【4月更文挑战第12天】 在多任务操作系统如Linux中,进程调度机制是系统的核心组成部分之一,它决定了处理器资源如何分配给多个竞争的进程。本文深入探讨了Linux内核中的进程调度策略和相关算法,包括其设计哲学、实现原理及对系统性能的影响。通过分析进程调度器的工作原理,我们能够理解操作系统如何平衡效率、公平性和响应性,进而优化系统表现和用户体验。
18 3
|
14天前
|
负载均衡 算法 Linux
深度解析:Linux内核调度器的演变与优化策略
【4月更文挑战第5天】 在本文中,我们将深入探讨Linux操作系统的核心组成部分——内核调度器。文章将首先回顾Linux内核调度器的发展历程,从早期的简单轮转调度(Round Robin)到现代的完全公平调度器(Completely Fair Scheduler, CFS)。接着,分析当前CFS面临的挑战以及社区提出的各种优化方案,最后提出未来可能的发展趋势和研究方向。通过本文,读者将对Linux调度器的原理、实现及其优化有一个全面的认识。
|
14天前
|
Ubuntu Linux
Linux查看内核版本
在Linux系统中查看内核版本有多种方法:1) 使用`uname -r`命令直接显示版本号;2) 通过`cat /proc/version`查看内核详细信息;3) 利用`dmesg | grep Linux`显示内核版本行;4) 如果支持,使用`lsb_release -a`查看发行版及内核版本。
36 6
|
17天前
|
Linux 内存技术
Linux内核读取spi-nor flash sn
Linux内核读取spi-nor flash sn
14 1
|
24天前
|
存储 网络协议 Linux
【Linux 解惑 】谈谈你对linux内核的理解
【Linux 解惑 】谈谈你对linux内核的理解
23 0