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

Support volume type "hostPath" for volume mounting #15546

Closed
vthurimella opened this issue Oct 2, 2024 · 22 comments · Fixed by #15648
Closed

Support volume type "hostPath" for volume mounting #15546

vthurimella opened this issue Oct 2, 2024 · 22 comments · Fixed by #15648
Assignees
Labels
area/API API objects and controllers kind/feature Well-understood/specified features, ready for coding.
Milestone

Comments

@vthurimella
Copy link
Contributor

In what area(s)?

/area API

Describe the feature

Adding support for the "hostPath" volume type in Knative Serving would allow users to mount directories from the host node's filesystem into their Knative service containers. This feature would enable access to local storage on the node, facilitating use cases such as accessing node-specific data or utilizing local caches, while maintaining the serverless benefits of Knative.

@vthurimella vthurimella added the kind/feature Well-understood/specified features, ready for coding. label Oct 2, 2024
@knative-prow knative-prow bot added the area/API API objects and controllers label Oct 2, 2024
@skonto
Copy link
Contributor

skonto commented Oct 3, 2024

Hi @vthurimella see comment here #13690 (comment).
Could you elaborate on this one? Is it an AI use case?

@vthurimella
Copy link
Contributor Author

My use case involves scientific workflows with AI components. We use Knative as a dynamic resource allocator across a shared cluster. Our Knative tasks generate files that must be written to the specific node where execution occurs. We have a robust system for file tracking and inter-node file transfer. Without hostPath support, we cannot efficiently manage data locality, which is crucial for our workflow performance (right now we have the task call a file service on the execution node that has a hostPath mounted). This feature would significantly help me integrate Knative into my application.

@skonto
Copy link
Contributor

skonto commented Oct 7, 2024

@dprotaso gentle ping, wdyth?

@vthurimella
Copy link
Contributor Author

Thank you for considering this feature request! I understand that adding hostPath support might not be feasible for the main project due to various constraints or design considerations.

If it's not possible to integrate this into Knative directly, I would appreciate any guidance on how I could modify the code myself to add the hostPath functionality for my specific use case and deploy it in my own application. This way, I could get the functionality I need for my installation without affecting the broader project.

Any information on which parts of the codebase I should focus on, or any architectural considerations I should keep in mind, would be extremely helpful. This would allow me to tailor the solution to my applications needs while maintaining the core benefits of Knative in my setup.

@rhuss
Copy link
Contributor

rhuss commented Oct 10, 2024

I think It makes sense to allow hostPath volumes, similar to support persistent volumes. This can be hidden behind a feature flag.

@vthurimella looks for kubernetes.podspec-persistent-volume-claim in the source, starting from pkg/apis/config/features.go and follow its usage trail. You should be able to implement hostPath in a similar way.

@vthurimella, just out of curiosity, what is the reason for choosing Knative as resource allocator ? Which feature of Knative serving is the most important to you ?

@skonto
Copy link
Contributor

skonto commented Oct 15, 2024

@vthurimella You can have hostPath access via a pvc however there are limitations see discussion here, this has been asked multiple times before. @dprotaso what is your take on this one? Should we stay opinionated here or add it as a feature as discussed before?

@dprotaso
Copy link
Member

I think it should be fine to add behind a feature flag.

@skonto
Copy link
Contributor

skonto commented Oct 18, 2024

/assign @skonto

@skonto
Copy link
Contributor

skonto commented Oct 18, 2024

@amarflybot hi, are you interested on working on #13693 again? If so I can assign it to you and re-open it.

@amarflybot
Copy link
Contributor

amarflybot commented Oct 18, 2024

Yes, I will work on this.

@skonto
Copy link
Contributor

skonto commented Oct 18, 2024

This is no longer required as we can achieve hostpath mount via pvc.

True but others have reported certain limitations on this, such as being restricted to a specific node.

@skonto
Copy link
Contributor

skonto commented Oct 18, 2024

/assign @amarflybot

@skonto
Copy link
Contributor

skonto commented Oct 18, 2024

@amarflybot a few comments about the PR you had:
a) schema changes need to be behind a flag, make sure you add that in the schemapatch-config.
b) hostpath needs certain validation as we want to catch errors early before we deploy real resources eg. path cannot be empty. K8s has this kind of validation here.
c) we need more tests under k8s validation

@vthurimella
Copy link
Contributor Author

@rhuss

@vthurimella looks for kubernetes.podspec-persistent-volume-claim in the source, starting from pkg/apis/config/features.go and follow its usage trail. You should be able to implement hostPath in a similar way.

Thank you for the tips!

@vthurimella, just out of curiosity, what is the reason for choosing Knative as resource allocator ? Which feature of Knative serving is the most important to you ?

The most important feature for my use case is autoscaling. The wide range of tunable parameters provides the flexibility I need to achieve good performance for my application.

@skonto @dprotaso Thank you two again for taking the time to considering this feature request!

@skonto
Copy link
Contributor

skonto commented Oct 24, 2024

@amarflybot hi, if you need any pointers here is what I had. Please ping me to review.

@skonto skonto added this to the v1.17.0 milestone Oct 24, 2024
@skonto
Copy link
Contributor

skonto commented Oct 29, 2024

@amarflybot hi, gentle ping.

@amarflybot
Copy link
Contributor

Give me sometime, was out for vacation. Will solve this asap.

@amarflybot
Copy link
Contributor

@amarflybot hi, if you need any pointers here is what I had. Please ping me to review.

56ef531

These are some changes in validation I could find I had done before, if this helps.

@skonto
Copy link
Contributor

skonto commented Nov 15, 2024

Hi @amarflybot that branch is a bit old. Pls take a look of my branch or update yours.

@skonto
Copy link
Contributor

skonto commented Nov 26, 2024

@amarflybot gentle ping.

@skonto
Copy link
Contributor

skonto commented Dec 9, 2024

@amarflybot hi any update on this?

@amarflybot
Copy link
Contributor

Hi @skonto , Could you please have a look at this PR?

#15648

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area/API API objects and controllers kind/feature Well-understood/specified features, ready for coding.
Projects
Development

Successfully merging a pull request may close this issue.

5 participants