linux 内核 补丁,linux版软件网站

大家好,今天来为大家解答linux 内核 补丁这个问题的一些问题点,包括linux版软件网站也一样很多人还不知道,因此呢,今天就来为大家分析分析,现在让我们一起来看看吧!如果解决了您的问题,还望您关注下本站哦,谢谢~

linux内核补丁安装方法linux内核补丁

如何给linux安装新内核?

一、获取内核源码

二、解压内核源码

首先以root帐号登录,然后进入/usr/src子目录。如果用户在安装Linux时,安装了内核的源代码,则会发现一个linux-x.y.z的子目录。该目录下存放着内核x.y.z的源代码。此外,还会发现一个指向该目录的链接linux。删除该连接,然后将新内核的源文件拷贝到/usr/src目录中,并解压:

#tarzxvfLinux-2.3.14.tar.gz

文件释放成功后,在/usr/src目录下会生成一个linux子目录。其中包含了内核2.3.14的全部源代码。将/usr/include/asm、/usr/inlude/linux、/usr/include/scsi链接到/usr/src/linux/include目录下的对应目录中。

#cd/usr/include

#rm-Rfasmlinux

#ln-s/usr/src/linux/include/asm-i386asm

#ln-s/usr/src/linux/include/linuxlinux

#ln-s/usr/src/linux/include/scsiscsi

删除源代码目录中残留的.o文件和其它从属文件。

#cd/usr/src/linux

#makemrproper

三.增量补丁

有时不需要完全重新安装,只需打增量补丁,类似升级,在内核源码树根目录运行:

patch-p1../patch-x.y.z

四.内核源码树目录:

arch:包含和硬件体系结构相关的代码,每种平台占一个相应的目录。和32位PC相关的代码存放在i386目录下,其中比较重要的包括kernel(内核核心部分)、mm(内存管理)、math-emu(浮点单元仿真)、lib(硬件相关工具函数)、boot(引导程序)、pci(PCI总线)和power(CPU相关状态)。

block:部分块设备驱动程序。

crypto:常用加密和散列算法(如AES、SHA等),还有一些压缩和CRC校验算法。

Documentation:关于内核各部分的通用解释和注释。

drivers:设备驱动程序,每个不同的驱动占用一个子目录。

fs:各种支持的文件系统,如ext、fat、ntfs等。

include:头文件。其中,和系统相关的头文件被放置在linux子目录下。

init:内核初始化代码(注意不是系统引导代码)。

ipc:进程间通信的代码。

kernel:内核的最核心部分,包括进程调度、定时器等,和平台相关的一部分代码放在arch/*/kernel目录下。

lib:库文件代码。

mm:内存管理代码,和平台相关的一部分代码放在arch/*/mm目录下。

net:网络相关代码,实现了各种常见的网络协议。

scripts:用于配置内核文件的脚本文件。

security:主要是一个SELinux的模块。

sound:常用音频设备的驱动程序等。

usr:实现了一个cpio。

在i386体系下,系统引导将从arch/i386/kernel/head.s开始执行,并进而转移到init/main.c中的main()函数初始化内核。

五.配置内核

#cd/usr/src/linux

内核配置方法有三种:

(1)命令行:makeconfig

(2)菜单模式的配置界面:makemenuconfig

(3)Xwindow:makexconfig

Linux的内核配置程序提供了一系列配置选项。对于每一个配置选项,用户可以"y"、"m"或"n"。其中"y"表示将相应特性的支持或设备驱动程序编译进内核;"m"表示将相应特性的支持或设备驱动程序编译成可加载模块,在需要时,可由系统或用户自行加入到内核中去;"n"表示内核不提供相应特性或驱动程序的支持。由于内核的配置选项非常多,本文只介绍一些比较重要的选项。

1、Codematurityleveloptions(代码成熟度选项)

Promptfordevelopmentand/orincompletecode/drivers(CONFIG_EXPERIMENTAL)如果用户想要使用还处于测试阶段的代码或驱动,可以选择“y”。如果想编译出一个稳定的内核,则要选择“n”。

2、Processortypeandfeatures(处理器类型和特色)

