<html><head><style type='text/css'>p { margin: 0; }</style></head><body><div style='font-family: arial,helvetica,sans-serif; font-size: 12pt; color: #000000'>I'm glad that worked out for you. I don't know why you couldn't get the script to reboot--it might have had more to do with cron than being in a script. Cron doesn't get your .profile, etc. so PATH and other environment missing can trip you up. But I assume you meant it wouldn't reboot even when running the script directly.<div><br></div><div>I notice the ps command got the "-p" parameter changed into "-e" somehow. The -p pid looks for that particular process id. But -e says show every process, and the exit code is always true (0). I don't see how it'll work with the -e. I guess that's why you reversed the sense of the condition. The idea is the lsusb will run within a second or so and the process will be gone if everything is ok. If, after the timeout, the process is still there, then it's hung and you need the reboot or whatever. I understand it's a bit hard to test if you can't cause the usb to hang when you want it to.</div><div><br></div><div><br></div><div>The normal idiom in bash to use a variable or a default if the variable isn't set is ${parameter:-word}. So you could replace your two "test" statements at the top with this: </div><div><br></div><div>TIMEOUT=${1:-7}</div><div><br></div><div>You can get the details for this in the bash man page under "Parameter Expansion". If you're going to do much bash scripting, there are a bunch of super useful things in that section.</div><div><br></div><div>Most sources say the convention is to use all caps just for environment variables in bash, and lower case for local variables. Usually the first variables people see when learning are environment variables like HOME and PATH and they get the idea all variables are meant to be all caps. It's just convention though (and not universally applied) but it's something to consider. It'll help keep you from accidentally hiding some environment variable that you end up wanting to use down the road.</div><div><br></div><div>Scott<br><br><hr id="zwchr"><div style="color:#000;font-weight:normal;font-style:normal;text-decoration:none;font-family:Helvetica,Arial,sans-serif;font-size:12pt;"><b>From: </b>"Todor Fassl" <fassl.tod@gmail.com><br><b>To: </b>"Atlanta Linux Enthusiasts" <ale@ale.org><br><b>Sent: </b>Tuesday, May 10, 2016 3:14:39 PM<br><b>Subject: </b>Re: [ale] checking for process in uninterruptable sleep state<br><br>That worked fine. Thanks. I actually wrote the script on a workstation <br>with a wedged usb sub-system at the time. So I could be sure the script <br>worked as intended. I couldn't get it to reboot though. I don't know if <br>you can't put a reboot command in a bash script or if it didn't work <br>because of the original problem. Probably safer this way anyhow. I put <br>it in cron on the 15 workstations because it generates a line of output <br>if a machine is hung and cron itself will email me. For completeness, <br>here is the full script:<br><br>#!/bin/bash<br>test ! -z "$1" && TIMEOUT=$1<br>test -z "$TIMEOUT" && TIMEOUT=7<br>( /usr/bin/lsusb > /dev/null ) & PID=$!<br>sleep $TIMEOUT<br>if ps -e $PID > /dev/null 2>&1; then<br> test ! -z "$VERBOSE" && echo "$HOSTNAME is okay."<br>else<br> echo "$HOSTNAME is hung, process $PID" >&2<br>fi<br><br><br>#!/bin/bash<br><br>test ! -z "$1" && TIMEOUT=$1<br>test -z "$TIMEOUT" && TIMEOUT=7<br>( /usr/bin/lsusb > /dev/null ) & PID=$!<br>sleep $TIMEOUT<br>if ps -e $PID > /dev/null 2>&1; then<br> test ! -z "$VERBOSE" && echo "$HOSTNAME is okay."<br>else<br> echo "$HOSTNAME is hung, process $PID" >&2<br>fi<br><br>On 05/10/2016 10:21 AM, Scott Plante wrote:<br>><br>> How about if you do lsusb in the background then check the PID to see if it's still running/stuck, like:<br>><br>><br>> lsusb >/dev/null 2>&1 &<br>> usbpid=$!<br>> sleep 4 #or however long > max lsusb exec time<br>> if ps -p $usbpid >/dev/null 2>&1<br>> then<br>> #lsusb is hung--do your stuff here, reboot etc.<br>> fi<br>> ----- Original Message -----<br>><br>> From: "Todor Fassl" <fassl.tod@gmail.com><br>> To: "Atlanta Linux Enthusiasts" <ale@ale.org><br>> Sent: Tuesday, May 10, 2016 10:39:26 AM<br>> Subject: [ale] checking for process in uninterruptable sleep state<br>><br>> Okay, so my latest problem with these lab workstations is that accessing<br>> the usb sub-system puts the calling process into an uninterruptable<br>> sleep. I'd like to write a script to check for that so at least I'd know<br>> that I have to go over and reboot the machine.<br>><br>> Details: I have 15 Dell workstations running ubuntu 15.10 (2 are running<br>> 16.04 -- that did not help). Occasionally, the keyboard and mouse<br>> freeze. Logging in remotely and running lsusb hangs such that you can't<br>> even control-c outand it cannot be killed even with a -9. The process<br>> goes into an uninterruptable sleep during a system call to open the file<br>> /sys/bus/usb/devices/usb1/descriptors. That file is part of the kernel's<br>> control files for the usb controller itself. So you can see why the<br>> keyboard and mouse are dead, the driver for the usb controller itself is<br>> hung.<br>><br>> We've upgraded the kernel and installed Dell's latest bios upgrades. No<br>> joy. I am thinking the only remaining thing to do is to file a bug<br>> report. However, I could eleaviate the problem a little if I could<br>> easily detect it and reboot.<br>><br>> The problem is that I can't figure out how to write a script to detect a<br>> process in a uninterruptable sleep state. No matter what I do,it seems<br>> to hang. I've tried something like "bash -c "lsusb' and 'timeout 5<br>> lsusb'. They both hang. The only thing I've been able to do is to have<br>> 2 different scripts. One running lsusb and another checking for blocked<br>> lsusb procs. But that is way ugly.<br>><br>> PS: I wouldn't mind ideas wrt the original problem either. Not that I<br>> hold out any hope for that.<br>><br>><br>><br>> _______________________________________________<br>> Ale mailing list<br>> Ale@ale.org<br>> http://mail.ale.org/mailman/listinfo/ale<br>> See JOBS, ANNOUNCE and SCHOOLS lists at<br>> http://mail.ale.org/mailman/listinfo<br>><br><br>-- <br>Todd<br>_______________________________________________<br>Ale mailing list<br>Ale@ale.org<br>http://mail.ale.org/mailman/listinfo/ale<br>See JOBS, ANNOUNCE and SCHOOLS lists at<br>http://mail.ale.org/mailman/listinfo<br></div><br></div></div></body></html>