linux-2.6內核升級文檔


做一件事情,首先要知道自己在幹什麼,而不是盲目得升級內核,現在升級內核有點氾濫,sigh
首先讓我們先了解一下2.6內核的新特性

一、01a.模塊子系統(Module Subsystem);

            

          b.統一設備模型(Unified Device Model);

         

          c.PnP 支持


          模塊子系統發生了重大變化。
02.穩定性有所提高
爲了徹底避免內核加載或者導出正在被使用的內核模塊,或者至少爲了減少加載或者卸載模塊的同時使用該模塊的可能性
(這有時會導致系統崩潰),內核加載和導出內核模塊的過程都得到了改進。

03.統一設備模型
統一設備模型的創建是 2.6 內核最重要的變化之一。它促進了模塊接口的標準化,其目的是更好地控制和管理設備,例如:

更準確地確定系統設備。
電源管理和設備電源狀態。
改進的系統總線結構管理。

04.即插即用(PnP)支持
1.1.1 和 1.1.2 小節中提及的變化使得運行 2.6 內核的 Linux 成爲一個真正即插即用的 OS。
例如,對 ISA PnP 擴展、遺留 MCA 和 EISA 總線以及熱插拔設備的 PnP 支持。

05.內核基礎設施的變化
爲了區別以 .o 爲擴展名的常規對象文件,內核模塊現在使用的擴展名是 .ko。
創建了新的 sysfs 文件系統,當內核發現設備樹時就會描述它。
內存支持,NUMA 支持
支持更大數量的 RAM
2.6 內核支持更大數量的 RAM,在分頁模式下最高可達 64GB。

06.NUMA
對非一致內核訪問(Non-Uniform Memory Access - NUMA)系統的支持是 2.6 內核中新出現的。

07.線程模型,NPTL
相對於 v2.4 的 LinuxThreads,在版本 2.6 中新出現的是 NPTL(Native POSIX Threading Library)。
NPTL 爲 Linux 帶來了企業級線程支持,提供的性能遠遠超過了 LinuxThreads。它所基於的用戶與內核線程的比率是 1:1。

在 2003 年 10 月,GNU C 程序庫 glibc 中融入了 NPTL 支持,Red Hat 率先在 Red Hat Linux 9 和
Red Hat Enterprise Linux 中使用定製的 v2.4 內核實現了 NPTL。

08.性能改進
新的調度器算法
2.6 Linux 內核引入了新的 O(1) 算法。在高負載情況下它運行得特別好。新的調度器基於每個 CPU 來分佈時間片,
這樣就消除了全局同步和重新分配循環,從而提高了性能。

內核搶佔(Kernel Preemption)
新的 2.6 內核是搶佔式的。這將顯著地提高交互式和多媒體應用程序的性能。

I/O 性能改進
Linux 的 I/O 子系統也發生了重大的變化,通過修改 I/O 調度器來確保不會有進程駐留在隊列中過長時間等待進行輸入/輸出操作,
這樣就使得 I/O 操作的響應更爲迅速。

快速用戶空間互斥(Fast User-Space Mutexes)
“futexes”(快速用戶空間互斥)可以使線程串行化以避免競態條件,引入它也提高了響應速度。
通過在內核空間中部分實現“futexes”以允許基於競爭設置等待任務的優先級而實現改進。

09.擴展性改進
處理器數目更多
Linux 內核 2.6 最多可以支持 64 個 CPU。支持更大的內存,歸功於 PAE(物理地址擴展,Physical Address Extensions),在 32-位系統上分頁模式下所支持的內存增加到了 64GB。

用戶和組
惟一用戶和組的數量從 65,000 增至 40 多億,也就是從 16-位增加到了 32-位。

PID 的數量
PID 的最大數量從 32,000 增至 10 億。

打開文件描述符的數量
打開文件描述符的數量沒有增加,但是不再需要事先設置該參數,它將自行調節。

