1

I have a simple bash script that's supposed to create a dump file from a database

docker exec -i container sh -c "mongodump --archive" > \
    ~/dumps/db-$(date + "%d%m%Y").dump 2> \
    ~/logs/dumps/db-$(date + "%d%m%Y").log \

I've been asked to ensure the script will handle any errors, so I attempted adding the following to the script.

docker exec -i container sh -c "mongodump --archive" > \
    ~/dumps/db-$(date + "%d%m%Y").dump 2> \
    ~/logs/dumps/db-$(date + "%d%m%Y").log \

exit_status=$?
if [ exit_status -ne 0 ]; then
    echo "An error occured while running mongodump. Exit Status: $exit_status"
fi

The above was my attempt. If the exit status is anything but 0, send an echo message with the actual exit code. The script successfully creates a dump file, however I receive the following error:

[: exit_status: integer expression expected

My assumption is that because of my log redirection, the command itself doesn't actually report a exit status on completion. But I'm not so sure. I'm still learning the ropes of Bash scripting, so any advice is appreciated.

1
  • Please always mention what shell you are using. Is that run as bash? Sh? Dash? Zsh? Ksh? It would be valid code for any of them. Commented Jan 21 at 16:19

1 Answer 1

1

The problem is that you are ending your command on a \ which suggests that the command will continue on the next line. In the first code snippet, that worked since there was nothing after that except the end of the file. However, now that you have added more stuff, your original syntax error is coming back to bite you, and the command you are actually running has become (removing the detail to show the structure):

docker exec [...] > db.dump 2> db.log exit_status=$?

Which is why this simple script reproduces your error:

#!/usr/bin/env bash
echo foo exit_status=$?
if [ exit_status -ne 0 ]; then
    echo "An error occured while running mongodump. Exit Status: $exit_status"
fi

Running that results in:

/home/terdon/scripts/foo.sh: line 6: [: exit_status: integer expression expected

Because exit_status=$? was run as part of the previous command, that means that it was simply passed as one more argument to your docker command. You ran docker ... exit_status=$?. This means it was never run as a variable assignment and so the variable exit_status is not set in your environment. Because it is not set, you get that error. It's the same you would get with any random, non-existant variable name. For instance:

$ if [ blahblah -ne 0 ]; then echo whoops; fi
bash: [: blahblah: integer expression expected

Simply remove the trailing \ from your script and it will work:

docker exec -i container sh -c "mongodump --archive" > \
    ~/dumps/db-$(date + "%d%m%Y").dump 2> \
    ~/logs/dumps/db-$(date + "%d%m%Y").log 

exit_status=$?
if [ exit_status -ne 0 ]; then
    echo "An error occured while running mongodump. Exit Status: $exit_status"
fi

Or, since you don't really need a variable, you could simplify (and fix spelling) to:

docker exec -i container sh -c "mongodump --archive" > \
    ~/dumps/db-$(date + "%d%m%Y").dump 2> \
    ~/logs/dumps/db-$(date + "%d%m%Y").log 

exit_status=$?
if [ $? -ne 0 ]; then
    echo "An error occurred while running mongodump. Exit Status: $?"
fi

Or even just:

docker exec -i container sh -c "mongodump --archive" > \
    ~/dumps/db-$(date + "%d%m%Y").dump 2> \
    ~/logs/dumps/db-$(date + "%d%m%Y").log ||
       echo "An error occurred while running mongodump. Exit Status: $?"
2
  • For some reason, even after removing the trailing / on line 3 as suggested, I got the same error. However your last suggestion worked, and seems like the cleanest method to accomplish what I'm trying to do. Your response gave more than enough insight to troubleshoot on my own, Thank you so much! Commented Jan 21 at 17:01
  • Glad I could help, @Ambre. As for the 1st approach, I'd have to see your script to tell you the details of how, but if you're getting the same error, then you are still not actually giving a value to the variable $exit_status. Commented Jan 21 at 17:41

You must log in to answer this question.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.