`
luckyclouds
  • 浏览: 111780 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

linux 2.4 和linux2.5以上 多线程的不同

阅读更多
在Linux 2.4内核中,Linux内核中使用了一个内核线程来处理用户态进程中的多个线程的上下文切换(线程切换)。
由于内核中并没有什么线程组的概念,即一个进程的多个线程,因此必须依靠在pthread库中实现一个额外的线程来管理其他用户线程(即用户程序生成的线程)的建立,
退出,资源分配和回收以及线程的切换。由于当时硬件并没有线程寄存器之类的东东来支持多线程,
因此线程的切换性能低下,并且需要引入复杂的机制在进程的栈中为各个线程划分出各自的栈数据所在位置,
并且在切换时进行栈数据拷贝。而最大的问题是内核中缺乏对线程间的同步机制的支持,
因此pthread库不得不在底层依靠信号方式来实现同步,因此线程互斥中的互斥量操作和条件量操作都转换为进程的信号操作。
pthread的实现中充斥了极其复杂的信号操作。大家都知道信号本身是低速的通信方式,因此势必拖慢了线程的实际性能。
最后的问题就是信号处理,还有由于内核对线程的无知,必须由管理线程来接收信号后投递给相应的线程,
一方面是效率低,另外一方面由于信号产生的不确定性(比如读取一个文件的时候突然出错了),要准确投递所有的信号给正确的线程难以保证。

而在IA-32硬件结构中,出现了对线程寄存器的支持,因此Pthread的线程上下文切换速度有了很大提高。但是由于硬件限制局限,线程的数量必须小于8192个,反正我是觉得已经很多了。
于是从2.5内核代码开始Linux内核采用了NPTL(Native Posix Thread Library)方式。NPTL的设计思想初稿可参考nptl-design.pdf(http://people.redhat.com/drepper/nptl-design.pdf)
首先在IA-32和x86-64位体系结构上能实现任意数量的线程数量。通过引入了TLS系统调用可以建立多个GDT全局描述符表,每个cpu维护一个描述符表,每个表项存放一个线程。
其次,clone系统调用优化了线程的建立和结束功能。也不再需要额外的调度线程的帮助就可以回收线程资源了。
其三,信号投递由内核完成,而不再需要额外的用户态管理线程的帮助,而严重错误信号之间结束整个进程。
其四,引入了新的退出系统调用exit_group()。原来的exit保留用于退出单个线程,exit_group用于退出整个进程。
其五, 新的exec调用会先结束到一个进程中的所有线程后再载入新程序的执行,而不是只结束调用的线程。
其六,所有线程的资源使用情况(cpu资源,内存资源)会报告给整个进程,而不再是只报告给初始化线程
其七,proc文件系统中只显示初始化线程的信息,而不再是所有线程的信息(上万个线程会把proc文件系统拖死)
其八, 支持线程脱离, 执行Pthread_join的线程不需要再执行no wait。
其九,由内核来维护初始化线程(变成内核线程了),并在proc文件系统中显示其状态,并维护直到所有线程退出来保证信号的投递。
其十,内核支持无限制的线程数量。
最后,允许pthread_join在子线程已死之后返回,即pthread_join的返回和子线程状态变成异步的了,提高了性能。
根据报告,NPTL中线程的启动和中止时间消耗只有Linuxthread的大约1/8,当线程数量急遽增加的时候,消耗时间的差异更加明显。
在线程间同步试验中,频繁进出临界区的时间消耗只有原来的一半。
更多的用户测试报告可以看 http://kerneltrap.org/node/422
至于如何在开发中使用NPTL可参考Migrating to Linux kernel 2.6 -- Part 5: Migrating apps to the 2.6 kernel and NPTL(http://linuxdevices.com/articles/AT6753699732.html)。需要做的事情有这么几件。
1:使用2.6的内核的系统平台
2:确定你的gcc支持NPTL
用# getconf GNU_LIBPTHREAD_VERSION命令来查看gcc的编译时的对多线程的支持方式
如果返回的是linuxthreads-0.10,说明你的gcc不支持NPTL
如果返回的是nptl-0.60这样的信息,说明你的gcc能用来编译新的NPTL
3:重新在这样的系统环境中编译你的程序,不需要改变程序中对pthread的调用(但是某些函数被取消了)

分享到:
评论

相关推荐

    Linux Kernel 2.4 Internals

    总结来说,《Linux Kernel 2.4 Internals》深入探讨了Linux内核2.4的各个方面,包括引导过程、进程管理、中断处理、虚拟文件系统和进程间通信等。这本书提供了大量的技术细节和实用示例,对于希望深入了解Linux内核...

    Linux2.5线程机制研究.pdf

    【Linux2.5线程机制研究】 Linux操作系统在2.5版本中对线程机制进行了深入的研究和改进,以应对2.4版本中线程支持的不足。线程是操作系统中实现并行计算的关键,特别是在多处理器环境中,线程可以高效利用处理器...

    linux多线程编程

    在64位Linux系统中,多线程编程可以充分利用更大的地址空间和更宽的数据路径,进一步提升程序的性能和稳定性。 #### 二、基本线程编程 **2.1 线程库** 在Linux中,主要使用pthread库来创建和管理线程。这个库提供...

    Linux多线程服务端编程:使用muduo C++网络库

    《Linux多线程服务端编程:使用muduo C++网络库》主要讲述采用现代C++在x86-64 Linux上编写多线程TCP网络服务程序的主流常规技术,重点讲解一种适应性较强的多线程服务器的编程模型,即one loop per thread。...

    linux环境下多线程编程

    ### Linux环境下多线程编程知识点总结 ...以上总结了Linux环境下多线程编程的基础知识和技术细节,这些知识点涵盖了从线程的基本概念到具体的编程实践,可以帮助开发者更好地理解和应用多线程编程技术。

    Linux内核驱动模块编程指南 (内核版本2.2, 2.4)The Linux Kernel Module Programming Guide CHS

    Linux内核驱动模块编程指南 (内核版本2.2, 2.4) The Linux Kernel Module Programming Guide CHS Linux内核驱动模块编程指南 (内核版本2.2, 2.4) Peter Jay Salzman Ori Pomerantz 版权 © 2001 Peter Jay Salzman...

    嵌入式Linux应用程序开发标准教程(第2版全)

    第9章 多线程编程 9.1 Linux线程概述 9.1.1 线程概述 9.1.2 线程机制的分类和特性 9.2 Linux线程编程 9.2.1 线程基本编程 9.2.2 线程之间的同步与互斥 9.2.3 线程属性 9.3 实验内容——“生产者消费者”实验 9.4 本...

    《多线程编程技术》

    **多线程编程**是一种软件技术,它允许在单个进程中同时执行多个代码路径,从而提高程序的执行效率和响应能力。线程作为进程内的轻量级实体,比进程更小、更灵活,并且在操作系统层面得到了支持。本文将探讨Unix环境...

    Linux内核版本号发布历史.pdf

    例如,Linux 1.0的发布标志着内核的成熟,而2.4和2.6版本则引入了多处理器支持、64位计算和更高效的线程处理。Linux 2.6.15加强了对IPv6的支持,2.6.30在文件系统和安全性方面进行了改进,2.6.32则引入了虚拟化内存...

    深入理解linux内核2nd(EN)

    通过以上章节的详细介绍,《深入理解Linux内核》第二版不仅涵盖了Linux内核的基础知识,还深入探讨了内核的关键技术和设计思想。这对于希望深入了解Linux内核工作机制的专业人士来说是一本不可多得的好书。

    Linux内核编译与裁剪

    稳定版本的主版本号通常是偶数(例如2.4、2.6),而处于开发阶段的版本则使用奇数(如2.3、2.5)。例如,`2.6`表示这是一个稳定的内核版本。 - **次版本号 (SUBLEVEL)**:次版本号用于表示在同一个主版本系列内的...

    linux网络编程-宋敬彬-part3

    4.4.1 多线程编程实例 127 4.4.2 Linux下线程创建函数pthread_create() 129 4.4.3 线程的结束函数pthread_join()和pthread_exit() 129 4.4.4 线程的属性 130 4.4.5 线程间的互斥 132 4.4.6 线程中使用信号...

    linux网络编程-宋敬彬-part2

    4.4.1 多线程编程实例 127 4.4.2 Linux下线程创建函数pthread_create() 129 4.4.3 线程的结束函数pthread_join()和pthread_exit() 129 4.4.4 线程的属性 130 4.4.5 线程间的互斥 132 4.4.6 线程中使用信号...

    基于Linux点对点聊天文件传输系统.docx

    在聊天文件传输系统中,多线程用于实现I/O流的非阻塞状态,使得客户端可以同时接收和发送消息,提高用户体验。 1.6 GTK+库 GTK+是一套用于创建图形用户界面的开源库,支持多种操作系统,包括Linux。在本系统中,...

    清华大学Linux操作系统原理与应用

    1.3.4 GNU和Linux 9 1.3.5 Linux的开发模式 10 1.4 Linux内核 10 1.4.1 Linux内核的位置 10 1.4.2 Linux内核的作用 11 1.4.3 Linux内核子系统 11 1.5 Linux内核源代码 13 1.5.1 多版本的内核源代码 13 1.5.2 Linux...

    Posix线程编程指南.rar

    线程取消 2.1 线程取消的定义 2.2 线程取消的语义 2.3 取消点 2.4 程序设计方面的考虑 2.5 与线程取消相关的pthread函数 3.线程私有数据 3.1概念及作用 3.2创建和注销 4.线程...

    深入分析Linux内核源码.pdf

    - 不同版本的Linux内核源代码存在差异,反映了技术进步和发展方向。 - **1.6.2 Linux内核源代码的结构** - 文件夹和文件的组织方式遵循一定的逻辑顺序,便于理解和维护。 - **1.6.3 从何处开始阅读源代码** - ...

    裁剪Linux、制作USB安装盘过程

    JThread库为C++提供了多线程支持,简化了多线程程序的编写。 **5.5 编译安装JRTPLIB库** JRTPLib库提供了一种用于实时传输协议(RTP)和实时控制协议(RTCP)的C++实现。 **5.6 完成对库文件SO的更新** 库文件(....

    glibc-2.5.tar.gz

    glibc 对多线程编程提供了全面的支持,包括线程创建、同步、互斥锁等功能。在glibc-2.5中,这些线程API更加健壮,能有效避免竞态条件和死锁问题。 6. **网络编程接口**: glibc 提供了丰富的网络编程接口,如...

Global site tag (gtag.js) - Google Analytics