Simple bash script sometimes fails












1















I have a bash script that disables a USB port if there is no internet connection and after five seconds enables it again. But SOMETIMES it fails, the script disables the port but is not enabled again. Note that I only have a one USB port. This is my script:



#!/bin/bash

while true
do
sleep 10
if ping -c 2 google.com >> /dev/null 2>&1;then
echo $(date +"%r") >> /root/log.txt
echo "Conectado a SopelaBari" >> /root/log.txt
else
echo $(date +"%r") >> /root/log.txt
echo "Sin conexion" >> /root/log.txt
echo '2-1' |tee /sys/bus/usb/drivers/usb/unbind
sleep 5
echo '2-1' |tee /sys/bus/usb/drivers/usb/bind
sleep 5
fi
sleep 30
done


I am running Ubuntu 14.04.05 and the script is run as root with crontab.










share|improve this question

























  • I don't see anything obviously wrong with your script. Try adding 2> /tmp/script.logfile to the end of your crontab line and see if any error output is generated when it doesn't work. You could also try increasing the sleep 5 10 or 20 or so, to be sure it isn't a problem with how long it takes for the port to be disabled/enabled.

    – terdon
    Feb 11 '18 at 16:38













  • @terdon, thanks for your answer. Do I have to create 2> /tmp/script.logfile directory or is automatically created? I don't think time is a problem, normally it takes less than 1 sec to enable/disable the port.

    – Andermutu
    Feb 11 '18 at 16:42













  • The /tmp directory is created by default, just add 2> /tmp/script.logfile and that will create a file called script.logfile in /tmp. And yes, I agree that it should take less than a second but since you say it usually works, but sometimes does not, then we're looking for something strange. So maybe it sometimes takes longer.

    – terdon
    Feb 11 '18 at 16:47











  • Thanks @terdon. I added the script.logfile and increased the time. I will need some time to reproduce the error. I will tell you something as soon as I can.

    – Andermutu
    Feb 11 '18 at 16:53






  • 1





    Great! When you have more details, please edit your question and add them there (don't write "edit" or anything, just write your question as if you had included this information from the beginning). That way, the next person to read your question will have all the information.

    – terdon
    Feb 11 '18 at 17:20
















1















I have a bash script that disables a USB port if there is no internet connection and after five seconds enables it again. But SOMETIMES it fails, the script disables the port but is not enabled again. Note that I only have a one USB port. This is my script:



#!/bin/bash

while true
do
sleep 10
if ping -c 2 google.com >> /dev/null 2>&1;then
echo $(date +"%r") >> /root/log.txt
echo "Conectado a SopelaBari" >> /root/log.txt
else
echo $(date +"%r") >> /root/log.txt
echo "Sin conexion" >> /root/log.txt
echo '2-1' |tee /sys/bus/usb/drivers/usb/unbind
sleep 5
echo '2-1' |tee /sys/bus/usb/drivers/usb/bind
sleep 5
fi
sleep 30
done


I am running Ubuntu 14.04.05 and the script is run as root with crontab.










share|improve this question

























  • I don't see anything obviously wrong with your script. Try adding 2> /tmp/script.logfile to the end of your crontab line and see if any error output is generated when it doesn't work. You could also try increasing the sleep 5 10 or 20 or so, to be sure it isn't a problem with how long it takes for the port to be disabled/enabled.

    – terdon
    Feb 11 '18 at 16:38













  • @terdon, thanks for your answer. Do I have to create 2> /tmp/script.logfile directory or is automatically created? I don't think time is a problem, normally it takes less than 1 sec to enable/disable the port.

    – Andermutu
    Feb 11 '18 at 16:42













  • The /tmp directory is created by default, just add 2> /tmp/script.logfile and that will create a file called script.logfile in /tmp. And yes, I agree that it should take less than a second but since you say it usually works, but sometimes does not, then we're looking for something strange. So maybe it sometimes takes longer.

    – terdon
    Feb 11 '18 at 16:47











  • Thanks @terdon. I added the script.logfile and increased the time. I will need some time to reproduce the error. I will tell you something as soon as I can.

    – Andermutu
    Feb 11 '18 at 16:53






  • 1





    Great! When you have more details, please edit your question and add them there (don't write "edit" or anything, just write your question as if you had included this information from the beginning). That way, the next person to read your question will have all the information.

    – terdon
    Feb 11 '18 at 17:20














1












1








1


1






I have a bash script that disables a USB port if there is no internet connection and after five seconds enables it again. But SOMETIMES it fails, the script disables the port but is not enabled again. Note that I only have a one USB port. This is my script:



#!/bin/bash

while true
do
sleep 10
if ping -c 2 google.com >> /dev/null 2>&1;then
echo $(date +"%r") >> /root/log.txt
echo "Conectado a SopelaBari" >> /root/log.txt
else
echo $(date +"%r") >> /root/log.txt
echo "Sin conexion" >> /root/log.txt
echo '2-1' |tee /sys/bus/usb/drivers/usb/unbind
sleep 5
echo '2-1' |tee /sys/bus/usb/drivers/usb/bind
sleep 5
fi
sleep 30
done


I am running Ubuntu 14.04.05 and the script is run as root with crontab.










share|improve this question
















I have a bash script that disables a USB port if there is no internet connection and after five seconds enables it again. But SOMETIMES it fails, the script disables the port but is not enabled again. Note that I only have a one USB port. This is my script:



#!/bin/bash

while true
do
sleep 10
if ping -c 2 google.com >> /dev/null 2>&1;then
echo $(date +"%r") >> /root/log.txt
echo "Conectado a SopelaBari" >> /root/log.txt
else
echo $(date +"%r") >> /root/log.txt
echo "Sin conexion" >> /root/log.txt
echo '2-1' |tee /sys/bus/usb/drivers/usb/unbind
sleep 5
echo '2-1' |tee /sys/bus/usb/drivers/usb/bind
sleep 5
fi
sleep 30
done


I am running Ubuntu 14.04.05 and the script is run as root with crontab.







bash shell-script usb






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited 2 hours ago









Rui F Ribeiro

41.5k1483140




41.5k1483140










asked Feb 11 '18 at 16:31









AndermutuAndermutu

85




85













  • I don't see anything obviously wrong with your script. Try adding 2> /tmp/script.logfile to the end of your crontab line and see if any error output is generated when it doesn't work. You could also try increasing the sleep 5 10 or 20 or so, to be sure it isn't a problem with how long it takes for the port to be disabled/enabled.

    – terdon
    Feb 11 '18 at 16:38













  • @terdon, thanks for your answer. Do I have to create 2> /tmp/script.logfile directory or is automatically created? I don't think time is a problem, normally it takes less than 1 sec to enable/disable the port.

    – Andermutu
    Feb 11 '18 at 16:42













  • The /tmp directory is created by default, just add 2> /tmp/script.logfile and that will create a file called script.logfile in /tmp. And yes, I agree that it should take less than a second but since you say it usually works, but sometimes does not, then we're looking for something strange. So maybe it sometimes takes longer.

    – terdon
    Feb 11 '18 at 16:47











  • Thanks @terdon. I added the script.logfile and increased the time. I will need some time to reproduce the error. I will tell you something as soon as I can.

    – Andermutu
    Feb 11 '18 at 16:53






  • 1





    Great! When you have more details, please edit your question and add them there (don't write "edit" or anything, just write your question as if you had included this information from the beginning). That way, the next person to read your question will have all the information.

    – terdon
    Feb 11 '18 at 17:20



















  • I don't see anything obviously wrong with your script. Try adding 2> /tmp/script.logfile to the end of your crontab line and see if any error output is generated when it doesn't work. You could also try increasing the sleep 5 10 or 20 or so, to be sure it isn't a problem with how long it takes for the port to be disabled/enabled.

    – terdon
    Feb 11 '18 at 16:38













  • @terdon, thanks for your answer. Do I have to create 2> /tmp/script.logfile directory or is automatically created? I don't think time is a problem, normally it takes less than 1 sec to enable/disable the port.

    – Andermutu
    Feb 11 '18 at 16:42













  • The /tmp directory is created by default, just add 2> /tmp/script.logfile and that will create a file called script.logfile in /tmp. And yes, I agree that it should take less than a second but since you say it usually works, but sometimes does not, then we're looking for something strange. So maybe it sometimes takes longer.

    – terdon
    Feb 11 '18 at 16:47











  • Thanks @terdon. I added the script.logfile and increased the time. I will need some time to reproduce the error. I will tell you something as soon as I can.

    – Andermutu
    Feb 11 '18 at 16:53






  • 1





    Great! When you have more details, please edit your question and add them there (don't write "edit" or anything, just write your question as if you had included this information from the beginning). That way, the next person to read your question will have all the information.

    – terdon
    Feb 11 '18 at 17:20

















I don't see anything obviously wrong with your script. Try adding 2> /tmp/script.logfile to the end of your crontab line and see if any error output is generated when it doesn't work. You could also try increasing the sleep 5 10 or 20 or so, to be sure it isn't a problem with how long it takes for the port to be disabled/enabled.

– terdon
Feb 11 '18 at 16:38







I don't see anything obviously wrong with your script. Try adding 2> /tmp/script.logfile to the end of your crontab line and see if any error output is generated when it doesn't work. You could also try increasing the sleep 5 10 or 20 or so, to be sure it isn't a problem with how long it takes for the port to be disabled/enabled.

– terdon
Feb 11 '18 at 16:38















@terdon, thanks for your answer. Do I have to create 2> /tmp/script.logfile directory or is automatically created? I don't think time is a problem, normally it takes less than 1 sec to enable/disable the port.

– Andermutu
Feb 11 '18 at 16:42







@terdon, thanks for your answer. Do I have to create 2> /tmp/script.logfile directory or is automatically created? I don't think time is a problem, normally it takes less than 1 sec to enable/disable the port.

– Andermutu
Feb 11 '18 at 16:42















The /tmp directory is created by default, just add 2> /tmp/script.logfile and that will create a file called script.logfile in /tmp. And yes, I agree that it should take less than a second but since you say it usually works, but sometimes does not, then we're looking for something strange. So maybe it sometimes takes longer.

– terdon
Feb 11 '18 at 16:47





The /tmp directory is created by default, just add 2> /tmp/script.logfile and that will create a file called script.logfile in /tmp. And yes, I agree that it should take less than a second but since you say it usually works, but sometimes does not, then we're looking for something strange. So maybe it sometimes takes longer.

– terdon
Feb 11 '18 at 16:47













Thanks @terdon. I added the script.logfile and increased the time. I will need some time to reproduce the error. I will tell you something as soon as I can.

– Andermutu
Feb 11 '18 at 16:53





Thanks @terdon. I added the script.logfile and increased the time. I will need some time to reproduce the error. I will tell you something as soon as I can.

– Andermutu
Feb 11 '18 at 16:53




1




1





Great! When you have more details, please edit your question and add them there (don't write "edit" or anything, just write your question as if you had included this information from the beginning). That way, the next person to read your question will have all the information.

– terdon
Feb 11 '18 at 17:20





Great! When you have more details, please edit your question and add them there (don't write "edit" or anything, just write your question as if you had included this information from the beginning). That way, the next person to read your question will have all the information.

– terdon
Feb 11 '18 at 17:20










0






active

oldest

votes











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
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f423400%2fsimple-bash-script-sometimes-fails%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























0






active

oldest

votes








0






active

oldest

votes









active

oldest

votes






active

oldest

votes
















draft saved

draft discarded




















































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.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f423400%2fsimple-bash-script-sometimes-fails%23new-answer', 'question_page');
}
);

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







Popular posts from this blog

CARDNET

Boot-repair Failure: Unable to locate package grub-common:i386

濃尾地震