Variables often look like $var, but they also look like $1, $*, $? and $$. Let's take a look at what all these $ values can tell you. Credit: Mike Lawrence A lot of important values are stored on Linux systems in what we call “variables,” but there are actually several types of variables and some interesting commands that can help you work with them. In a previous post, we looked at environment variables and where they are defined. In this post, we’re going to look at variables that are used on the command line and within scripts. User variables While it’s quite easy to set up a variable on the command line, there are a few interesting tricks. To set up a variable, all you need to do is something like this: $ myvar=11 $ myvar2="eleven" To display the values, you simply do this: $ echo $myvar 11 $ echo $myvar2 eleven You can also work with your variables. For example, to increment a numeric variable, you could use any of these commands: $ myvar=$((myvar+1)) $ echo $myvar 12 $ ((myvar=myvar+1)) $ echo $myvar 13 $ ((myvar+=1)) $ echo $myvar 14 $ ((myvar++)) $ echo $myvar 15 $ let "myvar=myvar+1" $ echo $myvar 16 $ let "myvar+=1" $ echo $myvar 17 $ let "myvar++" $ echo $myvar 18 With some of these, you can add more than 1 to a variable’s value. For example: $ myvar0=0 $ ((myvar0++)) $ echo $myvar0 1 $ ((myvar0+=10)) $ echo $myvar0 11 With all these choices, you’ll probably find at least one that is easy to remember and convenient to use. You can also unset a variable — basically undefining it. $ unset myvar $ echo $myvar Another interesting option is that you can set up a variable and make it read-only. In other words, once set to read-only, its value cannot be changed (at least not without some very tricky command line wizardry). That means you can’t unset it either. $ readonly myvar3=1 $ echo $myvar3 1 $ ((myvar3++)) -bash: myvar3: readonly variable $ unset myvar3 -bash: unset: myvar3: cannot unset: readonly variable You can use any of those setting and incrementing options for assigning and manipulating variables within scripts, but there are also some very useful internal variables for working within scripts. Note that you can’t reassign their values or increment them. Internal variables There are quite a few variables that can be used within scripts to evaluate arguments and display information about the script itself. $1, $2, $3 etc. represent the first, second, third, etc. arguments to the script. $# represents the number of arguments. $* represents the string of arguments. $0 represents the name of the script itself. $? represents the return code of the previously run command (0=success). $$ shows the process ID for the script. $PPID shows the process ID for your shell (the parent process for the script). Some of these variables also work on the command line but show related information: $0 shows the name of the shell you’re using (e.g., -bash). $$ shows the process ID for your shell. $PPID shows the process ID for your shell’s parent process (for me, this is sshd). If we throw all of these variables into a script just to see the results, we might do this: #!/bin/bash echo $0 echo $1 echo $2 echo $# echo $* echo $? echo $$ echo $PPID When we call this script, we’ll see something like this: $ tryme one two three /home/shs/bin/tryme If we check the process ID of the shell once the script is done running, we can see that it matches the PPID displayed within the script: $ echo $$ 10109 Of course, we're more likely to use these variables in considerably more useful ways than simply displaying their values. Let's check out some ways we might do this. Checking to see if arguments have been provided: if [ $# == 0 ]; then echo "$0 filename" exit 1 fi Checking to see if a particular process is running: ps -ef | grep apache2 > /dev/null if [ $? != 0 ]; then echo Apache is not running exit fi Verifying that a file exists before trying to access it: if [ $# -lt 2 ]; then echo "Usage: $0 lines filename" exit 1 fi if [ ! -f $2 ]; then echo "Error: File $2 not found" exit 2 else head -$1 $2 fi And in this little script, we check if the correct number of arguments have been provided, if the first argument is numeric, and if the second argument is an existing file. #!/bin/bash if [ $# -lt 2 ]; then echo "Usage: $0 lines filename" exit 1 fi if [[ $1 != [0-9]* ]]; then echo "Error: $1 is not numeric" exit 2 fi if [ ! -f $2 ]; then echo "Error: File $2 not found" exit 3 else echo top of file head -$1 $2 fi Renaming variables When writing a complicated script, it's often useful to assign names to the script's arguments rather than continuing to refer to them as $1, $2, and so on. By the 35th line, someone reading your script might have forgotten what $2 represents. It will be a lot easier on that person if you assign an important parameter's value to $filename or $numlines. #!/bin/bash if [ $# -lt 2 ]; then echo "Usage: $0 lines filename" exit 1 else numlines=$1 filename=$2 fi if [[ $numlines != [0-9]* ]]; then echo "Error: $numlines is not numeric" exit 2 fi if [ ! -f $ filename]; then echo "Error: File $filename not found" exit 3 else echo top of file head -$numlines $filename fi Of course, this example script does nothing more than run the head command to show the top X lines in a file, but it is meant to show how internal parameters can be used within scripts to help ensure the script runs well or fails with at least some clarity. Related content how-to Compressing files using the zip command on Linux The zip command lets you compress files to preserve them or back them up, and you can require a password to extract the contents of a zip file. By Sandra Henry-Stocker May 13, 2024 4 mins Linux opinion NSA, FBI warn of email spoofing threat Email spoofing is acknowledged by experts as a very credible threat. By Sandra Henry-Stocker May 13, 2024 3 mins Linux how-to The logic of && and || on Linux These AND and OR equivalents can be used in scripts to determine next actions. By Sandra Henry-Stocker May 02, 2024 4 mins Linux how-to Using the apropos command on Linux By Sandra Henry-Stocker Apr 24, 2024 3 mins Linux PODCASTS VIDEOS RESOURCES EVENTS NEWSLETTERS Newsletter Promo Module Test Description for newsletter promo module. Please enter a valid email address Subscribe