10.支持更多的設備
在 Linux 內核 2.6 之前,內核中有可以約束大型系統的限制,比如每條鏈 256 個設備。v2.6 內核徹底地打破了這些限制,
不但可以支持更多類型的設備,而且支持更多同類型的設備。在 Linux 2.6 系統中,可以支持 4095 種主要的設備類型,
每一個單獨的類型可以有超過一百萬個子設備。
文件系統大小
Linux 內核 2.6 所允許的可尋址文件系統大小最大爲 16 TB。

11.文件系統
ext2、ext3 和 ReiserFS 等傳統 Linux 文件系統得到了顯著的改進。最值得注意的改進是擴展屬性(或文件元數據)的引入。
最重要的是 POSIX ACL 的實現,這是對普通 UNIX 權限的擴展,可以支持更細化的用戶訪問控制。

12.除了對傳統 Linux 文件系統的改進支持以外,新的內核完全支持在 Linux 中相對較新的 XFS 文件系統。
Linux 2.6 內核現在還引入了對 NTFS 文件系統的改進的支持,現在允許以讀/寫模式安裝 NTFS 文件系統。

基於以上2.6的新特性,我決定用2.6的內核,我的系統爲Red Hat Enterprise Linux AS release 3 (Taroon Update 3)
硬件環境爲DELL 2850

一、下載解壓並打上內核補丁
我以2.6.10爲例子,patche以bk4的例子,目的只是讓大家知道怎麼打patch,
其實本人用的是2.6.6的內核,因爲在AS3.0上升級到2.6.9以上的內核,
mount大的nfs網絡硬盤時,df 顯示不正確,明明是800G的盤變成4.2G,
不過還是能正常用,我升級過nfs和mount的包都沒用,/var/log/message裏
提示是kernel: nfs warning: mount version older than kernel
還望知道的 告知一聲,謝 :) BTW:2.6.8的內核沒用過

內核源代碼:http://www.kernel.org/pub/linux/kernel/v2.6/linux-2.6.10.tar.bz2
最新內核補丁:http://www.kernel.org/pub/linux/kernel/v2.6/snapshots/patch-2.6.10-bk4.bz2

cd /usr/src
rm -rf linux
tar jxf /download/linux-2.6.10.tar.bz2
ln -s linux-2.6.10 linux
cd linux
bunzip2 -dv /download/patch-2.6.10-bk4.bz2 |patch -p1
如果在/usr/src目錄下就用patch -p0

二、修改內核源代碼 (升級2.6就是爲了優化,乾脆連源代碼也改了吧)

1.修改/usr/src/linux/include/linux/posix_types.h
設置fd_set支持的最大數量
#define __FD_SETSIZE 1024 ---> 65536

2.修改/usr/src/linux/include/linux/fs.h
設置最大打開文件數量(TCP連接數量)
#define INR_OPEN 1024 ---> 65536
#define NR_FILE 8192 ---> 65536
#define NR_RESERVED_FILES 10 ---> 128

3.修改/usr/src/linux/include/net/tcp.h
設置TIMEOUT的時間爲1秒
#define TCP_TIMEWAIT_LEN (60*HZ) 60 ---> 1*HZ
設置在backlog隊列裏的半連接的重試次數,每次都會花相應的時間,本質上 也是減少重試時間
#define TCP_SYNACK_RETRIES 5 ---> 3

針對RHEL-AS3本來就是穩定+優化的,不過就算你用 RHEL-AS3 自己的內核,那也要修改一下上面的參數纔好呀 :)

三、安裝必要的工具

1.下載module-init-tools-3.1.tar.bz2
http://www.kernel.org/pub/linux/utils/kernel/module-init-tools/module-init-tools-3.1.tar.bz2

代碼:
        ./configure --prefix=/
        make moveold
        make all install
        ./generate-modprobe.conf /etc/modprobe.conf


2.下載新的mkinitrd
ftp://195.220.108.108/linux/6/fedora/core/3/i386/os/Fedora/RPMS/mkinitrd-4.1.18-2.i386.rpm
它需要lvm2 device-mapper
ftp://195.220.108.108/linux/6/fedora/core/3/i386/os/Fedora/RPMS/device-mapper-1.00.19-2.i386.rpm
ftp://195.220.108.108/linux/6/fedora/core/3/i386/os/Fedora/RPMS/lvm2-2.00.25-1.01.i386.rpm
如果不更新這個包在make install時會提示以下錯誤:

