前几天的一篇linux定时删除服务器日志 ,有人读了,私信问题。说我写了脚本了,怎么去调试一下,类似于代码的debug。
那我们今天来聊聊。
执行脚本命令是:
sh 脚本名
bash
sh dele_log2.sh
data:image/s3,"s3://crabby-images/50cd7/50cd78d4f265d829a2f6253cb256a459939b5fff" alt=""
执行并输出。
Shell 脚本调试选项:
-v(verbose )
告诉 Shell 读取脚本时显示所有行,激活详细模式。
其实就是当命令进行读取时显示输入。
sh -v 脚本名
bash
sh -v dele_log2.sh
data:image/s3,"s3://crabby-images/b5be6/b5be69f3cdb23a13ca45057aa0520c9a38941feb" alt=""
在脚本内部增加 set -v
data:image/s3,"s3://crabby-images/6993b/6993b39ff5ae49205e50d15d68a6568d5b3e3c56" alt=""
执行sh dele_log2.sh ,和上面的sh -v dele_log2.sh 一样的效果
data:image/s3,"s3://crabby-images/4e0e1/4e0e1345563f2cbccb9596f4d4705439522c93fe" alt=""
+v:禁止打印输入
bash
sh +v dele_log2.sh
-n(noexec 或 no ecxecution)
- 指示 Shell 读取所有命令然而不执行它们,这个选项激活语法检查模式。
sh -n 脚本名
bash
sh -n dele_log2.sh
data:image/s3,"s3://crabby-images/0838d/0838daea6efb982eb9fea4b631de6fe10de57bdb" alt=""
-x(xtrace 或 execution trace )
告诉 Shell 在终端显示所有执行的命令和它们的参数。 这个选项是启用 Shell 跟踪模式。
sh -x 脚本名
bash
sh -x dele_log2.sh
data:image/s3,"s3://crabby-images/51497/5149725d52e6a7148cd9e9a41ad5af19dfde9a73" alt=""
在脚本内部增加 set -x
data:image/s3,"s3://crabby-images/0f256/0f25629cc1ad0ae8115a555f19d09f6a75cf2ba7" alt=""
执行sh dele_log2.sh ,和上面的sh -x dele_log2.sh 一样的效果
data:image/s3,"s3://crabby-images/bd19f/bd19f5cbf2bdb025ac2b4893300904a3de12173a" alt=""
+x:禁止调试。
bash
sh +x dele_log2.sh
data:image/s3,"s3://crabby-images/ec1dc/ec1dccf3199186e91ad8761e869568cc820cff87" alt=""