## CSDN博客

### LINUX is obsolete Linux的技术过时了 Date: 29 Jan 92 12:12:50 GMT

*** EOOH *** 来自Newsgroup的论争
From: ast@cs.vu.nl (Andy Tanenbaum)
Newsgroups: comp.os.minix
Subject: LINUX is obsolete Linux的技术过时了
Date: 29 Jan 92 12:12:50 GMT
Organization: Fac. Wiskunde & Informatica, Vrije Universiteit, Amsterdam

I was in the U.S. for a couple of weeks, so I haven't commented much on
LINUX (not that I would have said much had I been around), but for what
it is worth, I have a couple of comments now.
(我来美国已有几周了，是的，我还没有就Linux发表评论，并不是时间问题，

As most of you know, for me MINIX is a hobby, something that I do in the
evening when I get bored writing books and there are no major wars,
revolutions, or senate hearings being televised live on CNN. My real
job is a professor and researcher in the area of operating systems.
（你们大多数都知道，MINIX对我而言只是一个业余爱好，每当我在夜里厌倦

As a result of my occupation, I think I know a bit about where operating
are going in the next decade or so. Two aspects stand out:
（凭我专业的感觉，我觉得就未来10年或20年里操作系统的发展方向而言，

1. MICROKERNEL VS MONOLITHIC SYSTEM
Most older operating systems are monolithic, that is, the whole operating
system is a single a.out file that runs in 'kernel mode.' This binary
contains the process management, memory management, file system and the
rest. Examples of such systems are UNIX, MS-DOS, VMS, MVS, OS/360,
MULTICS, and many more.
（1.微内核模式 VS 单组件模式

The alternative is a microkernel-based system, in which most of the OS
runs as separate processes, mostly outside the kernel. They communicate
by message passing. The kernel's job is to handle the message passing,
interrupt handling, low-level process management, and possibly the I/O.
Examples of this design are the RC4000, Amoeba, Chorus, Mach, and the
not-yet-released Windows/NT.
（另一个选择是基于微内核的操作系统，它提供的许多系统服务都是独立

While I could go into a long story here about the relative merits of the
two designs, suffice it to say that among the people who actually design
operating systems, the debate is essentially over. Microkernels have won.
The only real argument for monolithic systems was performance, and there
is now enough evidence showing that microkernel systems can be just as
fast as monolithic systems (e.g., Rick Rashid has published papers comparing
Mach 3.0 to monolithic systems) that it is now all over but the shoutin.

MINIX is a microkernel-based system. The file system and memory management
are separate processes, running outside the kernel. The I/O drivers are
also separate processes (in the kernel, but only because the brain-dead
nature of the Intel CPUs makes that difficult to do otherwise). LINUX is
a monolithic style system. This is a giant step back into the 1970s.
That is like taking an existing, working C program and rewriting it in
BASIC. To me, writing a monolithic system in 1991 is a truly poor idea.
（尽管在此我可以就两者的优缺点来一番长篇累牍的叙述，但对于

Minix是基于微内核的操作系统。文件系统与内存管理分属于内核之外

Intel处理器设计上的缺陷）
Linux是基于单组件模式的操作系统，这实际上是倒退到70年代技术，

2. PORTABILITY
Once upon a time there was the 4004 CPU. When it grew up it became an
8008. Then it underwent plastic surgery and became the 8080. It begat
the 8086, which begat the 8088, which begat the 80286, which begat the
80386, which begat the 80486, and so on unto the N-th generation. In
the meantime, RISC chips happened, and some of them are running at over
100 MIPS. Speeds of 200 MIPS and more are likely in the coming years.
These things are not going to suddenly vanish. What is going to happen
is that they will gradually take over from the 80x86 line. They will
run old MS-DOS programs by interpreting the 80386 in software. (I even
wrote my own IBM PC simulator in C, which you can get by FTP from
ftp.cs.vu.nl = 192.31.231.42 in dir minix/simulator.) I think it is a
gross error to design an OS for any specific architecture, since that is
not going to be around all that long.
MINIX was designed to be reasonably portable, and has been ported from the
Intel line to the 680x0 (Atari, Amiga, Macintosh), SPARC, and NS32016.
LINUX is tied fairly closely to the 80x86. Not the way to go.
（Intel的4004CPU是开端，然后它发展为8008，再有8080—>8088--->8086
---->80286--->80386--->80486,直到第N代。在这段时期里RISC 技术也得到

（Minix的设计具有相当的可移植性，现在支持Intel系列及680x0 (Atari, Amiga, Macintosh)
，SPARC, and NS32016，而Linux却于80x86紧密相连）（译注：这里的

Dont get me wrong, I am not unhappy with LINUX. It will get all the people
who want to turn MINIX in BSD UNIX off my back. But in all honesty, I would
suggest that people who want a **MODERN** "free" OS look around for a
microkernel-based, portable OS, like maybe GNU or something like that.

（别误解我，我并不是讨厌Linux，Linux的确会将BSD Unix用户的注意力

Andy Tanenbaum (ast@cs.vu.nl)

0 0