2017-06-23 19:23:36 +00:00
---
title: "Example: Deploying Cassandra with Stateful Sets"
2018-02-18 20:13:37 +00:00
reviewers:
2017-08-19 00:19:11 +00:00
- ahmetb
2018-05-05 16:00:51 +00:00
content_template: templates/tutorial
2018-05-15 22:29:27 +00:00
weight: 30
2017-06-23 19:23:36 +00:00
---
2018-05-05 16:00:51 +00:00
{{% capture overview %}}
2018-08-20 20:47:30 +00:00
This tutorial shows you how to develop a native cloud [Cassandra ](http://cassandra.apache.org/ ) deployment on Kubernetes. In this example, a custom Cassandra *SeedProvider* enables Cassandra to discover new Cassandra nodes as they join the cluster.
2017-07-27 21:11:39 +00:00
2018-08-20 20:47:30 +00:00
*StatefulSets* make it easier to deploy stateful applications within a clustered environment. For more information on the features used in this tutorial, see the [*StatefulSet* ](/docs/concepts/workloads/controllers/statefulset/ ) documentation.
2017-07-27 21:11:39 +00:00
2018-07-05 20:50:44 +00:00
**Cassandra on Docker**
2017-06-23 19:23:36 +00:00
2018-08-20 20:47:30 +00:00
The *Pods* in this tutorial use the [`gcr.io/google-samples/cassandra:v13` ](https://github.com/kubernetes/examples/blob/master/cassandra/image/Dockerfile )
2017-06-23 19:23:36 +00:00
image from Google's [container registry ](https://cloud.google.com/container-registry/docs/ ).
2018-07-05 20:50:44 +00:00
The Docker image above is based on [debian-base ](https://github.com/kubernetes/kubernetes/tree/master/build/debian-base )
2018-07-02 20:37:19 +00:00
and includes OpenJDK 8.
2018-07-05 20:50:44 +00:00
2018-07-02 20:37:19 +00:00
This image includes a standard Cassandra installation from the Apache Debian repo.
By using environment variables you can change values that are inserted into `cassandra.yaml` .
2017-06-23 19:23:36 +00:00
| ENV VAR | DEFAULT VALUE |
| ------------- |:-------------: |
2018-06-22 00:00:30 +00:00
| `CASSANDRA_CLUSTER_NAME` | `'Test Cluster'` |
| `CASSANDRA_NUM_TOKENS` | `32` |
| `CASSANDRA_RPC_ADDRESS` | `0.0.0.0` |
2017-06-23 19:23:36 +00:00
2018-05-05 16:00:51 +00:00
{{% /capture %}}
2017-06-23 19:23:36 +00:00
2018-05-05 16:00:51 +00:00
{{% capture objectives %}}
2018-08-20 20:47:30 +00:00
* Create and validate a Cassandra headless [*Service* ](/docs/concepts/services-networking/service/ ).
* Use a [StatefulSet ](/docs/concepts/workloads/controllers/statefulset/ ) to create a Cassandra ring.
* Validate the [StatefulSet ](/docs/concepts/workloads/controllers/statefulset/ ).
* Modify the [StatefulSet ](/docs/concepts/workloads/controllers/statefulset/ ).
* Delete the [StatefulSet ](/docs/concepts/workloads/controllers/statefulset/ ) and its [Pods ](/docs/concepts/workloads/pods/pod/ ).
2018-05-05 16:00:51 +00:00
{{% /capture %}}
2017-06-23 19:23:36 +00:00
2018-05-05 16:00:51 +00:00
{{% capture prerequisites %}}
2018-08-20 20:47:30 +00:00
To complete this tutorial, you should already have a basic familiarity with [Pods ](/docs/concepts/workloads/pods/pod/ ), [Services ](/docs/concepts/services-networking/service/ ), and [StatefulSets ](/docs/concepts/workloads/controllers/statefulset/ ). In addition, you should:
2017-06-23 19:23:36 +00:00
2018-08-20 20:47:30 +00:00
* [Install and Configure ](/docs/tasks/tools/install-kubectl/ ) the *kubectl* command-line tool
2017-06-23 19:23:36 +00:00
2018-07-27 23:03:27 +00:00
* Download [`cassandra-service.yaml` ](/examples/application/cassandra/cassandra-service.yaml )
and [`cassandra-statefulset.yaml` ](/examples/application/cassandra/cassandra-statefulset.yaml )
2017-06-23 19:23:36 +00:00
2018-07-27 23:03:27 +00:00
* Have a supported Kubernetes cluster running
2017-06-23 19:23:36 +00:00
2018-05-05 16:00:51 +00:00
{{< note > }}
2018-11-06 19:33:04 +00:00
Please read the [getting started guides ](/docs/setup/pick-right-solution/ ) if you do not already have a cluster.
2018-05-05 16:00:51 +00:00
{{< / note > }}
2017-06-23 19:23:36 +00:00
2017-07-27 21:11:39 +00:00
### Additional Minikube Setup Instructions
2017-06-23 19:23:36 +00:00
2018-05-05 16:00:51 +00:00
{{< caution > }}
2018-11-06 19:33:04 +00:00
[Minikube ](/docs/getting-started-guides/minikube/ ) defaults to 1024MB of memory and 1 CPU. Running Minikube with the default resource configuration results in insufficient resource errors during this tutorial. To avoid these errors, start Minikube with the following settings:
2017-06-23 19:23:36 +00:00
2018-07-25 22:41:34 +00:00
```shell
2018-06-22 00:00:30 +00:00
minikube start --memory 5120 --cpus=4
```
{{< / caution > }}
2017-08-19 00:10:40 +00:00
2018-05-05 16:00:51 +00:00
{{% /capture %}}
2017-06-23 19:23:36 +00:00
2018-05-05 16:00:51 +00:00
{{% capture lessoncontent %}}
2017-07-27 21:11:39 +00:00
## Creating a Cassandra Headless Service
2018-06-22 00:00:30 +00:00
2018-08-20 20:47:30 +00:00
A Kubernetes [Service ](/docs/concepts/services-networking/service/ ) describes a set of [Pods ](/docs/concepts/workloads/pods/pod/ ) that perform the same task.
2017-06-23 19:23:36 +00:00
2018-08-20 20:47:30 +00:00
The following `Service` is used for DNS lookups between Cassandra Pods and clients within the Kubernetes cluster.
2017-06-23 19:23:36 +00:00
2018-07-02 20:37:19 +00:00
{{< codenew file = "application/cassandra/cassandra-service.yaml" > }}
2017-06-23 19:23:36 +00:00
2017-08-19 00:10:40 +00:00
1. Launch a terminal window in the directory you downloaded the manifest files.
2018-08-20 20:47:30 +00:00
1. Create a Service to track all Cassandra StatefulSet nodes from the `cassandra-service.yaml` file:
2017-06-23 19:23:36 +00:00
2018-07-25 22:41:34 +00:00
```shell
Official 1.14 Release Docs (#13174)
* Official documentation on Poseidon/Firmament, a new multi-scheduler support for K8S. (#11752)
* Added documentation about Poseidon-Firmament scheduler
* Fixed some style issues.
* Udpated the document as per the review comments.
* Fixed some typos and updated the document
* Updated the document as per the review comments.
* Document timeout attribute for kms-plugin. (#12158)
See 72540.
* Official documentation on Poseidon/Firmament, a new multi-scheduler (#12343)
* Removed the old version of the Poseidon documentation. Incorrect location.
* Official documentation on Poseidon/Firmament, a new multi-scheduler support for K8S (#12069)
* Official documentation on Poseidon/Firmament, a new multi-scheduler support for K8S. (#11752)
* Added documentation about Poseidon-Firmament scheduler
* Fixed some style issues.
* Udpated the document as per the review comments.
* Fixed some typos and updated the document
* Updated the document as per the review comments.
* Updated the document as per review comments. Added config details.
* Updated the document as per the latest review comments. Fixed nits
* Made changes as per latest suggestions.
* Some more changes added.
* Updated as per suggestions.
* Changed the release process section.
* SIG Docs edits
Small edits to match style guidelines.
* add plus to feature state
* capitalization
* revert feature state shortcode
since this is a Kubernetes extension, not a direct feature, it shouldn't use the regular feature state tagging.
(cherry picked from commit 7730c1540b637be74b9b21d4128a145994eb19cc)
* Remove initializers from doc. It will be removed in 1.14 (#12331)
* kubeadm: Document CRI auto detection functionality (#12462)
Signed-off-by: Rostislav M. Georgiev <rostislavg@vmware.com>
* Minor doc change for GAing Pod DNS Config (#12514)
* Graduate ExpandInUsePersistentVolumes feature to beta (#10574)
* Rename 2018-11-07-grpc-load-balancing-with-linkerd.md.md file (#12594)
* Add dynamic percentage of node scoring to user docs (#12235)
* Add dynamic percentage of node scoring to user docs
* addressed review comments
* delete special symbol (#12445)
* Update documentation for VolumeSubpathEnvExpansion (#11843)
* Update documentation for VolumeSubpathEnvExpansion
* Address comments - improve descriptions
* Graduate Pod Priority and Preemption to GA (#12428)
* Added Instana links to the documentation (#12977)
* Added link to the Instana Kubernetes integration
* Added Instana link for services section
Added Instana and a link to the Kubernetes integration to the analytics services section and broadened the scope to APM, monitoring and analytics.
* Oxford comma /flex
* More Oxford commas, because they matter
* Update kubectl plugins to stable (#12847)
* documentation for CSI topology beta (#12889)
* Document changes to default RBAC discovery ClusterRole(Binding)s (#12888)
* Document changes to default RBAC discovery ClusterRole(Binding)s
Documentation for https://github.com/kubernetes/enhancements/issues/789 and https://github.com/kubernetes/kubernetes/pull/73807
* documentation review feedback
* CSI raw block to beta (#12931)
* Change incorrect string raw to block (#12926)
Fixes #12925
* Update documentation on node OS/arch labels (#12976)
These labels have been promoted to GA:
https://github.com/kubernetes/enhancements/issues/793
* local pv GA doc updates (#12915)
* Publish CRD OpenAPI Documentation (#12910)
* add documentation for CustomResourcePublishOpenAPI
* address comments
fix links, ordered lists, style and typo
* kubeadm: add document for upgrading from 1.13 to 1.14 (single CP and HA) (#13189)
* kubeadm: add document for upgrading from 1.13 to 1.14
- remove doc for upgrading 1.10 -> 1.11
* kubeadm: apply amends to upgrade-1.14 doc
* kubeadm: apply amends to upgrade-1.14 doc (part2)
* kubeadm: apply amends to upgrade-1.14 doc (part3)
* kubeadm: add note about "upgrade node experimental-control-plane"
+ add comment about `upgrade plan`
* kubeadm: add missing "You should see output similar to this"
* fix bullet indentation (#13214)
* mark PodReadinessGate GA (#12800)
* Update RuntimeClass documentation for beta (#13043)
* Update RuntimeClass documentation for beta
* Update feature gate & add upgrade section
* formatting fixes
* Highlight upgrade action required
* Address feedback
* CSI ephemeral volume alpha documentation (#10934)
* update kubectl documentation (#12867)
* update kubectl documentation
* add document for Secret/ConfigMap generators
* replace `kubectl create -f` by `kubectl apply -f`
* Add page for kustomization support in kubectl
* fix spelling errors and address comments
* Documentation for Windows GMSA feature (#12936)
* Documentation for Windows GMSA feature
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Enhancements to GMSA docs
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Fix links
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Fix GMSA link
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add GMSA feature flag in feature flag list
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Relocate GMSA to container configuration
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add example for container spec
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Remove changes in Windows index
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Update configure-gmsa.md
* Update configure-gmsa.md
* Update configure-gmsa.md
* Update configure-gmsa.md
* Rearrange the steps into two sections and other edits
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Fix links
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add reference to script to generate GMSA YAMLs
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Some more clarifications for GMSA
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* HugePages graduated to GA (#13004)
* HugePages graduated to GA
* fixing nit for build
* Docs for node PID limiting (https://github.com/kubernetes/kubernetes/pull/73651) (#12932)
* kubeadm: update the reference documentation for 1.14 (#12911)
* kubeadm: update list of generated files for 1.14
NOTE: PLACEHOLDERS! these files are generated by SIG Docs each
release, but we need them to pass the k/website PR CI.
- add join_phase* (new sub phases of join)
- add init_phase_upload-certs.md (new upload certs phase for init)
- remove alpha-preflight (now both init and join have this)
* kubeadm: update reference docs includes for 1.14
- remove includes from alpha.md
- add upload-certs to init-phase.md
- add join-phase.md and it's phases
* kubeadm: update the editorial content of join and init
- cleanup master->control-plane node
- add some notes about phases and join
- remove table about pre-pulling images
- remove outdated info about self-hosting
* kubeadm: update target release for v1alpha3 removal
1.14 -> 1.15
* kubeadm: copy edits for 1.14 reference docs (part1)
* kubeadm: use "shell" for code blocks
* kubeadm: update the 1.14 HA guide (#13191)
* kubeadm: update the 1.14 HA guide
* kubeadm: try to fix note/caution indent in HA page
* kubeadm: fix missing sudo and minor amends in HA doc
* kubeadm: apply latest amends to the HA doc for 1.14
* fixed a few missed merge conflicts
* Admission Webhook new features doc (#12938)
- kubernetes/kubernetes#74998
- kubernetes/kubernetes#74477
- kubernetes/kubernetes#74562
* Clarifications and fixes in GMSA doc (#13226)
* Clarifications and fixes in GMSA doc
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Update configure-gmsa.md
* Reformat to align headings and pre-reqs better
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Reformat to align headings and pre-reqs better
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Reformat to fix bullets
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Reword application of sample gmsa
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Update configure-gmsa.md
* Address feedback to use active voice
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Address feedback to use active voice
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* RunAsGroup documentation for Progressing this to Beta (#12297)
* start serverside-apply documentation (#13077)
* start serverside-apply documentation
* add more concept info on server side apply
* Update api concepts
* Update api-concepts.md
* fix style issues
* Document CSI update (#12928)
* Document CSI update
* Finish CSI documentation
Also fix mistake with ExpandInUsePersistentVolumes documented as beta
* Overall docs for CSI Migration feature (#12935)
* Placeholder docs for CSI Migration feature
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Address CR comments and update feature gates
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add mappings for CSI plugins
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add sections for AWS and GCE PD migration
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add docs for Cinder and CSI Migration info
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Clarify scope to volumes with file system
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Change the format of EBS and Cinder CSI Migration sections to follow the GCE template
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Windows documentation updates for 1.14 (#12929)
* Updated the note to indicate doc work for 1.14
* first attempt at md export from gdoc
* simplifyig
* big attempt
* moving DRAFT windows content to PR for review
* moving content to PR in markdown for review
* updated note tags
* Delete windows-contributing.md
deleting this file as it is already ported to the github contributor guide
* fixed formatting in intro and cluster setup guide
* updating formatting for running containers guide
* rejiggered end of troubleshooting
* fixed minor typos
* Clarified the windows binary download step
* Update _index.md
making updates based on feedback
* Update _index.md
updating ovn-kubernetes docs
* Update _index.md
* Update _index.md
* updating relative docs links
updating all the links to be relative links to /docs
* Update _index.md
* Update _index.md
updates for windows services and ovn-kubernetes
* formatted for correct step numbering
* fix typos
* Update _index.md
updates for flannel PR in troubleshooting
* Update _index.md
* Update _index.md
updating a few sections like roadmap, services, troubleshooting/filing tickets
* Update _index.md
* Update _index.md
* Update _index.md
* Fixed a few whitespace issues
* Update _index.md
* Update _index.md
* Update _index.md
* add section on upgrading CoreDNS (#12909)
* documentation for kubelet resource metrics endpoint (#12934)
* windows docs updates for 1.14 (#13279)
* Delete sample-l2bridge-wincni-config.json
this file is not used anywhere
* Update _index.md
* Update _index.md
* Update _index.md
* Update _index.md
* Update _index.md
* Rename content/en/docs/getting-started-guides/windows/_index.md to content/en/docs/setup/windows/_index.md
moving to new location
* Delete flannel-master-kubectl-get-ds.png
* Delete flannel-master-kubeclt-get-pods.png
* Delete windows-docker-error.png
* Add files via upload
* Rename _index.md to add-windows-nodes.md
* Create _index.md
* Update _index.md
* Update add-windows-nodes.md
* Update add-windows-nodes.md
* Create user-guide-windows-nodes.md
* Create user-guide-windows-containers.md
* Update and rename add-windows-nodes.md to intro-windows-nodes.md
* Update user-guide-windows-containers.md
* Rename intro-windows-nodes.md to intro-windows-in-kubernetes.md
* Update user-guide-windows-nodes.md
* Update user-guide-windows-containers.md
* Update user-guide-windows-containers.md
* Update user-guide-windows-nodes.md
* Update user-guide-windows-containers.md
* Update _index.md
* Update intro-windows-in-kubernetes.md
* Update intro-windows-in-kubernetes.md
fixing the pause image
* Update intro-windows-in-kubernetes.md
changing tables from html to MD
* Update user-guide-windows-nodes.md
converting tables from HTML to MD
* Update intro-windows-in-kubernetes.md
* Update user-guide-windows-nodes.md
* Update user-guide-windows-nodes.md
* Update user-guide-windows-nodes.md
updating the numbering , even though it messes up the notes a little bit. Jim will file a ticket to follow up
* Update user-guide-windows-nodes.md
* update to windows docs for 1.14 (#13322)
* Update intro-windows-in-kubernetes.md
* Update intro-windows-in-kubernetes.md
* Update intro-windows-in-kubernetes.md
* Update intro-windows-in-kubernetes.md
* Update intro-windows-in-kubernetes.md
* Update user-guide-windows-containers.md
* Update user-guide-windows-nodes.md
* Update intro-windows-in-kubernetes.md (#13344)
* server side apply followup (#13321)
* change some parts of serverside apply docs in response to comments
* fix typos and wording
* Update config.toml (#13365)
2019-03-25 22:06:16 +00:00
kubectl apply -f https://k8s.io/examples/application/cassandra/cassandra-service.yaml
2018-06-22 00:00:30 +00:00
```
2017-06-23 19:23:36 +00:00
2017-07-27 21:11:39 +00:00
### Validating (optional)
2017-06-23 19:23:36 +00:00
2018-08-20 20:47:30 +00:00
Get the Cassandra Service.
2017-06-23 19:23:36 +00:00
2018-07-25 22:41:34 +00:00
```shell
2018-06-22 00:00:30 +00:00
kubectl get svc cassandra
```
2017-06-23 19:23:36 +00:00
2018-07-25 22:42:33 +00:00
The response is
2017-06-23 19:23:36 +00:00
2018-06-22 00:00:30 +00:00
```
2018-08-21 14:09:15 +00:00
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
cassandra ClusterIP None < none > 9042/TCP 45s
2018-06-22 00:00:30 +00:00
```
2017-06-23 19:23:36 +00:00
2018-07-25 22:42:33 +00:00
Service creation failed if anything else is returned. Read [Debug Services ](/docs/tasks/debug-application-cluster/debug-service/ ) for common issues.
2017-06-23 19:23:36 +00:00
2017-07-27 21:11:39 +00:00
## Using a StatefulSet to Create a Cassandra Ring
2017-06-23 19:23:36 +00:00
2018-08-20 20:47:30 +00:00
The StatefulSet manifest, included below, creates a Cassandra ring that consists of three Pods.
2017-06-23 19:23:36 +00:00
2018-05-05 16:00:51 +00:00
{{< note > }}
2018-11-06 19:33:04 +00:00
This example uses the default provisioner for Minikube. Please update the following StatefulSet for the cloud you are working with.
2018-05-05 16:00:51 +00:00
{{< / note > }}
2017-06-23 19:23:36 +00:00
2018-07-02 20:37:19 +00:00
{{< codenew file = "application/cassandra/cassandra-statefulset.yaml" > }}
2017-06-23 19:23:36 +00:00
2018-08-20 20:47:30 +00:00
1. Update the StatefulSet if necessary.
1. Create the Cassandra StatefulSet from the `cassandra-statefulset.yaml` file:
2017-06-23 19:23:36 +00:00
2018-07-25 22:41:34 +00:00
```shell
Official 1.14 Release Docs (#13174)
* Official documentation on Poseidon/Firmament, a new multi-scheduler support for K8S. (#11752)
* Added documentation about Poseidon-Firmament scheduler
* Fixed some style issues.
* Udpated the document as per the review comments.
* Fixed some typos and updated the document
* Updated the document as per the review comments.
* Document timeout attribute for kms-plugin. (#12158)
See 72540.
* Official documentation on Poseidon/Firmament, a new multi-scheduler (#12343)
* Removed the old version of the Poseidon documentation. Incorrect location.
* Official documentation on Poseidon/Firmament, a new multi-scheduler support for K8S (#12069)
* Official documentation on Poseidon/Firmament, a new multi-scheduler support for K8S. (#11752)
* Added documentation about Poseidon-Firmament scheduler
* Fixed some style issues.
* Udpated the document as per the review comments.
* Fixed some typos and updated the document
* Updated the document as per the review comments.
* Updated the document as per review comments. Added config details.
* Updated the document as per the latest review comments. Fixed nits
* Made changes as per latest suggestions.
* Some more changes added.
* Updated as per suggestions.
* Changed the release process section.
* SIG Docs edits
Small edits to match style guidelines.
* add plus to feature state
* capitalization
* revert feature state shortcode
since this is a Kubernetes extension, not a direct feature, it shouldn't use the regular feature state tagging.
(cherry picked from commit 7730c1540b637be74b9b21d4128a145994eb19cc)
* Remove initializers from doc. It will be removed in 1.14 (#12331)
* kubeadm: Document CRI auto detection functionality (#12462)
Signed-off-by: Rostislav M. Georgiev <rostislavg@vmware.com>
* Minor doc change for GAing Pod DNS Config (#12514)
* Graduate ExpandInUsePersistentVolumes feature to beta (#10574)
* Rename 2018-11-07-grpc-load-balancing-with-linkerd.md.md file (#12594)
* Add dynamic percentage of node scoring to user docs (#12235)
* Add dynamic percentage of node scoring to user docs
* addressed review comments
* delete special symbol (#12445)
* Update documentation for VolumeSubpathEnvExpansion (#11843)
* Update documentation for VolumeSubpathEnvExpansion
* Address comments - improve descriptions
* Graduate Pod Priority and Preemption to GA (#12428)
* Added Instana links to the documentation (#12977)
* Added link to the Instana Kubernetes integration
* Added Instana link for services section
Added Instana and a link to the Kubernetes integration to the analytics services section and broadened the scope to APM, monitoring and analytics.
* Oxford comma /flex
* More Oxford commas, because they matter
* Update kubectl plugins to stable (#12847)
* documentation for CSI topology beta (#12889)
* Document changes to default RBAC discovery ClusterRole(Binding)s (#12888)
* Document changes to default RBAC discovery ClusterRole(Binding)s
Documentation for https://github.com/kubernetes/enhancements/issues/789 and https://github.com/kubernetes/kubernetes/pull/73807
* documentation review feedback
* CSI raw block to beta (#12931)
* Change incorrect string raw to block (#12926)
Fixes #12925
* Update documentation on node OS/arch labels (#12976)
These labels have been promoted to GA:
https://github.com/kubernetes/enhancements/issues/793
* local pv GA doc updates (#12915)
* Publish CRD OpenAPI Documentation (#12910)
* add documentation for CustomResourcePublishOpenAPI
* address comments
fix links, ordered lists, style and typo
* kubeadm: add document for upgrading from 1.13 to 1.14 (single CP and HA) (#13189)
* kubeadm: add document for upgrading from 1.13 to 1.14
- remove doc for upgrading 1.10 -> 1.11
* kubeadm: apply amends to upgrade-1.14 doc
* kubeadm: apply amends to upgrade-1.14 doc (part2)
* kubeadm: apply amends to upgrade-1.14 doc (part3)
* kubeadm: add note about "upgrade node experimental-control-plane"
+ add comment about `upgrade plan`
* kubeadm: add missing "You should see output similar to this"
* fix bullet indentation (#13214)
* mark PodReadinessGate GA (#12800)
* Update RuntimeClass documentation for beta (#13043)
* Update RuntimeClass documentation for beta
* Update feature gate & add upgrade section
* formatting fixes
* Highlight upgrade action required
* Address feedback
* CSI ephemeral volume alpha documentation (#10934)
* update kubectl documentation (#12867)
* update kubectl documentation
* add document for Secret/ConfigMap generators
* replace `kubectl create -f` by `kubectl apply -f`
* Add page for kustomization support in kubectl
* fix spelling errors and address comments
* Documentation for Windows GMSA feature (#12936)
* Documentation for Windows GMSA feature
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Enhancements to GMSA docs
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Fix links
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Fix GMSA link
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add GMSA feature flag in feature flag list
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Relocate GMSA to container configuration
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add example for container spec
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Remove changes in Windows index
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Update configure-gmsa.md
* Update configure-gmsa.md
* Update configure-gmsa.md
* Update configure-gmsa.md
* Rearrange the steps into two sections and other edits
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Fix links
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add reference to script to generate GMSA YAMLs
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Some more clarifications for GMSA
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* HugePages graduated to GA (#13004)
* HugePages graduated to GA
* fixing nit for build
* Docs for node PID limiting (https://github.com/kubernetes/kubernetes/pull/73651) (#12932)
* kubeadm: update the reference documentation for 1.14 (#12911)
* kubeadm: update list of generated files for 1.14
NOTE: PLACEHOLDERS! these files are generated by SIG Docs each
release, but we need them to pass the k/website PR CI.
- add join_phase* (new sub phases of join)
- add init_phase_upload-certs.md (new upload certs phase for init)
- remove alpha-preflight (now both init and join have this)
* kubeadm: update reference docs includes for 1.14
- remove includes from alpha.md
- add upload-certs to init-phase.md
- add join-phase.md and it's phases
* kubeadm: update the editorial content of join and init
- cleanup master->control-plane node
- add some notes about phases and join
- remove table about pre-pulling images
- remove outdated info about self-hosting
* kubeadm: update target release for v1alpha3 removal
1.14 -> 1.15
* kubeadm: copy edits for 1.14 reference docs (part1)
* kubeadm: use "shell" for code blocks
* kubeadm: update the 1.14 HA guide (#13191)
* kubeadm: update the 1.14 HA guide
* kubeadm: try to fix note/caution indent in HA page
* kubeadm: fix missing sudo and minor amends in HA doc
* kubeadm: apply latest amends to the HA doc for 1.14
* fixed a few missed merge conflicts
* Admission Webhook new features doc (#12938)
- kubernetes/kubernetes#74998
- kubernetes/kubernetes#74477
- kubernetes/kubernetes#74562
* Clarifications and fixes in GMSA doc (#13226)
* Clarifications and fixes in GMSA doc
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Update configure-gmsa.md
* Reformat to align headings and pre-reqs better
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Reformat to align headings and pre-reqs better
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Reformat to fix bullets
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Reword application of sample gmsa
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Update configure-gmsa.md
* Address feedback to use active voice
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Address feedback to use active voice
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* RunAsGroup documentation for Progressing this to Beta (#12297)
* start serverside-apply documentation (#13077)
* start serverside-apply documentation
* add more concept info on server side apply
* Update api concepts
* Update api-concepts.md
* fix style issues
* Document CSI update (#12928)
* Document CSI update
* Finish CSI documentation
Also fix mistake with ExpandInUsePersistentVolumes documented as beta
* Overall docs for CSI Migration feature (#12935)
* Placeholder docs for CSI Migration feature
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Address CR comments and update feature gates
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add mappings for CSI plugins
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add sections for AWS and GCE PD migration
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add docs for Cinder and CSI Migration info
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Clarify scope to volumes with file system
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Change the format of EBS and Cinder CSI Migration sections to follow the GCE template
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Windows documentation updates for 1.14 (#12929)
* Updated the note to indicate doc work for 1.14
* first attempt at md export from gdoc
* simplifyig
* big attempt
* moving DRAFT windows content to PR for review
* moving content to PR in markdown for review
* updated note tags
* Delete windows-contributing.md
deleting this file as it is already ported to the github contributor guide
* fixed formatting in intro and cluster setup guide
* updating formatting for running containers guide
* rejiggered end of troubleshooting
* fixed minor typos
* Clarified the windows binary download step
* Update _index.md
making updates based on feedback
* Update _index.md
updating ovn-kubernetes docs
* Update _index.md
* Update _index.md
* updating relative docs links
updating all the links to be relative links to /docs
* Update _index.md
* Update _index.md
updates for windows services and ovn-kubernetes
* formatted for correct step numbering
* fix typos
* Update _index.md
updates for flannel PR in troubleshooting
* Update _index.md
* Update _index.md
updating a few sections like roadmap, services, troubleshooting/filing tickets
* Update _index.md
* Update _index.md
* Update _index.md
* Fixed a few whitespace issues
* Update _index.md
* Update _index.md
* Update _index.md
* add section on upgrading CoreDNS (#12909)
* documentation for kubelet resource metrics endpoint (#12934)
* windows docs updates for 1.14 (#13279)
* Delete sample-l2bridge-wincni-config.json
this file is not used anywhere
* Update _index.md
* Update _index.md
* Update _index.md
* Update _index.md
* Update _index.md
* Rename content/en/docs/getting-started-guides/windows/_index.md to content/en/docs/setup/windows/_index.md
moving to new location
* Delete flannel-master-kubectl-get-ds.png
* Delete flannel-master-kubeclt-get-pods.png
* Delete windows-docker-error.png
* Add files via upload
* Rename _index.md to add-windows-nodes.md
* Create _index.md
* Update _index.md
* Update add-windows-nodes.md
* Update add-windows-nodes.md
* Create user-guide-windows-nodes.md
* Create user-guide-windows-containers.md
* Update and rename add-windows-nodes.md to intro-windows-nodes.md
* Update user-guide-windows-containers.md
* Rename intro-windows-nodes.md to intro-windows-in-kubernetes.md
* Update user-guide-windows-nodes.md
* Update user-guide-windows-containers.md
* Update user-guide-windows-containers.md
* Update user-guide-windows-nodes.md
* Update user-guide-windows-containers.md
* Update _index.md
* Update intro-windows-in-kubernetes.md
* Update intro-windows-in-kubernetes.md
fixing the pause image
* Update intro-windows-in-kubernetes.md
changing tables from html to MD
* Update user-guide-windows-nodes.md
converting tables from HTML to MD
* Update intro-windows-in-kubernetes.md
* Update user-guide-windows-nodes.md
* Update user-guide-windows-nodes.md
* Update user-guide-windows-nodes.md
updating the numbering , even though it messes up the notes a little bit. Jim will file a ticket to follow up
* Update user-guide-windows-nodes.md
* update to windows docs for 1.14 (#13322)
* Update intro-windows-in-kubernetes.md
* Update intro-windows-in-kubernetes.md
* Update intro-windows-in-kubernetes.md
* Update intro-windows-in-kubernetes.md
* Update intro-windows-in-kubernetes.md
* Update user-guide-windows-containers.md
* Update user-guide-windows-nodes.md
* Update intro-windows-in-kubernetes.md (#13344)
* server side apply followup (#13321)
* change some parts of serverside apply docs in response to comments
* fix typos and wording
* Update config.toml (#13365)
2019-03-25 22:06:16 +00:00
kubectl apply -f https://k8s.io/examples/application/cassandra/cassandra-statefulset.yaml
2018-06-22 00:00:30 +00:00
```
2017-06-23 19:23:36 +00:00
2017-07-27 21:11:39 +00:00
## Validating The Cassandra StatefulSet
2017-06-23 19:23:36 +00:00
2018-08-20 20:47:30 +00:00
1. Get the Cassandra StatefulSet:
2017-06-23 19:23:36 +00:00
2018-07-25 22:41:34 +00:00
```shell
2018-06-22 00:00:30 +00:00
kubectl get statefulset cassandra
```
2017-06-23 19:23:36 +00:00
2018-06-22 00:00:30 +00:00
The response should be:
2017-06-23 19:23:36 +00:00
2018-06-22 00:00:30 +00:00
```
NAME DESIRED CURRENT AGE
cassandra 3 0 13s
```
2017-06-23 19:23:36 +00:00
2018-08-20 20:47:30 +00:00
The `StatefulSet` resource deploys Pods sequentially.
2017-06-23 19:23:36 +00:00
2018-08-20 20:47:30 +00:00
1. Get the Pods to see the ordered creation status:
2017-07-27 21:11:39 +00:00
2018-07-25 22:41:34 +00:00
```shell
2018-06-22 00:00:30 +00:00
kubectl get pods -l="app=cassandra"
```
2017-08-19 00:10:40 +00:00
2018-06-22 00:00:30 +00:00
The response should be:
2017-08-19 00:10:40 +00:00
2018-07-25 22:41:34 +00:00
```shell
2018-06-22 00:00:30 +00:00
NAME READY STATUS RESTARTS AGE
cassandra-0 1/1 Running 0 1m
cassandra-1 0/1 ContainerCreating 0 8s
```
2018-08-20 20:47:30 +00:00
It can take several minutes for all three Pods to deploy. Once they are deployed, the same command returns:
2018-06-22 00:00:30 +00:00
```
NAME READY STATUS RESTARTS AGE
cassandra-0 1/1 Running 0 10m
cassandra-1 1/1 Running 0 9m
cassandra-2 1/1 Running 0 8m
```
3. Run the Cassandra [nodetool ](https://wiki.apache.org/cassandra/NodeTool ) to display the status of the ring.
2018-07-25 22:41:34 +00:00
```shell
2018-06-22 00:00:30 +00:00
kubectl exec -it cassandra-0 -- nodetool status
```
The response should look something like this:
```
Datacenter: DC1-K8Demo
======================
Status=Up/Down
|/ State=Normal/Leaving/Joining/Moving
-- Address Load Tokens Owns (effective) Host ID Rack
UN 172.17.0.5 83.57 KiB 32 74.0% e2dd09e6-d9d3-477e-96c5-45094c08db0f Rack1-K8Demo
UN 172.17.0.4 101.04 KiB 32 58.8% f89d6835-3a42-4419-92b3-0e62cae1479c Rack1-K8Demo
UN 172.17.0.6 84.74 KiB 32 67.1% a6a1e8c2-3dc5-4417-b1a0-26507af2aaad Rack1-K8Demo
```
2017-06-23 19:23:36 +00:00
2017-07-27 21:11:39 +00:00
## Modifying the Cassandra StatefulSet
2018-06-22 00:00:30 +00:00
2018-08-20 20:47:30 +00:00
Use `kubectl edit` to modify the size of a Cassandra StatefulSet.
2017-06-23 19:23:36 +00:00
2017-07-27 21:11:39 +00:00
1. Run the following command:
2017-06-23 19:23:36 +00:00
2018-07-25 22:41:34 +00:00
```shell
2018-06-22 00:00:30 +00:00
kubectl edit statefulset cassandra
```
2017-08-19 00:10:40 +00:00
2018-07-27 23:03:27 +00:00
This command opens an editor in your terminal. The line you need to change is the `replicas` field. The following sample is an excerpt of the `StatefulSet` file:
2018-06-25 17:54:12 +00:00
```yaml
# Please edit the object below. Lines beginning with a '#' will be ignored,
# and an empty file will abort the edit. If an error occurs while saving this file will be
# reopened with the relevant failures.
#
apiVersion: apps/v1 # for versions before 1.9.0 use apps/v1beta2
kind: StatefulSet
metadata:
creationTimestamp: 2016-08-13T18:40:58Z
generation: 1
labels:
app: cassandra
name: cassandra
namespace: default
resourceVersion: "323"
selfLink: /apis/apps/v1/namespaces/default/statefulsets/cassandra
uid: 7a219483-6185-11e6-a910-42010a8a0fc0
spec:
replicas: 3
```
2017-08-19 00:10:40 +00:00
2018-08-20 20:47:30 +00:00
1. Change the number of replicas to 4, and then save the manifest.
2017-08-19 00:10:40 +00:00
2018-08-20 20:47:30 +00:00
The `StatefulSet` now contains 4 Pods.
2017-06-23 19:23:36 +00:00
2018-08-20 20:47:30 +00:00
1. Get the Cassandra StatefulSet to verify:
2017-06-23 19:23:36 +00:00
2018-07-25 22:41:34 +00:00
```shell
2018-06-22 00:00:30 +00:00
kubectl get statefulset cassandra
```
2017-06-23 19:23:36 +00:00
2018-06-22 00:00:30 +00:00
The response should be
2017-06-23 19:23:36 +00:00
2018-06-22 00:00:30 +00:00
```
NAME DESIRED CURRENT AGE
cassandra 4 4 36m
```
2017-08-19 00:10:40 +00:00
2018-05-05 16:00:51 +00:00
{{% /capture %}}
2017-06-23 19:23:36 +00:00
2018-05-05 16:00:51 +00:00
{{% capture cleanup %}}
2018-08-20 20:47:30 +00:00
Deleting or scaling a StatefulSet down does not delete the volumes associated with the StatefulSet. This setting is for your safety because your data is more valuable than automatically purging all related StatefulSet resources.
2017-06-23 19:23:36 +00:00
2018-05-05 16:00:51 +00:00
{{< warning > }}
2018-11-06 19:33:04 +00:00
Depending on the storage class and reclaim policy, deleting the *PersistentVolumeClaims* may cause the associated volumes to also be deleted. Never assume you’ ll be able to access data if its volume claims are deleted.
2018-05-05 16:00:51 +00:00
{{< / warning > }}
2017-06-23 19:23:36 +00:00
2018-07-27 23:03:27 +00:00
1. Run the following commands (chained together into a single command) to delete everything in the Cassandra `StatefulSet` :
2017-06-23 19:23:36 +00:00
2018-07-25 22:41:34 +00:00
```shell
2018-06-22 00:00:30 +00:00
grace=$(kubectl get po cassandra-0 -o=jsonpath='{.spec.terminationGracePeriodSeconds}') \
& & kubectl delete statefulset -l app=cassandra \
& & echo "Sleeping $grace" \
& & sleep $grace \
& & kubectl delete pvc -l app=cassandra
```
2017-06-23 19:23:36 +00:00
2018-08-20 20:47:30 +00:00
1. Run the following command to delete the Cassandra Service.
2017-06-23 19:23:36 +00:00
2018-07-25 22:41:34 +00:00
```shell
2018-06-22 00:00:30 +00:00
kubectl delete service -l app=cassandra
```
2017-06-23 19:23:36 +00:00
2018-05-05 16:00:51 +00:00
{{% /capture %}}
2017-06-23 19:23:36 +00:00
2018-05-05 16:00:51 +00:00
{{% capture whatsnext %}}
2018-07-02 20:37:19 +00:00
2018-08-20 20:47:30 +00:00
* Learn how to [Scale a StatefulSet ](/docs/tasks/run-application/scale-stateful-set/ ).
* Learn more about the [*KubernetesSeedProvider* ](https://github.com/kubernetes/examples/blob/master/cassandra/java/src/main/java/io/k8s/cassandra/KubernetesSeedProvider.java )
2017-07-27 21:11:39 +00:00
* See more custom [Seed Provider Configurations ](https://git.k8s.io/examples/cassandra/java/README.md )
2017-06-23 19:23:36 +00:00
2018-05-05 16:00:51 +00:00
{{% /capture %}}