Skip to content
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

Why do the remote methods doGetRemoteBuffers and doCreateRemoteBuffer include AddDependency and RemoveDependency, while the local methods do not? #2017

Open
fduxzbin opened this issue Nov 18, 2024 · 5 comments
Labels

Comments

@fduxzbin
Copy link

Why do the remote methods doGetRemoteBuffers and doCreateRemoteBuffer in vineyard include AddDependency and RemoveDependency? However, there are no related operations in the local methods doCreateBuffer and doCreateBuffers. There is only AddDependency but no RemoveDependency in doGetBuffers.
Please explain the specific role of Dependency in detail. If I perform AddDependency first and then RemoveDependency for all get and create operations, will there be any problems?

@fduxzbin fduxzbin changed the title Why do the remote methods doGetRemoteBuffers and doCreateRemoteBuffer in vineyard include AddDependency and RemoveDependency? However, there are no related operations in the local methods doCreateBuffer and doCreateBuffers. There is only AddDependency but no RemoveDependency in doGetBuffers. Please explain the specific role of Dependency in detail. If I perform AddDependency first and then RemoveDependency for all get and create operations, will there be any problems? Why do the remote methods doGetRemoteBuffers and doCreateRemoteBuffer include AddDependency and RemoveDependency, while the local methods do not? Nov 18, 2024
@dashanji
Copy link
Member

Hi @fduxzbin, thanks for reporting this issue. Could you please tell us what problem you have encountered?

@fduxzbin
Copy link
Author

Hi @fduxzbin, thanks for reporting this issue. Could you please tell us what problem you have encountered?

The reason why I raised this question is that I encountered a scenario where, when it was necessary to release memory, none of the objects were spilled because all objects had Dependency, resulting in a failure to release memory. I found that when you create and get remote objects, you add Dependency before create/get, and then remove Dependency after create/get, thereby achieving immediate release of the object and adding it to the LRU. When it needs to be spilled, it is spilled immediately. My question is, why is there no corresponding operation for local methods when the above operation on remote objects is reasonable. How to avoid the problem of not releasing locally created/get immediately.

@dashanji
Copy link
Member

dashanji commented Dec 4, 2024

Hi @fduxzbin. You can use the client.release_object to release the object manually.

@github-actions github-actions bot added the stale label Dec 12, 2024
Copy link
Contributor

/cc @sighingnow, this issus/pr has had no activity for a long time, please help to review the status and assign people to work on it.

@Daniel-blue
Copy link

Hi @fduxzbin. You can use the client.release_object to release the obje

Hi @fduxzbin, thanks for reporting this issue. Could you please tell us what problem you have encountered?

If the client restarts or disconnects before using client.release_object to release a Dependency, will this cause the object to be unable to spill to disk as a cold object or be deleted? How should this situation be handled?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

3 participants