Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Redirecting command output to a variable in bash fails

I'm trying to redirect command output to a variable:

OUTPUT=$(sudo apache2ctl configtest)

and then to read it:

echo $OUTPUT

When running it the output is the following:

19:19:12 user@user ~ OUTPUT=$(sudo apache2ctl configtest)
Syntax OK
Syntax OK

But the variable stays blank. I've tried the same for other commands and everything works fine.

OUTPUT=$(ls -l)

This writes file list to variable OUTPUT so that it can be read later. What should i do to make it work?

like image 383
roman Avatar asked Apr 25 '12 16:04

roman


2 Answers

Maybe the output goes to stderr, not stdout? Try this:

OUTPUT=$(sudo apache2ctl configtest 2>&1)
like image 106
johnshen64 Avatar answered Oct 19 '22 08:10

johnshen64


For nginx possible situation when configtest can be successful with error in config files. Example:

nginx: [warn] conflicting server name "test.com" on 0.0.0.0:80, ignored
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful

for correct check errors in bash scripts need use:

if [[ $((sudo /sbin/service nginx configtest) 2>&1 | grep "failed\|warn" ) ]]; then
    echo "ERROR!!!"
else
    echo "OK!!!"
fi
like image 2
beliy Avatar answered Oct 19 '22 09:10

beliy