I want to run my script in crontab, but I have some problems...
In my script I run this command:
db2 connect to myDB2
This works fine when I run this as db2inst1 user, but when I run this script in db2inst1 crontab, I get this:
db2: command not found.
How can I solve this?
To avoid having to type the absolute path to a command, shells introduced the
$PATH
environment variable, each directory is separated by a:
and searches are done from left to right.cron
often clears the whole environment, including this$PATH
variable. Therefore, the script may behave differently in your cron compared to the behavior in the shell.Use absolute paths
Run
which db2
asdb2inst1
user to get the full path for thedb2
program. If the output is/usr/bin/db2
, your cron command would look like:Set the PATH variable
Run
echo "$PATH"
asdb2inst1
user to get the$PATH
variable and make sure this variable is available in your cron script too. For example, if the output was/usr/local/bin:/usr/bin:/bin
, you would put the next line in the top of your shell script:As answered in https://askubuntu.com/a/23438/227839, you should set
PATH
in your shell script:or in the crontab file, which will apply to all cron jobs:
You must define what db2 and myDB2 are, otherwise use the absolute location of 'file' or 'application' which want to run.
Example: