-
Notifications
You must be signed in to change notification settings - Fork 50
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
The ttrpc client lifetime is so long for Main thread #225
Comments
Hi @jokemanfire Why do you think the ttrpc client will live infinitely? Once the t and t2 thread were joined, then hc, thc, ac and tac would be destroyed, right? |
Hello , when I try to code 'like loop (create a client)' in the main thread (I need to create client_ttprc in my project , all my project function is in main thread), I found the /proc/{self.pid}/fd will increase infinitely.The file descriptor of the process is restricted to go online. I found the fd will not be release in main_thread , though I use client_ttprc in a wrap function, Is it the usage error caused by my insufficient understanding? thank you. |
The key is the client you create with " let c = Client::connect(utils::SOCK_ADDR).unwrap();" , once your client is over, you should make sure the "c" and any other clone entity should be destroyed. |
thank you ,but I feel confused , In the example code , please check If my error:
3、the hc 、ac 's life time should finished after this iter . Is there some desotry method for the hc 、ac variable? |
If the Client Inner _connection: Arc, this variable Arc count will not be zero cause this problem? the thread will hold it forever in Func new_client. |
Since the hc and ac's life time ended, then it should close the connection automatically.
That would be, but in your example, after the loop, all of the client and clone entity had been dropped and it should be reduced to zero? Anyway, would you check was there any thread created by client new exit after all of the client dropped? |
thanks , now I get this problem clearly , first change the thread's client_connection to weak Arc , this will not increase the Arc count, And then when use libc poll ,there must a timeout parameters , otherwise it will wait forever... I will push a pr ,and then you can check it. there is my test code
|
Fixed |
Description of problem
I code example client.rs like this
this this the phenomenon, the fd will infinite growth.
(replace this text with the list of steps you followed)
Expected result
method 1
1、Provide a interface that I can proactively release the fd.
2、If it exceeds the lifecycle ,release the fd automatic.
Actual result
1、fd will not increase in main thread.
(replace this text with details of what actually happened)
If it is true, I will submit a PR.
The text was updated successfully, but these errors were encountered: