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

Add section on storage classes to PV doc #1064

Merged
merged 11 commits into from
Aug 26, 2016

Conversation

wongma7
Copy link
Contributor

@wongma7 wongma7 commented Aug 19, 2016

For kubernetes/kubernetes#29006 & kubernetes/enhancements#36

edit: oops, reopening against 1.4 :)


This change is Reviewable

@wongma7 wongma7 force-pushed the storage-class branch 3 times, most recently from ecc7d33 to 2ab60ac Compare August 19, 2016 19:35
@wongma7 wongma7 changed the base branch from master to release-1.4 August 19, 2016 19:36
@wongma7 wongma7 changed the base branch from release-1.4 to master August 19, 2016 19:37
@wongma7 wongma7 closed this Aug 19, 2016
@wongma7 wongma7 reopened this Aug 19, 2016
@@ -20,6 +20,19 @@ A `PersistentVolume` (PV) is a piece of networked storage in the cluster that ha

A `PersistentVolumeClaim` (PVC) is a request for storage by a user. It is similar to a pod. Pods consume node resources and PVCs consume PV resources. Pods can request specific levels of resources (CPU and Memory). Claims can request specific size and access modes (e.g, can be mounted once read/write or many times read-only).

Administrators often need to offer and provision a variety of
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

These paragraphs seem out of place. Maybe a better transition from the previously ideas would help?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe intro with:

While PersistentVolumeClaims allow a user to consume abstract storage resources, it is common that users need PersistentVolumes with varying properties, such as performance, for different problems. Cluster administrators need to be able to offer a variety of PersistentVolumes that differ in more ways than just size and access modes, without exposing users to the details of how those volumes are implemented. For these needs there is the StorageClass resource.


### Provisioner
Storage classes have a provisioner that determines what volume plugin is used
for provisioning PVs. This field must be specified. The available provisioner
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

During beta, the available...

@jsafrane
Copy link
Member

IMO, StorageClasses and PVCs and PVs are more entangled together than it was before and the page should reflect it. E.g. chapter Provisioning should mention both static and dynamic provisioning and how class on PVC influences that, especially that pvc.class="" effectively disables dynamic provisioning.
https://github.com/wongma7/kubernetes.github.io/blob/c53a3272499650027498d58b9d645789edf6cea0/docs/user-guide/persistent-volumes/index.md#provisioning

Chapter Persistent Volumes should mention also class attribute/annotation
https://github.com/wongma7/kubernetes.github.io/blob/c53a3272499650027498d58b9d645789edf6cea0/docs/user-guide/persistent-volumes/index.md#persistent-volumes

Chapter PersistentVolumeClaims should mention also class attribute/annotation
https://github.com/wongma7/kubernetes.github.io/blob/c53a3272499650027498d58b9d645789edf6cea0/docs/user-guide/persistent-volumes/index.md#persistentvolumeclaims
(and you can put description of the admission controller here).

```

* `type`: `io1`, `gp2`, `sc1`, `st1`. See AWS docs for details. Default: `gp2`.
* `zone`: AWS zone. If not specified, a random zone in the same region as
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

actually, it's not "random zone in the same region", it's "a random zone where this Kubernetes cluster has a node". I'll update kubernetes/examples/experimental/persistent-volume-provisioning.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@jsafrane is this the same for gce?

@wongma7
Copy link
Contributor Author

wongma7 commented Aug 23, 2016

I moved the defaulting but kept a little sentence under StorageClasses. Is it redundant given that the linked section is right above it?

Still need to talk about dynamic provisioning throughout the page, as you say...I think right now it feels like it's an afterthought at the bottom of the page.

(just wondering is spec.class going to be a mandatory field?)

also in case this gets missed: I added this sentence 'This means that the PVs those PVCs would normally be bound to, the PVs that have no class (no annotation or annotation equal to ""), cannot be bound to any PVC. ' this is true and worth saying, right?

edit: sorry for the weird commits

be bound to the PVC.

PVCs don't necessarily have to request a class, they can omit the annotation or
set it to `""`. The cluster treats PVCs that don't request a class differently
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's slightly more complicated.

  • Missing class annotation in PVC means "I don't care about the class" and defaulting in the admission controller happens, i.e. the user gets the default class.
    • If there is no default storage class set or the admission controller is not running, a classless PV is then requested (see below).
  • Class annotation set to "" means that the PVC requests PV with class="" or missing annotation, i.e. a classless PV. That's the only way to get a PV with no/empty class.

can only be bound to PVs with no class (no annotation or one set equal to
`""`). A PVC with no annotation is not quite the same and is treated differently
by the cluster depending on whether the
[`SimpleDefaultStorageClassForPVC` admission controller](docs/admin/admission-controllers/#simpledefaultstorageclassforpvc)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

it's now DefaultStorageClass. And it's not "admission controller", but officially it is "admission plugin"

@jsafrane
Copy link
Member

@wongma7, great work so far, now it looks much better than before. I have only couple of comments above.

@thockin
Copy link
Member

thockin commented Aug 24, 2016

Admission controller got merged - please update this PR

iopsPerGB: "10"
```

* `type`: `io1`, `gp2`, `sc1`, `st1`. See AWS docs for details. Default: `gp2`.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we need a huge link to AWS docs (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSVolumeTypes.html) is necessary, rules about available sizes and types (and IOPS) are quite complicated.

@wongma7
Copy link
Contributor Author

wongma7 commented Aug 25, 2016

I added this sentence: Volumes that were dynamically provisioned are always deleted. So does gluster now also support delete reclaim policy?

nvm, I see kubernetes/kubernetes#31243

@jsafrane
Copy link
Member

I am satisfied with the current version

@wongma7, please rebase to master
@saad-ali @thockin PTAL

@thockin
Copy link
Member

thockin commented Aug 26, 2016

@jaredbhatti @devin-donnelly @kubernetes/docs

@devin-donnelly
Copy link
Contributor

This looks more or less fine from a docs standpoint.

@devin-donnelly devin-donnelly merged commit 086c65a into kubernetes:master Aug 26, 2016
wongma7 added a commit to wongma7/kubernetes.github.io that referenced this pull request Sep 14, 2016
wongma7 added a commit to wongma7/kubernetes.github.io that referenced this pull request Sep 14, 2016
@wongma7 wongma7 mentioned this pull request Sep 16, 2016
mikutas pushed a commit to mikutas/k8s-website that referenced this pull request Sep 22, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants