Running bash inside cronjobHow to determine why a machine is running slowly?Why does my cronjob not execute my shell-script?Cron job running at 12.00 AM despite changing its timeHow to interpret busybox “top” output?Latexmk, from Makefile, from bash script, from Cron - Latexmk not being executedLog free and topoutput logs in crontab does not workunreasonable memory usageSFTP script not working with cron jobBash script able to run manually, but with cron not working. + Ubuntu 16.04
Professor forcing me to attend a conference, I can't afford even with 50% funding
The preposition for the verb (avenge) - avenge sb/sth (on OR from) sb
How can I portion out frozen cookie dough?
Was it really inappropriate to write a pull request for the company I interviewed with?
Are small insurances worth it?
Is there a logarithm base for which the logarithm becomes an identity function?
How to write a chaotic neutral protagonist and prevent my readers from thinking they are evil?
When to use a QR code on a business card?
How do we create new idioms and use them in a novel?
Why does Central Limit Theorem break down in my simulation?
Why restrict private health insurance?
I am the person who abides by rules, but breaks the rules. Who am I?
Is there a way to make cleveref distinguish two environments with the same counter?
The (Easy) Road to Code
What is this tube in a jet engine's air intake?
Are E natural minor and B harmonic minor related?
Can one live in the U.S. and not use a credit card?
Are these two graphs isomorphic? Why/Why not?
Do black holes violate the conservation of mass?
Why do phishing e-mails use faked e-mail addresses instead of the real one?
Giving a career talk in my old university, how prominently should I tell students my salary?
When an outsider describes family relationships, which point of view are they using?
Why does this boat have a landing pad? (SpaceX's GO Searcher) Any plans for propulsive capsule landings?
Too soon for a plot twist?
Running bash inside cronjob
How to determine why a machine is running slowly?Why does my cronjob not execute my shell-script?Cron job running at 12.00 AM despite changing its timeHow to interpret busybox “top” output?Latexmk, from Makefile, from bash script, from Cron - Latexmk not being executedLog free and topoutput logs in crontab does not workunreasonable memory usageSFTP script not working with cron jobBash script able to run manually, but with cron not working. + Ubuntu 16.04
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 1 min ago
Guillermo Mosse
1031
1031
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