热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

基于linux多核进程调度的研究,基于Linux多核进程调度的研究

摘要:在计算机技术飞快成长的今天,处理器多核技术也得到了丰富和发展,并在我们的身边影响着我们的日常生活.现在,计算机硬件的指标的日渐提升,计算机系统的复杂程度也水涨船

摘要:

在计算机技术飞快成长的今天,处理器多核技术也得到了丰富和发展,并在我们的身边影响着我们的日常生活.现在,计算机硬件的指标的日渐提升,计算机系统的复杂程度也水涨船高,所以操作系统必须努力做出及时的,有效的改善,以达到硬件资源利用率的最大化的目的,而调度系统作为操作系统中最为重要的子系统之一,它性能的表现面临着严峻的考验,选择什么样的算法,如何进行调度,在出现负载不平衡时,SMP调度系统如何做出调整,以及进行怎样的调整,才能使得软件与硬件相得益彰,这些都值得我们去深思,去探索. 本文首先对课题的背景进行了研究,概述了进程并行操作的两项技术:同时多线程SMT(Simultaneous Multi-Threading)和片上多处理器CMP(Chip Multi-Processor),并对进程,线程和它们状态之间的转换进行了介绍,接着对常见的调度策略和调度算法的基本知识进行了学习,并研究了一些Linux内核中的普遍用到的数据结构和宏操作,方便进行下一步的研究工作. 其次,以Linux2.6.36内核为研究对象,细致的分析了它目前所使用的调度机制,完全公平调度系统CFS和与多核相关的SMP调度系统,为了对调度系统有一个整体的认识,本文对内核中关于CFS的数据结构和重要函数进行了剖析,并对CFS的工作原理进行了研究,为下一步地研究做准备. 再次,通过两条主线:Linux检查系统中负载情况的时机,和针对出现负载不平衡时做出调整的策略,本文对Linux kernel中SMP的实现进行了解析,并概括了SMP的工作流程,并根据SMP的分析对已有调度系统的模型进行了改进. 最后,利用调度模型和对调度原理的分析,本文提出了一个针对SMP调度系统的基于唤醒信号的优化方案,以便于进一步的提升高速缓存的利用率.在原有的内核基础上,借助FUTEX锁机制,对优化方案进行了设计,对并Linux的相关源码进行了修改,对优化方案进行了实现,然后对使用了优化方案的内核系统和标准的内核系统分别进行了对比测试,并对结果进行了验证和分析.

展开



推荐阅读
  • 本文讨论了clone的fork与pthread_create创建线程的不同之处。进程是一个指令执行流及其执行环境,其执行环境是一个系统资源的集合。在调用系统调用fork创建一个进程时,子进程只是完全复制父进程的资源,这样得到的子进程独立于父进程,具有良好的并发性。但是二者之间的通讯需要通过专门的通讯机制,另外通过fork创建子进程系统开销很大。因此,在某些情况下,使用clone或pthread_create创建线程可能更加高效。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 本文介绍了操作系统的定义和功能,包括操作系统的本质、用户界面以及系统调用的分类。同时还介绍了进程和线程的区别,包括进程和线程的定义和作用。 ... [详细]
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 开发笔记:计网局域网:NAT 是如何工作的?
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了计网-局域网:NAT是如何工作的?相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 基于Socket的多个客户端之间的聊天功能实现方法
    本文介绍了基于Socket的多个客户端之间实现聊天功能的方法,包括服务器端的实现和客户端的实现。服务器端通过每个用户的输出流向特定用户发送消息,而客户端通过输入流接收消息。同时,还介绍了相关的实体类和Socket的基本概念。 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了软件测试知识点之数据库压力测试方法小结相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 预备知识可参考我整理的博客Windows编程之线程:https:www.cnblogs.comZhuSenlinp16662075.htmlWindows编程之线程同步:https ... [详细]
  • Android工程师面试准备及设计模式使用场景
    本文介绍了Android工程师面试准备的经验,包括面试流程和重点准备内容。同时,还介绍了建造者模式的使用场景,以及在Android开发中的具体应用。 ... [详细]
  • 本文总结了Linux下多线程执行shell脚本的4种方法,包括切换到工作目录执行、使用绝对路径执行、直接使用bash或sh执行。同时介绍了为什么需要加上"./"来执行脚本的原因。 ... [详细]
  • Java和JavaScript是什么关系?java跟javaScript都是编程语言,只是java跟javaScript没有什么太大关系,一个是脚本语言(前端语言),一个是面向对象 ... [详细]
  • 本文介绍了Java虚拟机中的垃圾收集器,包括年轻代收集器Serial收集器、ParNew收集器、Parallel Scavenge收集器,以及老年代收集器Serial Old收集器、Parallel Old收集器和CMS收集器。对每种收集器的算法和特点进行了详细解析,希望对读者有参考价值。 ... [详细]
author-avatar
zJv老方有点坑爹额B
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有