(1)、Processorfamily(386,486/Cx486,586/K5/5x86/6x86,Pentium/K6/TSC,PPro/6x86MX)选择处理器类型,缺省为Ppro/6x86MX。

(2)、MaximumPhysicalMemory(1GB,2GB)内核支持的最大内存数,缺省为1G。

(3)、Mathemulation(CONFIG_MATH_EMULATION)协处理器仿真,缺省为不仿真。

(4)、MTRR(MemoryTypeRangeRegister)support(CONFIG_MTRR)

选择该选项,系统将生成/proc/mtrr文件对MTRR进行管理,供Xserver使用。

(5)、Symmetricmulti-processingsupport(CONFIG_SMP)选择“y”,内核将支持对称多处理器。

3、Loadablemodulesupport(可加载模块支持)

(1)、Enableloadablemodulesupport(CONFIG_MODULES)选择“y”,内核将支持加载模块。

(2)、Kernelmoduleloader(CONFIG_KMOD)选择“y”,内核将自动加载那些可加载模块,否则需要用户手工加载。

4、Generalsetup(一般设置)

(1)、Networkingsupport(CONFIG_NET)该选项设置是否在内核中提供网络支持。

(2)、PCIsupport(CONFIG_PCI)该选项设置是否在内核中提供PCI支持。

(3)、PCIaccessmode(BIOS,Direct,Any)该选项设置Linux探测PCI设备的方式。选择“BIOS”,Linux将使用BIOS;选择“Direct”,Linux将不通过BIOS;选择“Any”,Linux将直接探测PCI设备,如果失败,再使用BIOS。

(4)Parallelportsupport(CONFIG_PARPORT)选择“y”,内核将支持平行口。

5、PlugandPlayconfiguration(即插即用设备支持)

(1)、PlugandPlaysupport(CONFIG_PNP)选择“y”,内核将自动配置即插即用设备。

(2)、ISAPlugandPlaysupport(CONFIG_ISAPNP)选择“y”,内核将自动配置基于ISA总线的即插即用设备。

6、Blockdevices(块设备)

(1)、NormalPCfloppydisksupport(CONFIG_BLK_DEV_FD)选择“y”,内核将提供对软盘的支持。

(2)、EnhancedIDE/MFM/RLLdisk/cdrom/tape/floppysupport(CONFIG_BLK_DEV_IDE)选择“y”,内核将提供对增强IDE硬盘、CDROM和磁带机的支持。

7、Networkingoptions(网络选项)

(1)、Packetsocket(CONFIG_PACKET)选择“y”,一些应用程序将使用Packet协议直接同网络设备通讯,而不通过内核中的其它中介协议。

(2)、Networkfirewalls(CONFIG_FIREWALL)选择“y”,内核将支持防火墙。

(3)、TCP/IPnetworking(CONFIG_INET)选择“y”,内核将支持TCP/IP协议。

(4)TheIPXprotocol(CONFIG_IPX)选择“y”,内核将支持IPX协议。

(5)、AppletalkDDP(CONFIG_ATALK)选择“y”,内核将支持AppletalkDDP协议。

8、SCSIsupport(SCSI支持)

如果用户要使用SCSI设备,可配置相应选项。

9、Networkdevicesupport(网络设备支持)

Networkdevicesupport(CONFIG_NETDEVICES)选择“y”,内核将提供对网络驱动程序的支持。

10、Ethernet(10or100Mbit)(10M或100M以太网)

在该项设置中,系统提供了许多网卡驱动程序,用户只要选择自己的网卡驱动就可以了。此外,用户还可以根据需要,在内核中加入对FDDI、PPP、SLIP和无线LAN(WirelessLAN)的支持。

11、Characterdevices(字符设备)

(1)、Virtualterminal(CONFIG_VT)选择“y”,内核将支持虚拟终端。

(2)、Supportforconsoleonvirtualterminal(CONFIG_VT_CONSOLE)

选择“y”,内核可将一个虚拟终端用作系统控制台。

(3)、Standard/generic(dumb)serialsupport(CONFIG_SERIAL)

选择“y”,内核将支持串行口。

(4)、Supportforconsoleonserialport(CONFIG_SERIAL_CONSOLE)

选择“y”,内核可将一个串行口用作系统控制台。

12、Mice(鼠标)