代碼:
        No module mptbase found for kernel 2.6.10-bk4, aborting.
        mkinitrd failed
        make[1]: *** [install] Error 1
        make: *** [install] Error 2


安裝lvm2-2.00.25-1.01.i386.rpm時請用rpm -ivh --nodeps package name

四、make menuconfig

代碼:
01.Code maturity level options    --->
        [*] Prompt for development and/or incomplete code/drivers                 
        [*]   Select only drivers expected to compile cleanly                           
    02.General setup  --->
        [*] Support for paging of anonymous memory (swap)                     
        [*] System V IPC                                                                 
        [*] POSIX Message Queues                                                         
        [ ] BSD Process Accounting                                                     
        [*] Sysctl support                                                                 
        [ ] Auditing support                                                               
        [ ] Support f

 

 [*] Kernel Userspace Events                                                        
 [ ] Kernel .config support                                                          
 [*] Configure standard kernel features (for small systems)  --->    
  [*]   Load all symbols for debugging/kksymoops 

 

[ ]     Do an extra kallsyms pass                                                     
              [*]   Enable futex support                                                           
              [*]   Enable eventpoll support                                                       
              [ ]   Optimize for size                                                               
              [*]   Use full shmem filesystem
    03.Loadable module support  --->         
        [*] Enable loadable module support                                         
        [*]   Module unloading                                                       
        [ ]     Forced module unloading                                             
        [ ]   Module versioning support (EXPERIMENTAL)                               
        [ ]   Source checksum for all modules                                       
        [*]   Automatic kernel module loading
    04.Processor type and features  ---> 
           Subarchitecture Type (PC-compatible)  --->   
           Processor family (Pentium-4/Celeron(P4-based)/Pentium-4 M/Xeon)  --->   
       [*] Generic x86 support                                   
       [ ] HPET Timer Support                                     
       [*] Symmetric multi-processing support      多CPU               
       (8)   Maximum number of CPUs (2-255)                       
       [*]   SMT (Hyperthreading) scheduler support               
       [*] Preemptible Kernel                     搶佔式內核,請選上它   
       [ ] Machine Check Exception                               
       < > Toshiba Laptop support                                 
       < > Dell laptop support                                   
       < > /dev/cpu/microcode - Intel IA32 CPU microcode support 
       < > /dev/cpu/*/msr - Model-specific register support       
       < > /dev/cpu/*/cpuid - CPU information support             
           Firmware Drivers  --->                                 
           High Memory Support (4GB)  --->         高內存             
       [ ] Allocate 3rd-level pagetables from highmem             
       [ ] Math emulation                                         
       [*] MTRR (Memory Type Range Register) support             
       [*] Enable kernel irq balancing                           
       [ ] Use register arguments (EXPERIMENTAL)       
    05.Power management options (ACPI, APM)  --->    電源管理 自定 (偶沒選)
    06.Bus options (PCI, PCMCIA, EISA, MCA, ISA)  ---> 板卡支持  自定
        [*] PCI support                                                                   
        PCI access mode (Any)  --->                                               
        [ ] Message Signaled Interrupts (MSI and MSI-X)                               
        [*] Legacy /proc/pci interface                                                   
        [*] PCI device name database                                                     
        [ ] ISA support                                                                   
        [ ] MCA support                                                                   
        < > NatSemi SCx200 support
    07.Executable file formats  --->
        [*] Kernel support for ELF binaries                                               
        <M> Kernel support for a.out and ECOFF binaries                                 
        <M> Kernel support for MISC binaries       
    08.Device Drivers  --->   設備驅動及網絡支持
         Generic Driver Options  --->  默認
            [*] Select only drivers that don't need compile-time external firmware                   
            [*] Prevent firmware from being built    &

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章