![]() |
Hello and Welcome from United States to the UNIX and Linux Forums! Thank You for Visiting and Joining Our Global Community.
|
|
google unix.com
|
|||||||
| Forums | Register | Forum Rules | Links | Albums | FAQ | Members List | Calendar | Search | Today's Posts | Mark Forums Read |
| UNIX for Advanced & Expert Users Expert-to-Expert. Learn advanced UNIX, UNIX commands, Linux, Operating Systems, System Administration, Programming, Shell, Shell Scripts, Solaris, Linux, HP-UX, AIX, OS X, BSD. |
More UNIX and Linux Forum Topics You Might Find Helpful
|
||||
| Thread | Thread Starter | Forum | Replies | Last Post |
| Finding the process id of the process using the ports | kinny | Shell Programming and Scripting | 1 | 3 Weeks Ago 11:02 AM |
| Finding PID of Killing process | enigma_007 | SUN Solaris | 7 | 08-28-2009 07:18 PM |
| Need help in finding process | dheeraj4uuu | Linux | 2 | 06-02-2009 04:34 PM |
| finding Background Process Id | krk_555 | Shell Programming and Scripting | 4 | 10-24-2007 08:34 PM |
| finding process id | sskb | UNIX for Dummies Questions & Answers | 8 | 04-10-2002 02:00 PM |
![]() |
|
|
LinkBack | Thread Tools | Search this Thread | Rate Thread | Display Modes |
|
|
|
||||
|
Finding process id of subsequent process
hi all,
I am trying to find the process id of the subsequent process created via fork and exec calls in perl. For eg: Code:
envVarSetter dataCruncher.exe < input.txt > output.txt it returns only the pid of envVarSetter and I don't know how to find the pid of dataCruncher.exe Option of pgrep, grepping by process name don't seem to suit my case and it will only involve additional processing. Also, multiple different parameters are passed which when grepped will return different values, so that's not a nice option In short, is there a way to find out the pid of subsequent process executed in one command? |
|
||||
|
Thanks for the reply.
But that is not the case really. As I have told that, 2 processes are executed in sequence, where the first one completes [ envVarSetter ] in no time which means the second process [ dataCruncher.exe ] would be left orphaned and init adopts that, therefore PPID of the second process is 1 and no more the PID that created it. This makes the problem hard to find out the PID of the subsequent process. Since they almost execute one after another, I have noticed most of the times that if PID of first process is 'x' and PID of second process is 'x+1' but that is a crude assumption and I can't go with that. In a very busy system, my script would be thrashed left and right ... Am just searching for a better way to do that. Thanks for your reply again. |
|
||||
|
I managed to get this working with a lock file concept in place.
To create a file - presence of which will indicate that the process is created and after the process is done, the next command in sequence is to delete the file. This indirectly means, if there is no file then processing is done. With this approach its perfectly working - no issues for now ![]() But to say frankly, I hate this approach like anything it is not robust not fool proof can be hacked no control of child created via the parent Am still looking for some help from experts here to get the actual pid that am interested. |
|
||||
|
Unless you expect the first script to finish within a second or two, frans's solution is fine. Also, if you added a lock file that gets deleted when the process ends, can't you use the same script that creates the lock file to create it with the pid in the lock file's name? Alternative concepts could be to have envVarSetter write the pid of the child and any other useful info to its parent process's read pipe.
Alternatively, you could look through children of init for processes of that name that began a within a second or two of the script's initial running. etc, etc. There are a lot of possibilities. |
|
||||
|
Quote:
Quote:
Quote:
say at t1 the main script spawns a process p1 and is adopted by init at the same time t1, another script with the same name can be spawned and become the child of the init In a busy node, all these considerations should be dealt well, else there would be confusion as to who is the parent of whom -- many thanks for the suggestions ---------- Post updated 11-05-09 at 11:27 AM ---------- Previous update was 11-04-09 at 11:34 PM ---------- Now I have an improved way to prevent the hack of spoofing child creation instance by adding new files at least to an extent. Instead of writing the active child number spawned, write a random number to the file and maintain that in an internal hash. When checking for the existence of file as a synonym that is indicating whether a process is running or not, search for the entry in the file and compare it against the internal hash that is built with this values. With this, spoof of child creating by just touching files can be avoided. I don't want to write the pid because effectively we are writing the PPID and not PID which should be avoided. |
|
||||
|
Quote:
in the above PCRE regex, the language/utility/whatever will create a backreference for the number portion of the pattern under "1." proof of concept in Perl: Code:
#!/usr/bin/perl -w
our @files = </tmp/dataCruncher.exe.lock*>;
our @pids = ();
foreach $file (@files) {
$file =~ /dataCruncher\.exe\.lock\.([0-9]+)/;
push ( @pids, $1 );
}
Hope that makes what I'm saying seem a little clearer. Quote:
Criteria you can examine the process tree for: username, time, command, parent(1), etc. All of which make it less likely that you've caught more than one process in the fray. You also haven't mentioned how you're creating the lockfile. It would seem a process that can know when the children die off can also do the above file naming. Well, I think I can maybe help a little more if I understand more about how you're creating the lockfile. Last edited by thmnetwork; 2 Weeks Ago at 08:22 PM.. Reason: fixing syntax error |
![]() |
| Bookmarks |
| Thread Tools | Search this Thread |
| Display Modes | Rate This Thread |
|
|