PS/2mouse(aka"auxiliarydevice")support(CONFIG_PSMOUSE)如果用户使用的是PS/2鼠标,则该选项应该选择“y”。

13、Filesystems(文件系统)

(1)、Quotasupport(CONFIG_QUOTA)选择“y”,内核将支持磁盘限额。

(2)、Kernelautomountersupport(CONFIG_AUTOFS_FS)选择“y”,内核将提供对automounter的支持,使系统在启动时自动mount远程文件系统。

(3)、DOSFATfssupport(CONFIG_FAT_FS)选择“y”,内核将支持DOSFAT文件系统。

(4)、ISO9660CDROMfilesystemsupport(CONFIG_ISO9660_FS)

选择“y”,内核将支持ISO9660CDROM文件系统。

(5)、NTFSfilesystemsupport(readonly)(CONFIG_NTFS_FS)

选择“y”,用户就可以以只读方式访问NTFS文件系统。

(6)、/procfilesystemsupport(CONFIG_PROC_FS)/proc是存放Linux系统运行状态的虚拟文件系统,该项必须选择“y”。

(7)、Secondextendedfssupport(CONFIG_EXT2_FS)EXT2是Linux的标准文件系统,该项也必须选择“y”。

14、NetworkFileSystems(网络文件系统)

(1)、NFSfilesystemsupport(CONFIG_NFS_FS)选择“y”,内核将支持NFS文件系统。

(2)、SMBfilesystemsupport(tomountWfWsharesetc.)(CONFIG_SMB_FS)

选择“y”,内核将支持SMB文件系统。

(3)、NCPfilesystemsupport(tomountNetWarevolumes)(CONFIG_NCP_FS)

选择“y”,内核将支持NCP文件系统。

15、PartitionTypes(分区类型)

该选项支持一些不太常用的分区类型,用户如果需要,在相应的选项上选择“y”即可。

16、Consoledrivers(控制台驱动)

VGAtextconsole(CONFIG_VGA_CONSOLE)选择“y”,用户就可以在标准的VGA显示方式下使用Linux了。

17、Sound(声音)

Soundcardsupport(CONFIG_SOUND)选择“y”,内核就可提供对声卡的支持。

18、Kernelhacking(内核监视)

MagicSysRqkey(CONFIG_MAGIC_SYSRQ)选择“y”,用户就可以对系统进行部分控制。一般情况下选择“n”。

六、编译内核

(一)、建立编译时所需的从属文件

#cd/usr/src/linux

#makedep

(二)、清除内核编译的目标文件

#makeclean

(三)、编译内核

#makezImage

内核编译成功后,会在/usr/src/linux/arch/i386/boot目录中生成一个新内核的映像文件zImage。如果编译的内核很大的话,系统会提示你使用makebzImage命令来编译。这时,编译程序就会生成一个名叫bzImage的内核映像文件。

(四)、编译可加载模块

如果用户在配置内核时设置了可加载模块,则需要对这些模块进行编译,以便将来使用insmod命令进行加载。

#makemodules

#makemodelus_install

编译成功后,系统会在/lib/modules目录下生成一个2.3.14子目录,里面存放着新内核的所有可加载模块。

七、启动新内核

(一)、将新内核和System.map文件拷贝到/boot目录下

#cp/usr/src/linux/arch/i386/boot/bzImage/boot/vmlinuz-2.3.14

#cp/usr/src/linux/System.map/boot/System.map-2.3.14

#cd/boot

#rm-fSystem.map

#ln-sSystem.map-2.3.14System.map

(二)、配置/etc/lilo.conf文件。在该文件中加入下面几行:

default=linux-2.3.14

image=/boot/vmlinuz-2.3.14

label=linux-2.3.14

root=/dev/hda1

read-only

(三)、使新配置生效

#/sbin/lilo

(四)、重新启动系统

#/sbin/reboot

新内核如果不能正常启动,用户可以在LILO:提示符下启动旧内核。然后查出故障原因,重新编译新内核即可。

怎样为linux内核打补丁?

1.进入你的工作文件夹(cd/usr/src/linux);

2.解压linux-2.4.18.tar.gz包(tar-zxflinux-2.4.18.tar.gz),会在当前目录生成一个名为linux-2.4.18或linux的文件夹;

