终端(terminal)、控制台(console)、tty和shell,这些概念是我们经常听到的概念。单独说一个概念,你可能七七八八说一大堆。但具体说到这几个概念的区别,估计很多人都说不上来。今天我们就一起了解一下这几个概念的差异。
历史渊源
我们先说一下控制台和终端,这些概念都有历史渊源,如果从历史上进行了解,会更加的清晰的明白这些概念的差异。
早期计算机精贵,一台主机,连很多终端,终端为主机提供了人机接口,很多人都通过终端使用主机的资源。终端有字符哑终端和图形终端两种。
而控制台是另一种人机接口。 不通过串行线路与主机相连,直接安在主机上,这是人控制主机的第一人机接口。
可以想象成主机上有块面板,面板上方小灯闪,人得站着才能够着它(控制台),主机上面一些电缆延伸到很多人办公桌的屏幕和键盘上(终端)。
为了更加清晰的了解这些概念,我们给出一个老爷机的实物图,红色方框是具体的说明。
现在的情况
随着硬件技术的飞速发展,过去那种多人使用同一台计算机的时代已经过去。但如果我们连接数据中心的服务器的话,会出现多个人同时连接同一台服务器的情况。但此时我们并不是通过硬件终端连接的,而是通过xshell或者eterm等软件进行连接的。
随着技术的发展,linux操作系统在软件层面保留了对硬件的兼容,因此在操作系统内部出现了多种概念。下面本文逐个解释一下这些概念的差异。
- 名词解释
-------tty-------:代指所有终端设备
-------pyt-------:没有实际设备的其他虚拟终端
--pts --ptmx--:两者结合,进而实现pty,是pty的实现方法
tty(teletype):电传打字机
ttys(tty serial) :tty 串行
pty(pseudo-tty):伪君子 tty=伪终端
pts(pseudo-terminal slave):伪君子 终端 女仆=伪终端从端
ptmx(pseudo-terminal master):伪君子 终端 主人=伪终端主端
1> tty(终端设备的统称):
tty一词源于teletypes,或teletypewriters,原来指的是电传打字机,是通过串行线用打印机键盘通过阅读和发送信息的东西,后来这东西被键盘和显示器取代,所以现在叫终端比较合适。
终端是一种字符型设备,他有多种类型,通常使用tty来简称各种类型的终端设备。
2> pty(虚拟终端):
但是假如我们远程telnet到主机或使用xterm时不也需要一个终端交互么?是的,这就是虚拟终端pty(pseudo-tty)
3> pts/ptmx(pts/ptmx结合使用,进而实现pty):
pts(pseudo-terminal slave)是pty的实现方法,和ptmx(pseudo-terminal master)配合使用实现pty。
- 分类
3.类别解释
串行端口终端
历史上只有这些串口设备才被叫做终端,也即现在的串行端口终端。计算机把每个串行设备看作一个字符设备。如你所知,linux把设备当作文件,对应的设备文件名是ttys。
伪终端/模拟终端
通过x windows(图形界面)、ssh、telnet等登入主机所用的终端。成对的逻辑终端设备,包含主端和从端。有两套伪终端接口:
bsd
master(主端)为 pty[p-za-e][0-9a-f],slave(从端)为 tty[p-za-e][0-9a-f]
由于在编程时想找到合适的终端需要逐个尝试,所以使用逐渐减少
unix 98
ptmx作为master设备,每次打开获得master的信息,动态生成pts/n
并不与实际物理设备相关,大多数系统选择这个接口作为pty实现
伪终端即假的,由模拟软件(gnome-terminal,urxvt,mlterm,xterm、konsole等)模拟出来的终端,ctrl alt t出来的那个小黑框就是其中一种
对master的操作会反应到slave上
控制终端
控制终端是指能够控制一个、一套设备或者几套设备的终端控制器;
/dev/tty是一个应用程序概念,面对进程;
/dev/tty会映射到当前使用的终端,使用命令tty查看其当前指向的“设备”
x windows下(图形化界面):映射到pts,也即你开启的是伪终端
哑字符界面下(alt fn):映射到tty1-6中的一个,也即控制台虚拟终端
tty(控制终端)会映射到你正在使用的任何类型的终端上,用tty命令查看
控制台终端/virtual consoles虚拟控制台
控制台终端(/dev/ttyn)是在系统视频监视器上全屏的显示终端;
其特殊性在于系统自动创建了64或6或10个(说法不一),且与cosloe关联;
tty0较特殊,指向当前控制台终端,即你正在使用的ttyn;有些ttyn,如tty1,tty2可能由图形化界面占用;
图形界面下:alt fn(ttyn)切换
哑终端下:ctrl alt fn(ttyn)切换
- 其他名称解释
哑终端(瘦客户端)
早期的计算机终端是通过串行rs-232通信的,它只能解释有限数量的控制码(cr,lf
等),但没有能力处理执行特殊的转义序列功能(如清行、清屏或控制光标的位置)。
总之就是很有限,很基本的终端;
x windows下按ctrl alt fn(n为特定数字时是x windows),其他时候按alt fn;
你得到的虚拟控制台终端,就是模仿的字符哑终端。
智能终端(胖客户端)
智能终端就是有能力处理转义序列,也就是说处理能力较强的终端机。
虚拟终端
本质上现代的终端都虚拟化了,但虚拟终端可特指伪终端,或者说模拟终端
串行端口终端需要外接一个真的物理上的终端,一般个人pc很少用到
控制终端比较特殊,是对其他的终端映射和管理,指的是当前用到的那个终端
控制台终端也叫虚拟控制台,可以理解为虚拟终端的高权限版本
所以,一般人在pc上会打开的都属于虚拟终端
虚拟控制台
与控制台终端同义,注意不要混淆虚拟终端与虚拟控制台,虚拟终端广义上包含虚拟控制台。
现代控制台
- 控制台与终端区别
控制台:直接连到机器上的物理主终端(primary teminal)
终端:文本的输入输出环境
console:/dev/console是系统控制台,必須打開支持控制台的物理实际设备;本质上是一种访问内核的方式;一边基于pc的显示器键盘等物理控制台,一边面向用户。
在一些操作系统(比如linux和freebsd)中console有多个tty(用特定的组合键能够在这些tty之间切换)。有时他们的命名很混乱,操作系统文档可能把那些tty叫做”console“ ”virtual console“ ”virtual terminal“等
/dev/console类似一个一个缓冲结果,用来实现对内核的打印,比如内核把要打印的内容装入缓冲区,然后由console来决定打印到哪里吧(如tty0或单用户模式)。所以说/dev/console是用来外接控制台的。
- linux控制台
过去
/dev/console默认是到/dev/tty0的链接(而tty0又指当前虚拟控制台,即atl fn切换到哪);
即console -> tty0 -> ttyn;
/dev/console的指向可以改变,取决于系统配置,指向tty0,ttyn,或串行设备;
现在(linux 2.1.71开始)
/dev/console仍然默认映射到/dev/tty0;
但已完全由内核管理,控制它的映射;
如果一个终端设备要实现console功能,必须在单用户模式才能登入console,才可以向内核注册一个struct console结构(内核命令console=);
ubuntu 18.04基于linux内核v4.15,属于后一种,现在的情况
控制终端、tty0、console都是指向,但指向的范围和顺序不同
什么是shell
shell,壳,与linux的核kernel对应。顾名思义就是机器的核心外面的一层壳,用于人机交互,只要是人与电脑之间交互的接口,就可以称为 shell;
shell教程=解释器,那解释什么呢?
交互式:等待你的命令,执行你提交的命令(不止是命令行下的键盘输入,还有图形界面下的鼠标输入)
非交互式:不与你交互,直接读取放在文件中的命令并执行,这种放在文件中的命令,也被叫做脚本
误解1:常见的对shell 这个概念的误解,认为一定要是命令行的 shell 才叫 shell。其实 ,我们熟悉的 gnome、kde 等图形界面也都是 shell,只不过是 gui(图形化) shell。
误解2:混同shell与cli(命令提示符),尽管指的是命令行下的shell,这也是错的。对于命令行下的shell,cli命令提示符是shell的核心,也是shell负责交互的那一部分,但不是shell的全部。对于图形化的shell,这一负责交互的部分,当然由gui,图形界面来取代了。
gui和cli都是shell,shell既不属于系统内核,也与一般应用程序不同,它属于系统工具,可以算作操作系统的一部分,主要用来管理文件和运行程序,并提供与用户的交互。
用户 > (<) shell > (<) 操作系统内核
- shell有哪些
windows 9x下:
核是dos,图形化的壳叫windows explorer,命令行的壳叫command
linux下:
核是linux内核
命令行的壳有bash(linux一般默认) 、sh 、csh 、ksh......
图形化的壳有kde、gnome、cde、 xfce......
- shell与tty的关系
tty是与计算机的输入输出相关的
shell是与内核相关的
也即你向终端输入命令(或gui下点击鼠标),终端自己是不会解释这些命令的,它只负责输入输出,而计算机是大爷,它只认二进制,不认你的命令。真正把这些命令解释成计算机明白的语言的是shell;
shell把一些信息适当的输送到终端设备,也接收来自终端设备的输入;
你每打开一个终端,都会启动一个shell进程与之关联
在除了gui占用的控制台终端以外的字符哑终端上:shell进程在用户登陆之后才启动
shell进程也可以没有终端与之关联
对前面内容的实验
“在ubuntu 18.04中,他們已經改變了一些東西,你無法訪問tty1,它總是顯示登錄屏幕。如果您已登錄,則無法訪問tty2,因為它將成為第一個登錄用戶的gui。在tty7上顯示的兩個gui的傳統已經結束。”
- ctrl alt t(被图形化界面占用的tty2下的伪终端)
输入tty
输出/dev/pts/1
输入echo "hello" > /dev/tty
输出hello
输入echo “hello” > /dev/tty0
输出无
关机见hello
输入echo “hello”> /dev/console
输出无
关机见hello
- ctrl alt f3(编号为tty3的虚拟控制台)
输入tty
输出tty3
输入echo "hello" > /dev/tty
输出hello
输入echo “hello” > /dev/tty0
输出hello
输入echo “hello”> /dev/console
输出hello