
Host OS: SUSE Pro 9.3
vmware: 4.5.2 for linux (any-any-update89)
Virtual OS: SLES9 两台 (SLES9serv1, SLES9serv2)
关键词:
Linux, console, serial, vmware, console loglevel
Linux 的系统的 console 可以重定向到串口,系统的 console 消息可以通过终端软件记录下来,对分析系统的故障
很有帮助。 由于没有串口线,所以只好借助 vmware 来测试这个功能了。
vmware 4.5.2 支持将串口创建为命名管道(在 linux 下实际是socket)
具体的做法如 vmware 文档 file:///usr/lib/vmware/help-manual/devices_serial_ws.htm 所介绍的方法
In the server virtual machine
Open the virtual machine settings editor (VM >Settings).
Click Add to start the Add Hardware Wizard.
Select Serial Port, then click Next.
Select Output to named pipe, then click Next.
In the Path field, enter /tmp/ or another Unix socket name of your choice.
Select This end is the server.
Select The other end is a virtual machine.
By default, the device status setting is Connect at power on. You may deselect this setting if you wish.
In the client virtual machine
Open the virtual machine settings editor (VM >Settings).
Click Add to start the Add Hardware Wizard.
Select Serial Port, then click Next.
Select Output to named pipe, then click Next.
In the Path field, enter /tmp/ or another Unix socket name of your choice. The pipe name must be the same on both server and client.
Select This end is the client.
Select The other end is a virtual machine.
By default, the device status setting is Connect at power on. You may deselect this setting if you wish.
直接使用输出重定向到你想要的文件即可,不过将所有的控制到信息输出到一个文本文件,只有两个办法:①:修改所有程序的输出路径:printf函数 echo.....几乎是不可能完成的任务
②:修改linux的标准输出路径:
句柄 句柄的数字代号 描述
STDIN 0 键盘输入
STDOUT1 输出到命令提示符窗口
STDERR2 错误输出到命令提示符窗口
将标准输出 标准输出的默认设置更改为你要保存的文件,这样就会控制台的信息就会输出到你指定的文件里面
输出重定向 :
我们使用 >或者 >>对输出进行重定向。 符号的左边表示文件描述符,如果没有的话表示1,也就是标准输出, 符号的右边可以是一个文件,也可以是一个输出设备(Linux中万物皆文件,即设备也是文件)。当使用>时,会判断右边的文件存不存在,如果存在的话就先删除,然后创建一个新的文件,不存在的话则直接创建。但是当使用>>进行追加时,则不会删除原来已经存在的文件。
格式 :
command-line [n]>文件
这条命令意思是:将一条命令执行结果(标准输出,或者错误输出,本来都要打印到屏幕上面的) 重定向其它输出设备(文件)1,2分别是标准输出,错误输出。
实例 :
输入重定向
在理解了输出重定向之后,理解输入重定向就会容易得多。对输入重定向的基本命令如下:
我们使用 <对输入做重定向, 如果符号左边没有写值,那么默认就是0。
格式:
command-line [n] <文件
命令默认从键盘获得的输入,使用输入重定向改成从文件,或者其它打开文件以及设备输入。执行这个命令,将标准输入0,与文件或设备绑定,将由它进行输入。
实例:
文件描述符的复制表示复制文件描述符到另一个文件描述符中,也就是将该文件描述符重定向到另一个文件描述符所绑定的文件,使用”&”进行复制。
想必很多人都知道 >file 2>&1 的作用,它等价于 &>file ,表示标准输出和标准错误都重定向到file中。那它和 2>&1 >file 有什么区别呢?
首先解释 >file 2>&1 。这里分两个过程:先打开file,再将fd=1重定向到file文件上,这样file文件就成了标准输出的输出目标;之后再将fd=2复制于fd=1,而fd=1此时已经重定向到file文件上,因此fd=2也重定向到file上。所以,最终的结果是标准输出重定向到file上,标准错误也重定向到file上。
再解释 2>&1 >file 。这里也分两个过程:先将fd=2复制于fd=1,而此时fd=1重定向的文件是默认的/dev/stdout,所以fd=2也重定向到/dev/stdout;之后再将fd=1重定向到file文件上。也就是说,这里的标准错误和标准输出仍然是分开输出的,只不过是使用/dev/stdout替代了/dev/stderr,使用file替代了/dev/stdout。所以,最终的结果是标准错误输出到/dev/stdout,即屏幕上,而标准输出将输出到file文件中。
可以使用下面的命令来测试 2>&1 >file 。第一个ls命令是正确的,结果输出到/tmp/fff.log中,第二个ls命令是错误的,结果将直接输出到屏幕上。
最后需要说明的是一种特殊情况,如果是 >&[word] ,且word不是一个数值,比如 echo haha >&/tmp/fff.log ,那么 >&word 和 &>word 是等价的,都表示 >word 2>&1 ,即标准错误和标准输出都重定向同一个目标。参考man bash的”Redirecting Standard Output and Standard Error”段落。
如果在命令中直接改变重定向的位置,那么命令执行结束的时候描述符会自动还原。正如上面的ls /boot 2>&1 >/tmp/fff.log命令,在ls执行结束后,fd=2还原回默认的/dev/stderr,fd=1还原回默认的/dev/stdout。
但是我们可以通过exec程序直接在当前的shell环境下改变重定向目标,只有在当前shell退出的时候才会释放描述符的绑定。
Tips :shell的内建命令exec将并不启动新的shell,而是用要被执行命令替换当前的shell进程,并且将老进程的环境清理掉,而且exec命令后的其它命令将不再执行。
不过,要注意一个例外,当exec命令来对文件描述符 *** 作的时候,就不会替换shell,而且 *** 作完成后,还会继续执行接下来的命令。
例如:下面的命令将标准错误fd=2指向fd=3对应的文件上。
因此,我们可能在一段程序执行结束后,需要将描述符还原到原来的位置,并关闭不再需要的描述符。毕竟描述符也是资源,是有限的(ulimit -n)。
[n]<>filename :打开filename,并指定其文件描述符为n,该描述符是可读、可写的描述符。若不指定n则默认为0,若filename文件不存在,则先创建filename文件。
文件描述符的移动表示将文件描述符1移动到描述符2上,同时关闭文件描述符1。
[n]>&digit- :将文件描述符digit代表的输出文件移动到n上,并关闭digit值的描述符。
[n]<&digit- :将文件描述符digit代表的输入文件移动到n上,并关闭digit值的描述符。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)