3.进入此文件夹,执行zcat../patch-2.4.18.gz|patch-p2

4.结束

举例说明Linux内核版本号变化规律。?

Linux内核版本号以主版本号、次版本号、补丁级版本号三部分组成。主版本号一般来说变化较大,表示改变较大,次版本号一般变化较小,表示功能有改进,补丁级版本号一般用于修复bug等。

例如Linux内核版本号为3.10.0,表示主版本号为3,次版本号为10,补丁级版本号为0。

linux内核版本号的构成linux内核版本号

举例说明Linux内核版本号变化规律。?

Linux内核版本号以主版本号、次版本号、补丁级版本号三部分组成。主版本号一般来说变化较大,表示改变较大,次版本号一般变化较小,表示功能有改进,补丁级版本号一般用于修复bug等。

例如Linux内核版本号为3.10.0,表示主版本号为3,次版本号为10,补丁级版本号为0。

现在那个版本的linux内核比较稳定,是不是版本越高越好?

并不是版本越高越好的。一直到linux2.5版本的内核,linux都通过简单的编号来区别内核的稳定版和开发板。每个版本号用三个数字描述,由圆点分割。前两个数字用来表示版本号,第三个数字表示发布号。第一位版本号从1996年开始就没有变过。第二位版本号表示内核的类型:如果为偶数,表示稳定的内核;否则,表示开发中的内核。

然而,在linux内核2.6的开发过程中,内核版本的编号方式发生了很大变化。主要变化在于第二个数字已经不再表示一个内核是稳定版本还是正在开发中的版本。(以上摘自于:深入理解linux内核)

所以用linux2.6的版本,自己用着稳定就行了,不用老更新升级的。

如何区别Linux的版本是开发版还是稳定版?

Linux的内核版本有两种:1稳固版2开发版。

Linux内核版本号是由3个数字构成:a.b.c

a:目前发布的内核主版本。

b:偶数表示稳固版本;奇数表示开发中版本。

c:错误修补的次数。

其中第一个数字是主版本号,第二个数字是次版本号,第三个数字是修订版本号。

Linux内核版本号的规则?

Linux内核版本有两种:稳定版和开发版,Linux内核版本号由3个数字组成:r.x.y

r:目前发布的内核主版本。

x:偶数表示稳定版本;奇数表示开发中版本。

y:错误修补的次数。

内核版本号每位都代表什么?

以版本号为例:2.6.9-5.ELsmp,

r:2,主版本号

x:6,次版本号,表示稳定版本

y:9,修订版本号,表示修改的次数

头两个数字合在一齐可以描述内核系列。如稳定版的2.6.0,它是2.6版内核系列。

5:表示这个当前版本的第5次微调patch,而ELsmp指出了当前内核是为ELsmp特别调校的

EL:EnterpriseLinux;smp:表示支持多处理器,表示该内核版本支持多处理器

知识延伸

一般的有三种

1smp

2bigmem

3一般的内核

RedHatLinux开机的时候,GRUB的启动菜单会有两个选项,分别是

RedHatEnterpriseLinuxES(版本号.ELsmp)

RedHatEnterpriseLinuxES-up(版本号.EL)

这两个分别是代表什么含义呢?

其实这个就是系统开机时由GRUB引导启动-单处理器与对称多处理器启动核心文件的区别。

RedHatEnterpriseLinuxES(版本号.ELsmp)multipleprocessor(symmetricmultiprocessing)

RedHatEnterpriseLinuxES-up(版本号.EL)uniprocessor

下面就把SUSE与RedHat启动菜单内可选择的选项,列举出来

SUSE

版本号-default:SUSELinuxkernelforuniprocessormachines默认选项,支持单处理器机器

版本号-smp:SUSELinuxkernelthatsupportssymmetricmultiprocessingandupto4GBofRAM

支持4GB内存的对称多处理器机器

版本号-bigsmp:SUSELinuxkernelsupportssymmetricmultiprocessingandupto64GB

支持64GB内存的对称多处理器机器

RedHatLinux

版本号.EL:RedHatLinuxkernelforuniprocessormachines支持单处理器机器

