Running bash inside cronjob
I have this cronjob to run every minute
*/1 * * * * root sh /test.sh
My /test.sh logs the result of "top" and "free" command. It works fine when I run it manually on terminal with "sh /teste.sh" and saves the output to a nice file, however when the cron job runs it only saves the result of the command "free" below. Check this please:
printf "n" >> "log_lojar_top_free.txt"
printf %s "$(date)" >> "log_lojar_top_free.txt"
printf 't' >> "log_lojar_top_free.txt"
top -b -n 3 -d 1 | grep "Cpu" | tail -n 1 | awk '/^%Cpu(s)/ {printf $2}' >> "log_lojar_top_free.txt"
printf 't' >> "log_lojar_top_free.txt"
free | awk '/^Mem:/ {printf $7}' >> "log_lojar_top_free.txt"
What is the error that is causing that only the last line (free) to have it's output loged?
linux ubuntu centos
add a comment |
I have this cronjob to run every minute
*/1 * * * * root sh /test.sh
My /test.sh logs the result of "top" and "free" command. It works fine when I run it manually on terminal with "sh /teste.sh" and saves the output to a nice file, however when the cron job runs it only saves the result of the command "free" below. Check this please:
printf "n" >> "log_lojar_top_free.txt"
printf %s "$(date)" >> "log_lojar_top_free.txt"
printf 't' >> "log_lojar_top_free.txt"
top -b -n 3 -d 1 | grep "Cpu" | tail -n 1 | awk '/^%Cpu(s)/ {printf $2}' >> "log_lojar_top_free.txt"
printf 't' >> "log_lojar_top_free.txt"
free | awk '/^Mem:/ {printf $7}' >> "log_lojar_top_free.txt"
What is the error that is causing that only the last line (free) to have it's output loged?
linux ubuntu centos
if you want to run a bash script then use bash, not sh. they're not the same thing. even if sh is a symlink to bash, bash behaves differently if called as sh rather than bash.
– cas
Oct 31 '15 at 0:51
you can do as cas suggests either by prefixing in crontab with/bin/bash
instead ofsh
, or by starting your script with a shebang line:#!/bin/bash
- see if it behaves better once you definitely have it running under bash and not some other shell. Another possibility is that you aren't looking in the right place for the output file. The cron job is running as root and since you didn't specify an output directory, only a file, it will probably save it at / - not a good place to use generally. Oh and BTW you don't need the /1.
– gogoud
Oct 31 '15 at 8:13
A quick check shows that my implementation ofcrond
writes to the user's home directory. In my case, for root that's/root
.
– roaima
Nov 3 '15 at 22:51
add a comment |
I have this cronjob to run every minute
*/1 * * * * root sh /test.sh
My /test.sh logs the result of "top" and "free" command. It works fine when I run it manually on terminal with "sh /teste.sh" and saves the output to a nice file, however when the cron job runs it only saves the result of the command "free" below. Check this please:
printf "n" >> "log_lojar_top_free.txt"
printf %s "$(date)" >> "log_lojar_top_free.txt"
printf 't' >> "log_lojar_top_free.txt"
top -b -n 3 -d 1 | grep "Cpu" | tail -n 1 | awk '/^%Cpu(s)/ {printf $2}' >> "log_lojar_top_free.txt"
printf 't' >> "log_lojar_top_free.txt"
free | awk '/^Mem:/ {printf $7}' >> "log_lojar_top_free.txt"
What is the error that is causing that only the last line (free) to have it's output loged?
linux ubuntu centos
I have this cronjob to run every minute
*/1 * * * * root sh /test.sh
My /test.sh logs the result of "top" and "free" command. It works fine when I run it manually on terminal with "sh /teste.sh" and saves the output to a nice file, however when the cron job runs it only saves the result of the command "free" below. Check this please:
printf "n" >> "log_lojar_top_free.txt"
printf %s "$(date)" >> "log_lojar_top_free.txt"
printf 't' >> "log_lojar_top_free.txt"
top -b -n 3 -d 1 | grep "Cpu" | tail -n 1 | awk '/^%Cpu(s)/ {printf $2}' >> "log_lojar_top_free.txt"
printf 't' >> "log_lojar_top_free.txt"
free | awk '/^Mem:/ {printf $7}' >> "log_lojar_top_free.txt"
What is the error that is causing that only the last line (free) to have it's output loged?
linux ubuntu centos
linux ubuntu centos
edited 2 hours ago
Guillermo Mosse
1033
1033
asked Oct 30 '15 at 22:46
SamulSamul
18117
18117
if you want to run a bash script then use bash, not sh. they're not the same thing. even if sh is a symlink to bash, bash behaves differently if called as sh rather than bash.
– cas
Oct 31 '15 at 0:51
you can do as cas suggests either by prefixing in crontab with/bin/bash
instead ofsh
, or by starting your script with a shebang line:#!/bin/bash
- see if it behaves better once you definitely have it running under bash and not some other shell. Another possibility is that you aren't looking in the right place for the output file. The cron job is running as root and since you didn't specify an output directory, only a file, it will probably save it at / - not a good place to use generally. Oh and BTW you don't need the /1.
– gogoud
Oct 31 '15 at 8:13
A quick check shows that my implementation ofcrond
writes to the user's home directory. In my case, for root that's/root
.
– roaima
Nov 3 '15 at 22:51
add a comment |
if you want to run a bash script then use bash, not sh. they're not the same thing. even if sh is a symlink to bash, bash behaves differently if called as sh rather than bash.
– cas
Oct 31 '15 at 0:51
you can do as cas suggests either by prefixing in crontab with/bin/bash
instead ofsh
, or by starting your script with a shebang line:#!/bin/bash
- see if it behaves better once you definitely have it running under bash and not some other shell. Another possibility is that you aren't looking in the right place for the output file. The cron job is running as root and since you didn't specify an output directory, only a file, it will probably save it at / - not a good place to use generally. Oh and BTW you don't need the /1.
– gogoud
Oct 31 '15 at 8:13
A quick check shows that my implementation ofcrond
writes to the user's home directory. In my case, for root that's/root
.
– roaima
Nov 3 '15 at 22:51
if you want to run a bash script then use bash, not sh. they're not the same thing. even if sh is a symlink to bash, bash behaves differently if called as sh rather than bash.
– cas
Oct 31 '15 at 0:51
if you want to run a bash script then use bash, not sh. they're not the same thing. even if sh is a symlink to bash, bash behaves differently if called as sh rather than bash.
– cas
Oct 31 '15 at 0:51
you can do as cas suggests either by prefixing in crontab with
/bin/bash
instead of sh
, or by starting your script with a shebang line: #!/bin/bash
- see if it behaves better once you definitely have it running under bash and not some other shell. Another possibility is that you aren't looking in the right place for the output file. The cron job is running as root and since you didn't specify an output directory, only a file, it will probably save it at / - not a good place to use generally. Oh and BTW you don't need the /1.– gogoud
Oct 31 '15 at 8:13
you can do as cas suggests either by prefixing in crontab with
/bin/bash
instead of sh
, or by starting your script with a shebang line: #!/bin/bash
- see if it behaves better once you definitely have it running under bash and not some other shell. Another possibility is that you aren't looking in the right place for the output file. The cron job is running as root and since you didn't specify an output directory, only a file, it will probably save it at / - not a good place to use generally. Oh and BTW you don't need the /1.– gogoud
Oct 31 '15 at 8:13
A quick check shows that my implementation of
crond
writes to the user's home directory. In my case, for root that's /root
.– roaima
Nov 3 '15 at 22:51
A quick check shows that my implementation of
crond
writes to the user's home directory. In my case, for root that's /root
.– roaima
Nov 3 '15 at 22:51
add a comment |
2 Answers
2
active
oldest
votes
As suggested by others, try to direct use the bash shebang in your script or prefix by using bash
instead of sh
. For I don't know what system you're actually running, I recently ran into trouble calling a script usign /bin/sh -c myscript.sh
under ubuntu which is a debian derivate which uses dash
instead of bash
.
Maybe this is the key to your problem.
EDIT: I've got it working with this crontab entry, done as root with crontab -e
:
*/1 * * * * /bin/bash -c "/test.sh"
Good catch redash
. However, the OP's script appears to run equivalently underbash
,sh
(for some value ofsh
) anddash
.
– roaima
Nov 3 '15 at 23:22
add a comment |
This version works for me. However, as your own script also works here I'm not entirely sure this will fix your problem.
System-wide crontab entry (omit the root
field if this is root's own crontab, as accessed with crontab -e
):
* * * * * root /root/test.sh
As far as I can detemine, your script takes the third iteration from top
and collects the CPU usermode percentage. It also collects the cached memory value from free
. Here I've dispensed with free
and extracted the same value from the third iteration of top
. Copy this script to /root/test.sh (and make it executable):
#!/bin/bash
top -b -n 3 -d 1 |
awk -v date="$(date)" '
/^%Cpu/ {cpu=$2}
/cached Mem/ {cached=$9}
END {printf "n%st%st%s", date, cpu, cached}
' >> /root/log_lojar_top_free.txt
Make the script executable:
chmod +x /root/test.sh
add a comment |
Your Answer
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "106"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f239863%2frunning-bash-inside-cronjob%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
2 Answers
2
active
oldest
votes
2 Answers
2
active
oldest
votes
active
oldest
votes
active
oldest
votes
As suggested by others, try to direct use the bash shebang in your script or prefix by using bash
instead of sh
. For I don't know what system you're actually running, I recently ran into trouble calling a script usign /bin/sh -c myscript.sh
under ubuntu which is a debian derivate which uses dash
instead of bash
.
Maybe this is the key to your problem.
EDIT: I've got it working with this crontab entry, done as root with crontab -e
:
*/1 * * * * /bin/bash -c "/test.sh"
Good catch redash
. However, the OP's script appears to run equivalently underbash
,sh
(for some value ofsh
) anddash
.
– roaima
Nov 3 '15 at 23:22
add a comment |
As suggested by others, try to direct use the bash shebang in your script or prefix by using bash
instead of sh
. For I don't know what system you're actually running, I recently ran into trouble calling a script usign /bin/sh -c myscript.sh
under ubuntu which is a debian derivate which uses dash
instead of bash
.
Maybe this is the key to your problem.
EDIT: I've got it working with this crontab entry, done as root with crontab -e
:
*/1 * * * * /bin/bash -c "/test.sh"
Good catch redash
. However, the OP's script appears to run equivalently underbash
,sh
(for some value ofsh
) anddash
.
– roaima
Nov 3 '15 at 23:22
add a comment |
As suggested by others, try to direct use the bash shebang in your script or prefix by using bash
instead of sh
. For I don't know what system you're actually running, I recently ran into trouble calling a script usign /bin/sh -c myscript.sh
under ubuntu which is a debian derivate which uses dash
instead of bash
.
Maybe this is the key to your problem.
EDIT: I've got it working with this crontab entry, done as root with crontab -e
:
*/1 * * * * /bin/bash -c "/test.sh"
As suggested by others, try to direct use the bash shebang in your script or prefix by using bash
instead of sh
. For I don't know what system you're actually running, I recently ran into trouble calling a script usign /bin/sh -c myscript.sh
under ubuntu which is a debian derivate which uses dash
instead of bash
.
Maybe this is the key to your problem.
EDIT: I've got it working with this crontab entry, done as root with crontab -e
:
*/1 * * * * /bin/bash -c "/test.sh"
edited Nov 3 '15 at 23:41
answered Nov 3 '15 at 23:19
ferdyferdy
1496
1496
Good catch redash
. However, the OP's script appears to run equivalently underbash
,sh
(for some value ofsh
) anddash
.
– roaima
Nov 3 '15 at 23:22
add a comment |
Good catch redash
. However, the OP's script appears to run equivalently underbash
,sh
(for some value ofsh
) anddash
.
– roaima
Nov 3 '15 at 23:22
Good catch re
dash
. However, the OP's script appears to run equivalently under bash
, sh
(for some value of sh
) and dash
.– roaima
Nov 3 '15 at 23:22
Good catch re
dash
. However, the OP's script appears to run equivalently under bash
, sh
(for some value of sh
) and dash
.– roaima
Nov 3 '15 at 23:22
add a comment |
This version works for me. However, as your own script also works here I'm not entirely sure this will fix your problem.
System-wide crontab entry (omit the root
field if this is root's own crontab, as accessed with crontab -e
):
* * * * * root /root/test.sh
As far as I can detemine, your script takes the third iteration from top
and collects the CPU usermode percentage. It also collects the cached memory value from free
. Here I've dispensed with free
and extracted the same value from the third iteration of top
. Copy this script to /root/test.sh (and make it executable):
#!/bin/bash
top -b -n 3 -d 1 |
awk -v date="$(date)" '
/^%Cpu/ {cpu=$2}
/cached Mem/ {cached=$9}
END {printf "n%st%st%s", date, cpu, cached}
' >> /root/log_lojar_top_free.txt
Make the script executable:
chmod +x /root/test.sh
add a comment |
This version works for me. However, as your own script also works here I'm not entirely sure this will fix your problem.
System-wide crontab entry (omit the root
field if this is root's own crontab, as accessed with crontab -e
):
* * * * * root /root/test.sh
As far as I can detemine, your script takes the third iteration from top
and collects the CPU usermode percentage. It also collects the cached memory value from free
. Here I've dispensed with free
and extracted the same value from the third iteration of top
. Copy this script to /root/test.sh (and make it executable):
#!/bin/bash
top -b -n 3 -d 1 |
awk -v date="$(date)" '
/^%Cpu/ {cpu=$2}
/cached Mem/ {cached=$9}
END {printf "n%st%st%s", date, cpu, cached}
' >> /root/log_lojar_top_free.txt
Make the script executable:
chmod +x /root/test.sh
add a comment |
This version works for me. However, as your own script also works here I'm not entirely sure this will fix your problem.
System-wide crontab entry (omit the root
field if this is root's own crontab, as accessed with crontab -e
):
* * * * * root /root/test.sh
As far as I can detemine, your script takes the third iteration from top
and collects the CPU usermode percentage. It also collects the cached memory value from free
. Here I've dispensed with free
and extracted the same value from the third iteration of top
. Copy this script to /root/test.sh (and make it executable):
#!/bin/bash
top -b -n 3 -d 1 |
awk -v date="$(date)" '
/^%Cpu/ {cpu=$2}
/cached Mem/ {cached=$9}
END {printf "n%st%st%s", date, cpu, cached}
' >> /root/log_lojar_top_free.txt
Make the script executable:
chmod +x /root/test.sh
This version works for me. However, as your own script also works here I'm not entirely sure this will fix your problem.
System-wide crontab entry (omit the root
field if this is root's own crontab, as accessed with crontab -e
):
* * * * * root /root/test.sh
As far as I can detemine, your script takes the third iteration from top
and collects the CPU usermode percentage. It also collects the cached memory value from free
. Here I've dispensed with free
and extracted the same value from the third iteration of top
. Copy this script to /root/test.sh (and make it executable):
#!/bin/bash
top -b -n 3 -d 1 |
awk -v date="$(date)" '
/^%Cpu/ {cpu=$2}
/cached Mem/ {cached=$9}
END {printf "n%st%st%s", date, cpu, cached}
' >> /root/log_lojar_top_free.txt
Make the script executable:
chmod +x /root/test.sh
answered Nov 3 '15 at 23:11
roaimaroaima
45.4k757123
45.4k757123
add a comment |
add a comment |
Thanks for contributing an answer to Unix & Linux Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f239863%2frunning-bash-inside-cronjob%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
if you want to run a bash script then use bash, not sh. they're not the same thing. even if sh is a symlink to bash, bash behaves differently if called as sh rather than bash.
– cas
Oct 31 '15 at 0:51
you can do as cas suggests either by prefixing in crontab with
/bin/bash
instead ofsh
, or by starting your script with a shebang line:#!/bin/bash
- see if it behaves better once you definitely have it running under bash and not some other shell. Another possibility is that you aren't looking in the right place for the output file. The cron job is running as root and since you didn't specify an output directory, only a file, it will probably save it at / - not a good place to use generally. Oh and BTW you don't need the /1.– gogoud
Oct 31 '15 at 8:13
A quick check shows that my implementation of
crond
writes to the user's home directory. In my case, for root that's/root
.– roaima
Nov 3 '15 at 22:51