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

Advanced vfolder deletion features (aka trash bin) #767

Open
4 of 6 tasks
fregataa opened this issue Oct 3, 2022 · 3 comments
Open
4 of 6 tasks

Advanced vfolder deletion features (aka trash bin) #767

fregataa opened this issue Oct 3, 2022 · 3 comments
Assignees
Labels
comp:manager Related to Manager component comp:storage-proxy Related to Storage proxy component urgency:4 As soon as feasible, implementation is essential.
Milestone

Comments

@fregataa
Copy link
Member

fregataa commented Oct 3, 2022

Main idea

We can now determine the status of vfolders after #713.
Let's extend this feature for advanced deletion status such as DELETE-PENDING, DELETE-ONGOING or DELETE-ERROR.

  • We can reserve what time to delete a vfolder by giving an option with a default value, such as 1 day or 1 week etc. This job could be done by a new event and event handlers.
  • We can implement "Trash bin", where we can restore DELETE-PENDING vfolders by the owner of the vfolder or any admin.

It is recommended that deletion job change the status of vfolder and save the result of job at audit log rather purge the row in DB.


Updated (2023-10-04)

In 24.03, vfolder trash bin feature is implemented. Now vfolder delete API just update the status of vfolder to DELETE_COMPLETE.
We need to implement a trash bin timer which periodically purges long-lasting VFolders in trash bin as @kyujin-cho mentioned.


Updated (2024-02-06)

We will refine the state transition as follows, with better namings:

flowchart TB
    A(READY) -->|delete from vfolder list| B(DELETE_PENDING)
    B -->|restore from trash bin| A
    B -->|delete from trash bin, triggering actual filesystem removal| C(DELETE_ONGOING)
    C -->|removal in filesystem succeeds| D(DELETE_COMPLETE)
    C -->|removal in filesystem fails| E(DELETE_ERROR)
    D -->|"automatic <code>clean-history</code> or manual cleanup"| X(end of lifecycle)
    E -->|manual cleanup| X
Loading
  • Remove the PURGE_ONGOING state and perform the actual filesystem-level removal in DELETE_ONGOING.
  • The normal vfolder list should display READY vfolders only.
  • The trash bin should display DELETE_PENDING and DELETE_ONGOING vfolders only.
    • DELETE_PENDING: Users can no longer mount this vfolder when creating new sessions.
  • DELETE_COMPLETE vfolders are not shown in the WebUI but only in the CLI and the control panel.
    • Currently the enum value is "deleted-complete". The typo should be fixed with an explicit migration.
  • Let's introduce the status_history column in the vfolders table, just like refactor: Replace sessions, kernels's status_history's type map with list #1662.

Before:

class VFolderOperationStatus(str, enum.Enum):
    """
    Introduce virtual folder current status for storage-proxy operations.
    """

    READY = "ready"
    PERFORMING = "performing"
    CLONING = "cloning"
    MOUNTED = "mounted"
    ERROR = "error"
    DELETE_ONGOING = "delete-ongoing"  # vfolder is being deleted
    DELETE_COMPLETE = "deleted-complete"  # vfolder is deleted
    PURGE_ONGOING = "purge-ongoing"  # vfolder is being removed permanently

After:

class VFolderOperationStatus(enum.StrEnum):  # use Python 3.11's StrEnum
    """
    Introduce virtual folder current status for storage-proxy operations.
    """

    READY = "ready"
    PERFORMING = "performing"
    CLONING = "cloning"
    # MOUNTED: Tracking of the mount status should be done in a separate table.
    # ERROR: It should be defined for each different operations. e.g., DELETE_ERROR, CLONING_ERROR, etc.
    DELETE_PENDING = "delete-pending"  # new state for trash bin
    DELETE_ONGOING = "delete-ongoing"  # vfolder is being deleted in the storage proxy
    DELETE_COMPLETE = "delete-complete"  # fix the typo
    DELETE_ERROR = "delete-error"  # explicit failure state

Additional technical considerations

  • storage-proxy
    • Limit the number of concurrent vfolder removal operations in the filesystem.
    • When requested vfolder removal twice or more times for a same vfolder, continue the first operation without spawning multiple removal jobs.
    • Report the completion of vfolder removal to the manager in an asynchronous way. (via the event bus?)
    • When cancelled due to shutdown of the service in the middle of operations, gracefully cease the operation. This cancellation shouldn't be treated as DELETE_ERROR but the state must be kept DELETE_ONGOING for continuation after restart.
      • In the future, we could introduce the reconcilation loop design here.
  • manager
    • When the manager is restarted, restart the delete operations against DELETE_ONGOING vfolders. It should be safe to make multiple duplicate removal requests to the same vfolder.
    • Extend clean-history implementation to "purge" the vfolders in the DELETE_COMPLETE state.

Tasks

  1. comp:client comp:manager comp:storage-proxy require:db-migration size:XL type:feature
    fregataa
  2. comp:cli comp:client comp:manager comp:storage-proxy require:db-migration size:XL type:feature urgency:4
    fregataa
  3. comp:manager skip:changelog type:enhance
    achimnol
  4. comp:cli comp:manager type:enhance
    fregataa
  5. area:docs comp:cli comp:client comp:common comp:manager comp:storage-proxy size:L type:enhance urgency:4
    fregataa
  6. 0 of 2
    comp:manager comp:storage-proxy type:enhance urgency:5
    fregataa
@fregataa fregataa added type:feature Add new features comp:storage-proxy Related to Storage proxy component labels Oct 3, 2022
@fregataa fregataa self-assigned this Oct 24, 2022
@lizable
Copy link
Contributor

lizable commented Oct 24, 2022

Let's implement this first.

We can implement "Trash bin", where we can restore DELETE-PENDING vfolders by the owner of the vfolder or any admin.
And the path would be changed when receiving DELETE request.
e.g. <vfhost>/12/23/456... -> <vfhoost>/.trash/12/23/456...

@kyujin-cho
Copy link
Member

Most of the essential features will be covered by #835 but we still need to implement a timer which periodically purges long-lasting VFolders in trash bin.

@fregataa
Copy link
Member Author

fregataa commented Oct 4, 2023

@agatha197 @lizable @yomybaby
Need vfolder purge support in webui, and delete API will be soft-delete as we implemented trash bin since 24.03 version.

@achimnol achimnol added this to the 24.03 milestone Feb 6, 2024
@achimnol achimnol changed the title Let's implement advanced deletion features for vfolder Let's implement advanced deletion features (aka trash bin) for vfolder Feb 6, 2024
@achimnol achimnol changed the title Let's implement advanced deletion features (aka trash bin) for vfolder Advanced vfolder deletion features (aka trash bin) Feb 6, 2024
@achimnol achimnol added the urgency:4 As soon as feasible, implementation is essential. label Feb 8, 2024
@achimnol achimnol added the comp:manager Related to Manager component label Feb 28, 2024
@achimnol achimnol removed the type:feature Add new features label Oct 18, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
comp:manager Related to Manager component comp:storage-proxy Related to Storage proxy component urgency:4 As soon as feasible, implementation is essential.
Projects
None yet
Development

No branches or pull requests

4 participants