| VB 源码 | VC 源码 | ASP源码 | JSP源码 | PHP源码 | CGI源码 | FLASH源码 | 素材模板 | C 源程序 | 站长工具 | 站长教程 |

Linux

数据库
邮件服务
Linux
Win9x/ME
Win2000/NT
WinXP/Server

本类阅读TOP10

·Linux日志管理详解
·创建iptables NAT规则
·使用Linux实现负载均衡
·在局域网中设置Linux时间服务器
·使用Linux建立IP隧道
·漂亮的国产Linux操作系统Open Desktop赏析
·构建Linux局域网
·LINUX系统初始化过程解析
·做个ADSL+Linux软路由器
·Linux下的网关设置

站内搜索

使用RPM包对RedHat进行内核升级

概述:本文讨论在RedHat中使用RedHat提供的内核rpm包手工进行内核升级的方法。将以在RedHat7.1中从2.4.2升级到2.4.3为例进行说明。

一、准备工作
1.确定是否要进行内核升级
通常需要进行内核升级是为了:
a.支持新安装的硬件设备:比如您刚买了一块新的声卡,但是当前的内核没有提供其驱动,而新版本内核可以驱动该声卡。
b.当前的系统内核被发现有安全漏洞,需要升级到新的版本进行修复。

2.确定所需下载的rpm包
首先通过以下命令确定系统当前所安装的内核包:
# rpm -qa | grep kernel
kernel-source-2.4.2-2
kernel-headers-2.4.2-2
kernel-2.4.2-2

我们需要下载这三个包的新版本,以及以下三个非内核包的新版本:
[root@test update]# rpm -qa | grep init
initscripts-5.83-1
mkinitrd-3.0.10-1
SysVinit-2.78-17

3.获取新版本内核rpm包
ftp://updates.redhat.com/7.1/en/os/i386/获取以上六个个包的新版本的rpm包,也就是:
kernel-source-2.4.3-12.i386.rpm
kernel-headers-2.4.3-12.i386.rpm
kernel-2.4.3-12.i386.rpm
SysVinit-2.78-17.i386.rpm
因为当前RedHat只发布了SysVinit-2.78-17.i386.rpm,所以就只下载了这个包。

4.检验新版本内核rpm包
为了保证下载过程不出错,使用以下命令对下载的包进行校验:
# rpm -K --nogpg *rpm
kernel-2.4.3-12.i386.rpm: md5 OK
kernel-headers-2.4.3-12.i386.rpm: md5 OK
kernel-source-2.4.3-12.i386.rpm: md5 OK
SysVinit-2.78-17.i386.rpm: md5 OK

如果校验结果为OK,说明传输过程没问题,所下载的rpm包是完整的。就可以接着做下一步,如果rpm不完整,请重新下载一次,最好使用支持断点续传的下载工具进行下载。

5.制作应急启动盘
使用以下命令制作一张系统启动盘,以便在系统升级失败后可以启动及恢复老系统:
# mkbootdisk --device /dev/fd0 2.4.2-2
Insert a disk in /dev/fd0. Any information on the disk will be lost.
Press to continue or ^C to abort:
2.4.2-2是当前的系统内核版本,可以使用以下命令进行确定:
# uname -r
2.4.2-2

二、升级内核
1.升级非内核rpm包:
#rpm –Uvh SysVinit-2.78-17.i386.rpm

2.升级内核源码rpm包:
# rpm -Uvh kernel-source-2.4.3-12.i386.rpm kernel-headers-2.4.3-12.i386.rpm
Preparing... ########################################### [100%]
1:kernel-source ########################################### [ 50%]
2:kernel-headers ########################################### [100%]

3.升级内核rpm包:
# rpm -Uvh kernel-2.4.3-12.i386.rpm
Preparing... ########################################### [100%]
1:kernel ########################################### [100%]

4.重新配置初始化RAM盘
如果系统中有SCSI设备,并且正在使用SCSI设备驱动模块,则必须重新配置初始化RAM盘,如果没有SCSI设备,可以直接跳到第5个步骤。

判断系统中是否有SCSI设备驱动模块的方法:
# more /etc/modules.conf |grep scsi
alias scsi_hostadapter megaraid
alias scsi_hostadapter1 sym53c8xx
alias scsi_hostadapter2 sym53c8xx

也即,如果这个命令有输出时,表明您的系统正在使用SCSI设备驱动模块,这时我们就必须重新配置初始化RAM盘。

所谓的RAM盘通常是用来驻留模块的,这些模块必须在内核访问相关设备(通常是SISC设备)前载入RAM盘中。

首先,查看/boot下的文件,以获取刚才安装的内核版本:
# ls -l /boot/
total 3408

-rwxr-xr-x 1 root root 2174722 Jun 9 01:57 vmlinux-2.4.3-12
lrwxrwxrwx 1 root root 16 Jul 26 22:56 vmlinuz -> vmlinuz-2.4.3-12

可见,我们新的内核版本是2.4.3-12,我们使用以下命令来创建新的RAM盘:
#mkinitrd initrd-2.4.3.img 2.4.3-12

5.更新lilo信息
更新您的lilo.conf文件如下所示:
image=/boot/vmlinuz-<新安装的内核版本号>
label=linux
root=<您的/分区>
initrd=/boot/initrd-
read-only
我的机器上的lilo.conf更新文件如下:
# more /etc/lilo.conf
boot=/dev/hda
map=/boot/map
install=/boot/boot.b
prompt
timeout=50
message=/boot/message
linear
default=linux

image=/boot/vmlinuz-2.4.3-12
label=linux
read-only
root=/dev/hda1
更新完成后,别忘了执行lilo使其生效。然后就可以重新启动了。





相关文章
  • 遭受拒绝服务攻击事件的分析及对策
  • 通过TCP/IP堆栈特征探测远程操作系统
  • 通过IP欺骗进行攻击的原理及预防
  • 远程连接作为root的用法和总结
  • 远程shell特洛伊木马病毒
  • 运用CrackLib构建安全的Unix口令
  • 调整 TCP/IP 防范攻击
  • 设置Unix启动密码
  • 解剖恶意网站代码
  • 虚拟服务器实现方法
  • 虚拟文件系统 (VFS) 简介
  • 网络最高安全指南
  • 网络安全的几项关键技术
  • 网络安全漏洞检测
  • 系统遭受入侵后使用TCT进行紧急恢复并分析
  • 系统管理进阶-内存管理
  • 系统管理员安全(2)
  • 系统管理员安全(1)
  • 系统管理员安全
  • 系统的安全检查
  • 相关软件


    下载首页关于我们广告服务联系方式常见问题隐私声明法律条款本站声明下载帮助发布软件站点地图谷歌卫星地图