Linux Know-How provides a collection of introductory texts on often needed Linux skills. |
Home Bash Guide for Beginners Writing and debugging scripts Debugging Bash scripts | |||||||||||||||||||||||
See also: Exercises - Debugging Scripts, Bash options | |||||||||||||||||||||||
Search the VIAS Library | Index | |||||||||||||||||||||||
Debugging Bash scriptsDebugging on the entire scriptWhen things don't go according to plan, you need to determine what exactly causes the script to fail. Bash provides extensive debugging features. The most common is to start up the subshell with the -x option, which will run the entire script in debug mode. Traces of each command plus its arguments are printed to standard output after the commands have been expanded but before they are executed. This is the commented-script1.sh script ran in debug mode. Note again that the added comments are not visible in the output of the script.
Debugging on part(s) of the scriptUsing the set Bash built-in you can run in normal mode those portions of the script of which you are sure they are without fault, and display debugging information only for troublesome zones. Say we are not sure what the w command will do in the example commented-script1.sh, then we could enclose it in the script like this:
Output then looks like this:
You can switch debugging mode on and off as many times as you want within the same script. The table below gives an overview of other useful Bash options: Table 2-1. Overview of set debugging options
The dash is used to activate a shell option and a plus to deactivate it. Don't let this confuse you! In the example below, we demonstrate these options on the command line:
Alternatively, these modes can be specified in the script itself, by adding the desired options to the first line shell declaration. Options can be combined, as is usually the case with UNIX commands: #!/bin/bash -xv Once you found the buggy part of your script, you can add echo statements before each command of which you are unsure, so that you will see exactly where and why things don't work. In the example commented-script1.sh script, it could be done like this, still assuming that the displaying of users gives us problems:
In more advanced scripts, the echo can be inserted to display the content of variables at different stages in the script, so that flaws can be detected:
|
|||||||||||||||||||||||
Home Bash Guide for Beginners Writing and debugging scripts Debugging Bash scripts |