调试shell

bash -x script 2>t.log

例子:

bash -x test.sh 2>t.log

或在shell脚本里添加

set -xv

sh ./test.sh 2>t.log

sh脚本调用全过程会写到t.log中


set +x

取消操作


其实就是set命令在shell脚本中的使用,下附set命令说明

===========================================

set

===========================================

功能说明:设置shell。

语  法:set [+-abCdefhHklmnpPtuvx]

补充说明:set指令能设置所使用shell的执行方式,可依照不同的需求来做设置。

参  数:
 -a  标示已修改的变量,以供输出至环境变量。 
 -b  使被中止的后台程序立刻回报执行状态。 
 -C  转向所产生的文件无法覆盖已存在的文件。 
 -d  Shell预设会用杂凑表记忆使用过的指令,以加速指令的执行。使用-d参数可取消。 
 -e  若指令传回值不等于0,则立即退出shell。   
 -f   取消使用通配符。 
 -h  自动记录函数的所在位置。 
 -H Shell  可利用"!"加<指令编号>的方式来执行history中记录的指令。 
 -k  指令所给的参数都会被视为此指令的环境变量。 
 -l  记录for循环的变量名称。 
 -m  使用监视模式。 
 -n  只读取指令,而不实际执行。 
 -p  启动优先顺序模式。 
 -P  启动-P参数后,执行指令时,会以实际的文件或目录来取代符号连接。 
 -t  执行完随后的指令,即退出shell。 
 -u  当执行时使用到未定义过的变量,则显示错误信息。 
 -v  显示shell所读取的输入值。 
 -x  执行指令后,会先显示该指令及所下的参数。 
 +<参数>  取消某个set曾启动的参数。


切换shell

===========================================

进入:bash回车; 退出:exit

进入:sh回车; 退出:exit

进入:csh回车; 退出:exit

进入:ksh回车; 退出:exit

进入:zsh回车; 退出:exit



参考资料:http://www.commandlinefu.com/commands/view/3310/run-a-bash-script-in-debug-mode-show-output-and-save-it-on-a-file


你可能感兴趣的:(shell,脚本,bash)