I have a multithreaded process running on RHEL6.x (64bit).
I find that the process hangs and some threads (of the same process) crash most of the time when I try to bring up the process. Some threads wait for shared memory between the threads to get created (I can see that all of it does not get created).
But when I use strace , the process does not hang and it works just fine (all of the memory that is supposed to be created, gets created). Even interrupting strace after the memory gets created, keeps the process running fine for good.
I have read this:
which did give me an idea. But I am still unclear on this as the version of RHEL that they have used is not mentioned.
Also, another point is that, changing the kernel to a fedora (compatible) kernel did not produce the issue.
So, I would just like to know how exactly does strace affect a process ? (or is it just the stack that moves back to the kernel as pointed out in the link) ?
strace
forces the kernel to halt on every syscall entry/exit. It could be highly likely that usingstrace
introduces a delay and adds an additional synchronization point that does away with the underlying cause of the hang, be it deadlock/livelock. It would thus be best to investigate potential areas that could cause the design to lock itself instead of delving into the inner workings ofstrace
– Fellows