系统集成论坛

标题: Unix操作系统感染病毒解决方法 [打印本页]

作者: 思考的牛    时间: 2010-4-16 14:16
标题: Unix操作系统感染病毒解决方法
很多的朋友的Unix操作系统都可能不小心染上了引导型病毒,用最新的杀毒软件杀完后还是不能启动,无奈之下只好重新安装整个系统:包括操作系统、数据库系统、应用程序,再从备份磁带恢复数据,花了半天多的时间。笔者听了不由扼腕叹息,因为笔者也曾经遇到过类似的事情,但只花不到十分钟就解决了。还是先从原理 上说起吧。

Unix操作系统分区结构,这里假设Unix操作系统装在活动的第一分区。Unix操作系统中把硬件全部当做文件来管理,第一个物理硬盘是/dev/hd00,第二个物理硬盘是/dev/hd10,依此类推;第一个物理硬盘的逻辑分区从/dev/hd01到/dev/hd04,/dev/hd0a特指活动分区。主引导程序、引导0和引导1在Unix操作系统中都有备份,它们分别为/etc/masterboot、/etc/hdboot0和/etc/hdboot1。

安装Unix操作系统的机器启动过程大概是这样的:上电→BIOS检查硬件→从硬盘物理0扇区加载主引导程序→从活动分区,即Unix操作系统分区加载boot0→加载boot1→检查divvy表,找到根文件系统→装入/boot,显示引导提示boot: →装入并执行内核/Unix操作系统→启动完毕。

了解启动过程后,对本文开始提出的问题就很好处理了。首先准备应急引导盘,Unix操作系统维护人员应该是常备的,即使没有也可以立即到其它机器用mkdev fd命令做一张。用应急引导盘启动,进入软盘根文件系统,连接硬盘根文件系统
# mount /dev/hd0root /mnt

如果提示出错,检查一下根文件系统:
# fsck /dev/hd0root

再次连接,接着先恢复硬盘主引导程序:
# cp /mnt/etc/masterboot /dev/hd00

然后恢复引导0:
# cp /mnt/etc/hdboot0 /dev/hd0a

重启:


# umount /mnt  # reboot 至此故障解决。顺便说一下,如果其它原因造成Unix操作系统不能启动,除了上面两个步骤外,还可能要恢复引导1和boot文件。因为引导1在Unix操作系统分区的1KB偏移处,所以不能直接拷贝,必须用dd命令:
# dd if=/mnt/etc/hdboot1 of=/dev/hd0a seek=1 bs=1k

最后恢复boot,将根文件软盘取出,插入应急引导盘,执行:


# umount /mnt  # mount -r /dev/fd0135ds18 /mnt  # cp /mnt/boot /tmp  # umount /mnt  # mount /dev/hd0root /mnt  # cp /tmp/boot /mnt 对于SCO Unix操作系统,boot已经不存放在根文件系统下,而是存放在/boot下,上面的步骤第5行应改为:
# mount /dev/boot /mnt

恢复后执行reboot重启计算机即可。这样,我们就解决了Unix操作系统中的病毒问题。




欢迎光临 系统集成论坛 (http://bbs.xtjc.com/) Powered by Discuz! X3.1