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

make volgroup and vgpattern optional args for volume provisioning #312

Open
abhilashshetty04 opened this issue Jun 14, 2024 · 0 comments
Open
Assignees
Labels
enhancement New feature or request

Comments

@abhilashshetty04
Copy link
Member

abhilashshetty04 commented Jun 14, 2024

Following are the current behavior.
1. volgroup or vgpattern are mandatory patten in sc for lvm localpv to provision volume successfully.

2. If only one of this pattern is specified, Then lvm local pv assumes that the vg matching the pattern is available on all lvmnodes. Otherwise, User have to explicitly define which node has spcified vg using node topology. Its not easy User experience.

3. This behaviour sort of mandates user to preprovision vg with specific vg name on all nodes. If they have a plan to have vg name unique accross lvmnodes then they have to sc specfic to the vg with node topology.

4.If user has unique vg name across nodes and creates a sc with volgroup for specific vg. Then provisioner will create lvmvolume cr anyway on some node without checking if that node has vg specified in sc parameter. The cr is picked by a node plugin which is set in owner field. It marks CR as error as vg is not available. Then provisioner sees the error on CR deletes CR and returns ResourceExhausted grpc Response.

5. If user created a sc with volgroup which doesnt exist in any node. Then also lvmvolume cr is created on any node randomly. The creation will fail and cr is deleted. If user creates a vg before a retry of /CreateVolume is received. It doesnt pick the node it picked before. Its as if not trying to schedule on the node where vg is present(unless vg with that name is present on all node and node topology is not given).

6. If all node has vg specified in sc. However, pvc is requesting volume size which no vg can accomodate. Then also lvmvolume cr is created and it follows same path where error is appended on cr by node plugin and deleted with ResourceExhaused.

Im suggesting following change:

1. Make volgroup and vgpattern not a mandatory paramater in storage class for volume provisioning. If user have not preovided anyof these 2 params and no topology constraint. Schedular can place lvmvolume on any node any vg.

2. If user specified volgroup/vgpattern then provisioner should take that into consideration. Even if no topology specified, Provisioner should not expect vg to be present on all node. If it cant find vg in any node then it should fail fast (Dont create CR also return ResourceExhausted allowing further retires. Meanwhile if user creates new vg on any node that match the pattern then lvmvolume should be provisioned on that node.

3. If user creates sc with volgroup/vgpattern, has node topologies also set to a particular node/s. Then strictly adhere to that. 

4. Dont create lvmvolume CR if no vg in the cluster can accomodate the volume due to the size requested in pvc. Today, We pick node mostly based on scheduling alorithm and dont factor in the pvc size requirement. We should Fail with ResourceExhausted. Allowing retry.

We should also analyse current provisioning algorithm and make it more capacity aware while choosing node to create lvmvolume cr.

Currently it sort of left on lvmnode plugin to select which vg should be used to create lv when it receives the create event. It can be done by th controller as vg capacity stats are on the lvmnode cr.

Anything else you would like to add:
Following link has details of some scenario that i tested.
https://gist.github.com/abhilashshetty04/dcb73d32a8c6eecbe3160629b9be4f52

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
Status: No status
Development

No branches or pull requests

2 participants