A curious question. If i execute same program multiple times and print its process id, its not in sequential order, the pattern i observed is, if first run shows 5737, second run shows 5739, third shows 5741, I am wondering why its 2 units apart everytime.. Any answer appreciated.. Thanks
A curious question. If i execute same program multiple times and print its process id, its not in sequential order, the pattern i observed is, if first run shows 5737, second run shows 5739, third shows 5741, I am wondering why its 2 units apart everytime.. Any answer appreciated.. Thanks
Hi.
So another process ran in the mean time.
How did you "print" its'process ID? With ps? ps is a process too, and has a process ID...
It may not be sequential for a few reasons; there may be other already-existing PID's at those spots, or, other things are getting run in the meantime. Try running it quickly three times and seeing if your PIDs are sequential then.
As others have posted, depending on system load it is very likely that multiple processes are being started simultaneously and that two commands executed sequentially will likely not have sequential PIDs. Even on a host with one active user, the presence of a browser, or other application, is likely to induce some 'noise' that would give you the results you are seeing.
I was curious about the fact that the PIDs seemed very regularly spaced and that it seemed fairly repeatable, so I did a bit of testing. I wrote a small script (t16) that does nothing but echo the pid:
On a quiet linux host, running it back to back under kshell yields the 'skipping' behaviour was noticed:
Yet running it via bash there was no skipping:
Using strace I observe that Kshell is invoking vfork() between the execution of the commands. The nature of vfork() is that it does 'consume' a PID and thus the 'gap.' I believe that I know why vfork() is being invoked by kshell, but because I'm not absolutely positive I'm not going to post my guessing.
Another 'odd' thing with the execution under Kshell is that the last command actually has the lowest PID. This is because Kshell doesn't fork a process to run the last command in; instead it exec's the command overtop of itself and so the last command's PID was the same as the Kshell process that was invoked to run the commands and thus the lowest PID in the list. This is not something that would be observed if I had just executed the commands from my prompt:
So, if you are using Kshell, this is yet another possible explanation of the behaviour you were seeing.
Specifying the shell script interpreter, i.e.:
will likely make ksh behaving the expected way.
Afraid not. The #! directive in the script being executed has nothing to do with it. It is the parent shell, the shell that is doing the fork()/exec() on the command (script in this case), that is affecting the environment such that PID values appear to be skipping. The only important thing about what is being executed is that it terminates quickly and writes its PID to stdout/stderr.
Team,
I have multiple batchjobs running in VM, if I do ps -ef |grep java or tomcat I am getting multiple process list.
How do I get my exact tomcat process running and that is unique? via shell script? (4 Replies)
I am writing a script to kick off a process to gather logs on multiple nodes in parallel using "&". These processes create individual log files. Which I would like to filter and convert in CSV format after they are complete. I am facing following issues:
1. Monitor all Processes parallelly.... (5 Replies)
Hi Experts,
I am facing one problem here which is one process always stuck in running state which causes the other similar process to sleep state . This causes my system in hanged state.
On doing cat /proc/<pid>wchan showing the "__init_begin" in the output.
Can you please help me here... (6 Replies)
Hi Experts,
I am facing one problem here which is one process always stuck in running state which causes the other similar process to sleep state . This causes my system in hanged state.
On doing cat /proc/<pid>wchan showing the "__init_begin" in the output.
Can you please help me here... (1 Reply)
Hi Experts,
I am facing one problem here which is one process always stuck in running state which causes the other similar process to sleep state . This causes my system in hanged state.
On doing cat /proc/<pid>wchan showing the "__init_begin" in the output.
Can you please help me here... (0 Replies)
get email notification from from system when a process from XXXX user takes longer than 15 min run.Let me know the time estimation for the same.
hi ,any one please tell me , how to write a script to get email notification from system when a process from as mentioned above a xxxx user takes... (1 Reply)
Hey all, I need to launch a script from within 2 other scripts that can run independently of the two parent scripts... Im having a hard time doing this, if anyone knows how please let me know.
More detail.
ScriptA (bash), ScriptB (ksh), ScriptC (bash)
ScriptA, launches ScriptB
ScirptB,... (7 Replies)
Hi Experts, we do have a shell script for Unix Solaris, which will kill all the process manullay, it used to work in my previous env, but now it is throwing this error.. could some one please help me to resolve it
This is how we execute the script (and this is the requirement) ... (2 Replies)
Hello all,
I would be happy if any one could help me with a shell script that would determine all the processes running on a Unix server and post a mail if any of the process is not running or aborted.
Thanks in advance
Regards,
pradeep kulkarni.
:mad: (13 Replies)
Hi all,
I'm doing automation task for my team and I just started to learn unix scripting so please shed some light on how to do this:
1) I have 2 sets of datafiles - datafile A and B. These datafiles must be loaded subsequently and cannot be loaded concurrently.
2) So I loaded datafile A... (10 Replies)