版本号.ELhugemem:RedHatLinuxkernelthatsupportsupto64GBofRAM

支持64GB内存的对称多处理器机器

版本号.ELsmp:RedHatLinuxkernelthatsupportssymmetricmultiprocessing对称多处理器机器,支持4G内存

有些情况下你需要支持1和2特性,那么你可以:重新编译一下内核,在处理器及内存选择项上选择与你配置相对应的选项即可。

如何下载对应内核版本的源代码?

一般情况下,可以直接到官网:下载,

缺点是:对于任何内核做过特殊优化调校的发行版是不合适的,尤其是fedoraubuntu这一类的,毕竟他们在内核中打了大量的补丁,做了很多优化,如果直接使用官方源码,你就无法享受到这些东西,内核不是越新越好的越合适越好

因此最好到发行商的官网去下载,因为官方已经提供了编译好的源码rpm包。

如何使用对应的内核源码包?

以fedora官方提供的内核源码:kernel-2.6.23.9-85.fc8.src.rpm为例

首先,安装源码

#rpm-ivhkernel-2.6.23.9-85.fc8.src.rpm

然后,转换源码

转换之前,请确保/usr/src/目录下有redhat目录(一般/usr/src/是空目录)。

#rpmbuild-bp--target=$(uname-m)/usr/src/redhat/SPECS/kernel.spec

这样会将源码放置在/usr/src/redhat/BUILD/kernel-2.6.23/。

这里有两个有用的文件夹:.

linux-2.6.23.ARCH——这个是kernel.org提供的包经过Fedora补丁和升级得到的。也就是2.6.23.9-85.fc8这个打过补丁的内核

ARCH与uname-m的输出结果一致,通常为i686。如果你想得到不同的输出,你可以使用

“--target=”这个选项来进行指定。

vanilla——这个是标准的、由kernel.org提供的没有经过补丁和升级的源码。

Linux系统如何查看版本信息?

一、查看linux内核版本号

1:登录linux,在终端输入cat/proc/version

2:登录linux,在终端输入uname-a即列出linux的内核版本号。

3:在Linux终端输入unmae-a即可查看linux的内核版本号。三种方法执行效果如下图所示:

二、查看linux版本信息

1:登录到linux服务器执行lsb_release-a命令,即可查看所有版本信息。

2:登录到linux执行cat/etc/issue(切记cat后要空一格)即可看到版本信息。两种方法执行效果如下图所示:

提高Linux内核性能打补丁的秘诀linux内核打补丁

Linux内核,可以非常有效地为用户提供极其可靠和健壮的服务、功能,然而,随着其复杂的功能,Linux内核的性能现在也不太理想,提高 Linux内核性能是系统管理者的必备技能和重要任务。

性能的改进有多种方法,但我们要以最有效的方式提高 Linux内核的性能,普遍认为下载、安装和使用补丁是必不可少的一步。

首先,应将系统升级到最新内核版本,并启用安全补丁。可以到 Linux内核网站,下载最新可用的 Linux内核版本,然后执行“make”命令,将补丁部署到系统中。其次,应考虑编译及优化内核,以充分使用系统的性能。编译内核需要将 Linux内核源代码加载到本地系统中,然后可以使用支持的编译器[1]编译内核,以使其更适合目标主机。

另外,还可以使用 PAM [2]技术来提高 Linux系统的性能。PAM是一种新的登录验证模块,它允许用户登录到系统,并进行基于模块的安全检查。

最后,使用其他性能增强工具来提高 Linux内核性能。最普遍和流行的性能增强工具之一是内核调优工具[3],它可以实时跟踪系统负荷,并调整内核配置来改善性能。其他的性能增强工具还包括内核站点缓存[4]、文件缓存[5]以及进程管理程序[6]等。

从上面的信息可以看出,提高 Linux内核性能的最有效方法是安装和打补丁。下载最新的补丁、升级到最新的内核版本,并使用内核的调优工具及其他性能增强工具,都可以提高内核的性能。

[1]GNU Compiler Collection(GCC)

[2]Pluggable Authentication Modules(PAM)

[3]Kernel Tuning Tool

[4]Kernel Site Cache

[5]File Cache

[6]Process Management Programs

阅读剩余
THE END