Detect pid reuse

Yao Bao by@REDACTED
Mon Jul 6 14:22:57 CEST 2020


Hello,

I am considering will the newly spawned process reuse the pid?

Cheers,
Yao

> 在 2020年7月6日,20:09,Dinislam Salikhov <Dinislam.Salikhov@REDACTED> 写道:
> 
> Hello,
> 
> I have a bunch of connections (processes) to different instances of the same database (instances are physically separated and don't share data). The connect may be unstable, so the connections are handled with a supervisor: if the connect is lost, the process terminates and supervisor starts a new one.
> 
> If I want to send a command to the database, I search for the pid of the corresponding connection (in supervisor's children list). And between the search and actual sending command (i.e. via gen_server:call(Pid,...)), the process may terminate and its pid will be reused by another connection (to different database). So I end up with sending a command to the wrong database (as gen_server:call/3 thinks that the pid is the correct one).
> 
> Is there a way to detect that such restart has occurred?
> I have an idea to keep some kind of token for the connection, so a process sending a command should pass the token and the connection process must check that the token is right. The code for connection process is 3rd party, so I would like to find some other solution.
> 
> Dinislam Salikhov



More information about the erlang-questions mailing list