Sponsored Content
Top Forums Shell Programming and Scripting How to display a message if program hangs(takes too long) Post 302672943 by rbatte1 on Tuesday 17th of July 2012 09:45:45 AM
Old 07-17-2012
Hello mrskittles99,

You could set the script you want to run in the background, capture the process id and then set a timer running. It always feels a bit spaghetti when i do this sort of thing though.

Code:
#!/bin/ksh
echo "`date` Running script2"
script2 &
SCRIPT2PID=$!

timer=0
until [ $timer = 600 -o `ps -fp $SCRIPTPID|wc -l` -ne 1 ]    # Set wait time to 600 seconds or 10 minutes.
do
   sleep 1
   ((timer=$timer+1))
done

if [ `ps -fp $SCRIPTPID|wc -l` -ne 1 ]
then
   kill $SCRIPT2PID
   echo "`date` Script2 can't run right now"
else
   echo "`date` Script2 complete"
fi



I hope that this helps. It may take a bit of trial and error to get the exact process right. Try it with a script2 that just contains a sleep command itself.

Any better suggestions? I would like to know too as I'm not that comfortable with what I've coded above.




Robin
Liverpool/Blackburn
 

10 More Discussions You Might Find Interesting

1. UNIX for Dummies Questions & Answers

Finding out how long a command takes to run

Hi I am trying to find out the best way to find out how long a command takes to run in miliseconds .. Is there such a way of doing this in Unix ? Thanks (3 Replies)
Discussion started by: cfoxwell
3 Replies

2. Programming

fwrite takes extremely long time

After my previous thread, I think I found out what causes the long delays. I run this program on several Linux computers, and the sometimes (after the file with the arrays becomes big) the fwrite takes between 100 ms to 900 ms. This is very bad for me, as I want a timer to halt each 30 ms.... ... (5 Replies)
Discussion started by: inna
5 Replies

3. Shell Programming and Scripting

Killing a process that takes too long

Hello, I have a C program that takes anywhere from 5 to 100 arguments and I'd like to run it from a script that makes sure it doesnt take too long to execute. If the C program takes more than 5 seconds to execute, i would like the shell script to kill it and return a short message to the user. ... (3 Replies)
Discussion started by: WeezelDs
3 Replies

4. UNIX for Dummies Questions & Answers

time how long it takes to load a module

Hello, like the title says, how can i measure the time it takes to load a module in Linux, and how how can i measure the time it takes to load a statically compiled module. /Best Regards Olle ---------- Post updated at 01:13 PM ---------- Previous update was at 11:54 AM ---------- For... (0 Replies)
Discussion started by: ollebanan
0 Replies

5. Shell Programming and Scripting

sort takes a long time

Dear experts I have a 200MG text file in this format: text \tab number I try to sort using options -fd and it takes very long! is that normal or I can speed it up in some ways? I dont want to split the file since this one is already splitted. I use this command: sort -fd file >... (12 Replies)
Discussion started by: voolek
12 Replies

6. UNIX and Linux Applications

database takes long time to process

Hi, we currently having a issue where when we send jobs to the server for the application lawson, it is taking a very long time to complete. here are the last few lines of the database log. 2012-09-18-10.35.55.707279-240 E244403536A576 LEVEL: Warning PID : 950492 ... (1 Reply)
Discussion started by: techy1
1 Replies

7. Shell Programming and Scripting

Wget takes a long time to complete

Hi, I wish to check the return value for wget $url. However, some urls are designed to take 45 minutes or more to return. All i need to check if the URL can be reached or not using wget. How can i get wget to return the value in a few seconds ? (8 Replies)
Discussion started by: mohtashims
8 Replies

8. UNIX for Advanced & Expert Users

Find command takes too long to complete

Hi, Below is my find command find /opt/app/websphere -name myfolder -perm -600 | wc -l At time it even takes 20 mins to complete. my OS is : SunOS mypc 5.10 Generic_150400-09 sun4v sparc SUNW,T5440 (10 Replies)
Discussion started by: mohtashims
10 Replies

9. Shell Programming and Scripting

Find command takes long

Hi, I am trying to search for a Directory called "mont" under a directory path "/opt/app/var/dumps" Although "mont" is in the very parent directory called "dumps" i.e "/opt/app/var/dumps/mont" and it can never be inside any Sub-Directory of "dumps"; my below find command which also checks... (5 Replies)
Discussion started by: mohtashims
5 Replies

10. Shell Programming and Scripting

Script takes too long to complete

Hi, I have a lengthy script which i have trimmed down for a test case as below. more run.sh #!/bin/bash paths="allpath.txt" while IFS= read -r loc do echo "Working on $loc" startdir=$loc find "$startdir" -type f \( ! -name "*.log*" ! -name "*.class*" \) -print | while read file do... (8 Replies)
Discussion started by: mohtashims
8 Replies
Util::TimeTracker(3)					User Contributed Perl Documentation				      Util::TimeTracker(3)

NAME
Log::Log4perl::Util::TimeTracker - Track time elapsed SYNOPSIS
use Log::Log4perl::Util::TimeTracker; my $timer = Log::Log4perl::Util::TimeTracker->new(); # equivalent to Time::HiRes::gettimeofday(), regardless # if Time::HiRes is present or not. my($seconds, $microseconds) = $timer->gettimeofday(); # reset internal timer $timer->reset(); # return milliseconds since last reset $msecs = $timer->milliseconds(); # return milliseconds since last call $msecs = $timer->delta_milliseconds(); DESCRIPTION
This utility module helps tracking time elapsed for PatternLayout's date and time placeholders. Its accuracy depends on the availability of the Time::HiRes module. If it's available, its granularity is milliseconds, if not, seconds. The most common use of this module is calling the gettimeofday() method: my($seconds, $microseconds) = $timer->gettimeofday(); It returns seconds and microseconds of the current epoch time. If Time::HiRes is installed, it will simply defer to its gettimeofday() function, if it's missing, time() will be called instead and $microseconds will always be 0. To measure time elapsed in milliseconds, use the reset() method to reset the timer to the current time, followed by one or more calls to the milliseconds() method: # reset internal timer $timer->reset(); # return milliseconds since last reset $msecs = $timer->milliseconds(); On top of the time span between the last reset and the current time, the module keeps track of the time between calls to delta_milliseconds(): $msecs = $timer->delta_milliseconds(); On the first call, this will return the number of milliseconds since the last reset(), on subsequent calls, it will return the time elapsed in milliseconds since the last call to delta_milliseconds() instead. Note that reset() also resets the time of the last call. The internal timer of this module gets its time input from the POSIX time() function, or, if the Time::HiRes module is available, from its gettimeofday() function. To figure out which one it is, use if( $timer->hires_available() ) { print "Hooray, we get real milliseconds! "; } else { print "Milliseconds are just bogus "; } For testing purposes, a different time source can be provided, so test suites can simulate time passing by without actually having to wait: my $start_time = time(); my $timer = Log::Log4perl::Util::TimeTracker->new( time_function => sub { return $start_time++; }, ); Every call to $timer->epoch() will then return a time value that is one second ahead of the the value returned on the previous call. This also means that every call to delta_milliseconds() will return a value that exceeds the value returned on the previous call by 1000. COPYRIGHT AND LICENSE
Copyright 2002-2009 by Mike Schilli <m@perlmeister.com> and Kevin Goess <cpan@goess.org>. This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. perl v5.12.1 2010-02-07 Util::TimeTracker(3)
All times are GMT -4. The time now is 11:23 AM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy