如何记录linux终端下的操作日志
在linux终端下,为方便检查操作中可能出现的错误,以及避免屏幕滚屏的限制,我们可以把操作日志记录下来。常用的工具有 screen,script,以及tee等,通过yum install安装。
1. screen — screen manager with VT100/ANSI terminal emulatio
> screen -L
这里是我们的操作
> exit
结束后会生成一个类似这样的文件名: screenlog.0
> more screenlog.0
这样可以查看你刚才进行的操作,发现可能存在的问题
2. script — make typescript of terminal session
> script
我们的操作
> exit
生成一个这样的文件:typescript
> more typescript
这里查看我们进行的操作
3. tee – read from standard input and write to standard output and files
这个命令可以读取终端输入输出到终端或者文件中,有时候可以用来记录make等命令可能产生的输出到终端的大量内容输出到文件中去。这样可以方便记 录这些命令的日志。
> make 2>&1 | tee make.log
当然,我们也可以直接重定向到一个文件中
> make > make.log
PS: 2>&1是为了记录错误日志
if you want to filter the control symbols, try to use the "col" command like this:
$ cat screenlog.0 | col -b > screenlog
or
$ cat typescript | col -b > scriptlog
还有一个比较好用的命令tail -f
比如把输出定向到text
./run.sh>text
tail -f text 这个命令会follow输出定向文件的内容
关于script命令:
在linux的世界里,你可能经常会遇到下面的问题:
1、在用源码安装软件的时候,想要将安装过程以及编译信息记录下来,供自己研究或者给他人作为参考
2、边思考边敲命令,不断执行一些程序,然后最终想要把这些零散敲出来的程序写成脚本
命令记录bash自己就可以做到,你可以使用history来查看,编译过程中的输出记录你也可以重定向到一个文件,然后再查看。可以怎么知道哪些输出是哪些命令的结果呢??在windows下可以找一个破解的屏幕记录软件以视频的方式记录下来,在linux下不用这么麻烦,一个命令就好---script.
script命令的语法很简单(CentOS 5自带,命令更新时间:2000年;其他系统应该也有,可能更新bug更少)
script [-a] [-c COMMAND] [-f] [-q] [-t] [file]
表示将记录输出到某文件,-t表示将命令的时间输出到文件,其他选项不是很重要,不过-f可以关注一下。
如何使用:
1、最简单的使用方法
$ script
Script started, file is typescript
$ xxxx各种命令、以及输出
$ exit
exit
Script done, file is typescript
该方法下终端信息记录到默认文件typescript中,这个时候你可以使用cat查看这个文件:
$ cat typescript
Script started on 2011年12月15日 星期四 14时11分30秒
dongzhi@saturn ~ $ cd Desktop/
dongzhi@saturn Desktop $ ls
1.pdf 2.pdf FEM fk gnome-terminal.desktop
dongzhi@saturn Desktop $ cd fk
dongzhi@saturn fk $ ls
aseries.h Complex.c constants.h fk fk.pl haskell.f kernel.f Makefile prop.f
radiats.h sac.h sample_input st_fk syn tau_p.f trav.f
bessel.FF Complex.h fft.c fk.f futterman.f hk layer.h model.h radiats.c
README sacio.c source.f st_haskell.f syn.c trav
dongzhi@saturn fk $ cd
dongzhi@saturn ~ $ pwd
/export/home/dongzhi
dongzhi@saturn ~ $ exit
exit
Script done on 2011年12月15日 星期四 14时11分54秒
cat的结果给出了你执行命令的开始结束时间以及具体的命令和输出。
当然这可能无法满足你的要求。如果只是这样就可以我完全可以执行完命令之后把整个终端的内容选中复制粘
贴就OK!这样的方法也可以,只是不够简单省事,当输出很多甚至“超屏”的时候以前的命令就看不到了。
也许你会说,既然终端信息输出到文件了,那我直接查看文件不就可以了~
$ vi typescript
看一看pwd命令的输出结果:
^[]0;dongzhi@saturn:~^G[dongzhi@saturn ~]$ pa^H^[[Kwd^M
exit^M
平白无故多了很多乱七八糟的字符?这个就是最大的bug,script记录了几乎全部的字符,包括一些特殊的字
符,比如换行、退格,比如文件夹显示的颜色信息。。。。
2、更常用的方法:
$ script -a logfile -t log.time
3、关于vi时乱码的问题解决办法:
在执行script之前首先要修改几个环境变量,如下
$ export SHELL=/bin/sh
$ export PS1="u@h W $ "
$ script -a logfile
$ xxxxx各种命令操作。。。
$ exit
环境变量SHELL设置使用sh而不是bash,这样为什么可以成功我也不清楚,PS1是命令提示符,其语法参见相
关文章。
执行完之后还要记得将环境变量设置回来。
得到的结果为
Script started on 2011年12月15日 星期四 17时24分47秒
dongzhi@saturn ~ $ ls^M
backup bin data Desktop document prog split tcltk typescript^M
dongzhi@saturn ~ $ cd Desktop/^H^[[K^H^[[K^H^[[K^H^[[K^M
sh: cd: Desk: 没有那个文件或目录^M
dongzhi@saturn ~ $ cd Desktop/^M
dongzhi@saturn Desktop $ ls^M
1.pdf 2.pdf FEM fk gnome-terminal.desktop^M
dongzhi@saturn Desktop $ cd fk^M
dongzhi@saturn fk $ cd ..^M
dongzhi@saturn Desktop $ ls^M
1.pdf 2.pdf FEM fk gnome-terminal.desktop^M
dongzhi@saturn Desktop $ cd ^H^[[K^H^[[K^H^[[K^Gexit^M
exit^M
Script done on 2011年12月15日 星期四 17时25分11秒
4、一些简化
可以利用alias对上面的命令作简化,在.bashrc上修改即可。
alias script='export SHELL=/bin/sh;export PS1="u@h W $ ";script'
将环境变量改回来也有简化,
alias initscript='export SHELL=/bin/sh'
使用时执行initscript即可。
5、文件结尾^M的去除
前面的文章介绍过,但是这里dos2unix最简单也最有效,其他方法好像都有问题。
6、其他的乱码。。。
去除^M之后还是会有乱码出现,这是由于操作过程中有退格等等特殊字符。这个问题还没有解决。。。
不过现在只要细心敲键盘应该就不会出现什么bug了。
其他特殊字符的问题不知道在新script版本中有没有得到解决