WelcomeWelcome | FAQFAQ | DownloadsDownloads | WikiWiki

Author Topic: scripting q-- wait for response?  (Read 10707 times)

Offline gerald_clark

  • TinyCore Moderator
  • Hero Member
  • *****
  • Posts: 4254
Re: scripting q-- wait for response?
« Reply #15 on: February 11, 2012, 06:34:49 PM »
It is hard to say why an unrevealed script does not run.

Offline mb0

  • Jr. Member
  • **
  • Posts: 86
Re: scripting q-- wait for response?
« Reply #16 on: February 11, 2012, 07:04:43 PM »
so you are saying there is no reason  to expect a script not to be launched fine from bootlocal.sh?#

e: here is an example that doesn't work; (remember, which works when ran manually)

#!/bin/sh
while true
do
        /usr/local/bin/mpc idle > /dev/null
        LINE=`/usr/local/bin/curl -s 127.0.0.1/test`
        curl -F "var=$LINE" 127.0.0.1:5678
done

saved as /opt/script.sh, with '/opt/script.sh &' in bootlocal.sh
« Last Edit: February 11, 2012, 07:10:50 PM by mb0 »

Offline gerald_clark

  • TinyCore Moderator
  • Hero Member
  • *****
  • Posts: 4254
Re: scripting q-- wait for response?
« Reply #17 on: February 11, 2012, 07:14:26 PM »
If it is executable, and you call it from bootlocal.sh, it will run.
It is your responsibility to insure that it runs to completion an does not hang on a line such as
/usr/local/bin/mpc idle > /dev/null.

bootlocal.sh runs as root without a stdin, so any program requiring keyboard input will fail.
It also runs files synchronously, so any program that does not return will hang bootlocal.sh.

Offline mb0

  • Jr. Member
  • **
  • Posts: 86
Re: scripting q-- wait for response?
« Reply #18 on: February 11, 2012, 07:17:29 PM »
again, how would i run this script on startup??

(and FWIW, i thought the & addition would stop it from blocking?.. as well as this i had it at the end of the scipt.
FYI there is no keyboard input required)
« Last Edit: February 11, 2012, 07:21:34 PM by mb0 »

Offline gerald_clark

  • TinyCore Moderator
  • Hero Member
  • *****
  • Posts: 4254
Re: scripting q-- wait for response?
« Reply #19 on: February 11, 2012, 07:30:14 PM »
It is your script.
You will have to figure out why it is not running as expected.
I cannot troubleshoot secret scripts, and have lost interest.

Offline mb0

  • Jr. Member
  • **
  • Posts: 86
Re: scripting q-- wait for response?
« Reply #20 on: February 11, 2012, 07:35:28 PM »
Excuse me, i posted my script just two posts ago. It runs as expected when i run it manually. Therefore, there is not a fundamental problem with the script.

Offline Rich

  • Administrator
  • Hero Member
  • *****
  • Posts: 12277
Re: scripting q-- wait for response?
« Reply #21 on: February 11, 2012, 08:15:59 PM »
Hi mb0
I don't know what the problem is, but I will make a couple of comments.
1. Are you sure  it's not  running? If you start  top  or execute  ps, does it show up?
2. I don't know what those commands do,  but if their execution time is short, you will suck up a lot of CPU cycles.
    If that's the case, it might be slowing down another process that is trying to start up, maybe one you are relying on.

Offline mb0

  • Jr. Member
  • **
  • Posts: 86
Re: scripting q-- wait for response?
« Reply #22 on: February 11, 2012, 08:21:02 PM »
Thank you for your reply rich. The execution time is not short. often minutes. the rest of the startup seems fine. i will look into your first point tomorrow.

Offline Rich

  • Administrator
  • Hero Member
  • *****
  • Posts: 12277
Re: scripting q-- wait for response?
« Reply #23 on: February 11, 2012, 08:32:39 PM »
Hi mb0
When troubleshooting a problem it can be helpful to have feedback. Since you are backgrounding the script, I
don't know if an echo command will work, but this will:
Code: [Select]
#!/bin/sh
while true
do
        /usr/local/bin/mpc idle > /dev/null
        touch one
        LINE=`/usr/local/bin/curl -s 127.0.0.1/test`
        touch two
        curl -F "var=$LINE" 127.0.0.1:5678
        touch three
done
If the script ran, ls will return the files one,two, and three. If you delete them and the script is still running, they will
be recreated.

Offline gerald_clark

  • TinyCore Moderator
  • Hero Member
  • *****
  • Posts: 4254
Re: scripting q-- wait for response?
« Reply #24 on: February 11, 2012, 09:21:48 PM »
Better make that /tmp/one, /tmp/two, /tmp/three.

Offline Rich

  • Administrator
  • Hero Member
  • *****
  • Posts: 12277
Re: scripting q-- wait for response?
« Reply #25 on: February 11, 2012, 09:40:55 PM »
Yeah, from a point of keeping the file system uncluttered, that is a cleaner approach.

Offline maro

  • Hero Member
  • *****
  • Posts: 1228
Re: scripting q-- wait for response?
« Reply #26 on: February 11, 2012, 10:09:19 PM »
Yeah, from a point of keeping the file system uncluttered, that is a cleaner approach.
Well, that as well as the fact that it could be quite a bit of guesswork to find out in which local directory a script was executed.

My general rule of thumb for trouble shooting a script that "the system" starts (e.g. one called by 'crobtab'): I'd tend to use pretty much only absolute file names. After I've identified what typically was a wrong assumption on my part I remove any surplus use of  these absolute file names again, as they are IMHO not a "good look" in general terms.

Offline H.Lunke

  • Newbie
  • *
  • Posts: 9
Re: scripting q-- wait for response?
« Reply #27 on: February 12, 2012, 10:15:17 AM »
The execution time is not short. often minutes. the rest of the startup seems fine.

Hi mb0,

'mpc' does not return until an event is generated, such as changing the playlist, pausing the player and so on. So the following works fine even when run from bootlocal.sh via: /path/to/script.sh &

Code: [Select]
while true;do echo `date;mpc idle`;done >/tmp/logfile
After reboot you should be able to watch the growing logfile via: "tail -f /tmp/logfile" - sure there should be some player activities ongoing..

You could also write the loop as follows:
Code: [Select]
while echo `date;mpc idle`;do mpc >/tmp/logplay;done >/tmp/logevent
This way "/tmp/logplay" contains the song currently played (if any) and "/tmp/logevent" contains status change messages.



Paradise is exactly like where you are right now -
only much, much better. [Laurie Anderson, Language is a virus]