tutorials/guestbook, tutorials/cassandra: import latest (#4775)
* tutorials/guestbook: fix broken links Importing from kubernetes/examples repository. Signed-off-by: Ahmet Alp Balkan <ahmetb@google.com> * Import newer versions for guestbook and cassandra Signed-off-by: Ahmet Alp Balkan <ahmetb@google.com>
This commit is contained in:
		
							parent
							
								
									beff4d8499
								
							
						
					
					
						commit
						acff65891f
					
				|  | @ -46,7 +46,7 @@ Deploying stateful distributed applications, like Cassandra, within a clustered | ||||||
| 
 | 
 | ||||||
| **Cassandra Docker** | **Cassandra Docker** | ||||||
| 
 | 
 | ||||||
| The pods use the [```gcr.io/google-samples/cassandra:v12```](https://github.com/kubernetes/examples/blob/master/cassandra/image/Dockerfile) | The Pods use the [`gcr.io/google-samples/cassandra:v12`](https://github.com/kubernetes/examples/blob/master/cassandra/image/Dockerfile) | ||||||
| image from Google's [container registry](https://cloud.google.com/container-registry/docs/). | image from Google's [container registry](https://cloud.google.com/container-registry/docs/). | ||||||
| The docker is based on `debian:jessie` and includes OpenJDK 8. 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`. | The docker is based on `debian:jessie` and includes OpenJDK 8. 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`. | ||||||
| 
 | 
 | ||||||
|  | @ -75,31 +75,30 @@ To complete this tutorial, you should already have a basic familiarity with [Pod | ||||||
| 
 | 
 | ||||||
| * Have a supported Kubernetes Cluster running | * Have a supported Kubernetes Cluster running | ||||||
| 
 | 
 | ||||||
| **Note:** Please read the [getting started guides](https://kubernetes.io/docs/setup/pick-right-solution/) if you do not already have a cluster.  | **Note:** Please read the [getting started guides](https://kubernetes.io/docs/setup/pick-right-solution/) if you do not already have a cluster. | ||||||
|  | {: .note} | ||||||
| 
 | 
 | ||||||
| ### Additional Minikube Setup Instructions | ### Additional Minikube Setup Instructions | ||||||
| 
 | 
 | ||||||
| **Warning:** [Minikube](https://kubernetes.io/docs/getting-started-guides/minikube/) defaults to 1024MB of memory and 1 CPU which results in an insufficient resource errors.  | **Caution:** [Minikube](https://kubernetes.io/docs/getting-started-guides/minikube/) defaults to 1024MB of memory and 1 CPU which results in an insufficient resource errors during this tutorial.  | ||||||
|  | {: .caution} | ||||||
| 
 | 
 | ||||||
| To avoid these errors, run minikube with: | To avoid these errors, run minikube with: | ||||||
| 
 | 
 | ||||||
| ``` |     minikube start --memory 5120 --cpus=4 | ||||||
| minikube start --memory 5120 --cpus=4 |   | ||||||
| ```  |  | ||||||
| {% endcapture %} | {% endcapture %} | ||||||
| 
 | 
 | ||||||
| {% capture lessoncontent %} | {% capture lessoncontent %} | ||||||
| ## Creating a Cassandra Headless Service | ## Creating a Cassandra Headless Service | ||||||
| A Kubernetes [Service](https://kubernetes.io/docs/concepts/services-networking/service/) describes a set of [Pods](https://kubernetes.io/docs/concepts/workloads/pods/pod/) that perform the same task.  | A Kubernetes [Service](https://kubernetes.io/docs/concepts/services-networking/service/) describes a set of [Pods](https://kubernetes.io/docs/concepts/workloads/pods/pod/) that perform the same task.  | ||||||
| 
 | 
 | ||||||
| The following `Service` is used for DNS lookups between Cassandra pods and clients within the Kubernetes Cluster. | The following `Service` is used for DNS lookups between Cassandra Pods and clients within the Kubernetes Cluster. | ||||||
| 
 | 
 | ||||||
| 1. `cd` to the folder you saved the .yaml files. | 1. Launch a terminal window in the directory you downloaded the manifest files. | ||||||
| 2. Create a `Service` to track all Cassandra StatefulSet Nodes from the following `.yaml` file: | 2. Create a `Service` to track all Cassandra StatefulSet Nodes from the `cassandra-service.yaml` file: | ||||||
| 
 | 
 | ||||||
| ```shell |        kubectl create -f cassandra-service.yaml | ||||||
| kubectl create -f cassandra-service.yaml |  | ||||||
| ``` |  | ||||||
| 
 | 
 | ||||||
| {% include code.html language="yaml" file="cassandra-service.yaml" ghlink="/docs/tutorials/stateful-application/cassandra-service.yaml" %} | {% include code.html language="yaml" file="cassandra-service.yaml" ghlink="/docs/tutorials/stateful-application/cassandra-service.yaml" %} | ||||||
| 
 | 
 | ||||||
|  | @ -107,31 +106,26 @@ kubectl create -f cassandra-service.yaml | ||||||
| 
 | 
 | ||||||
| Get the Cassandra `Service`. | Get the Cassandra `Service`. | ||||||
| 
 | 
 | ||||||
| ```shell |     kubectl get svc cassandra | ||||||
| kubectl get svc cassandra |  | ||||||
| ``` |  | ||||||
| 
 | 
 | ||||||
| The response should be | The response should be | ||||||
| 
 | 
 | ||||||
| ```console |     NAME        CLUSTER-IP   EXTERNAL-IP   PORT(S)    AGE | ||||||
| NAME        CLUSTER-IP   EXTERNAL-IP   PORT(S)    AGE |     cassandra   None         <none>        9042/TCP   45s | ||||||
| cassandra   None         <none>        9042/TCP   45s |  | ||||||
| ``` |  | ||||||
| 
 | 
 | ||||||
| If anything else returns, the service was not successfully created. Read [Debug Services](https://kubernetes.io/docs/tasks/debug-application-cluster/debug-service/) for common issues. | If anything else returns, the service was not successfully created. Read [Debug Services](https://kubernetes.io/docs/tasks/debug-application-cluster/debug-service/) for common issues. | ||||||
| 
 | 
 | ||||||
| ## Using a StatefulSet to Create a Cassandra Ring | ## Using a StatefulSet to Create a Cassandra Ring | ||||||
| 
 | 
 | ||||||
| The StatefulSet manifest, included below, creates a Cassandra ring that consists of three pods. | The StatefulSet manifest, included below, creates a Cassandra ring that consists of three Pods. | ||||||
| 
 | 
 | ||||||
| **Note:** This example uses the default provisioner for Minikube. Please update the following StatefulSet for the cloud you are working with.  | **Note:** This example uses the default provisioner for Minikube. Please update the following StatefulSet for the cloud you are working with. | ||||||
|  | {: .note} | ||||||
| 
 | 
 | ||||||
| 1. Update the StatefulSet if necessary. | 1. Update the StatefulSet if necessary. | ||||||
| 2. Create the Cassandra StatefulSet from the following `.yaml` file: | 2. Create the Cassandra StatefulSet from the `cassandra-statefulset.yaml` file: | ||||||
| 
 | 
 | ||||||
| ```shell |        kubectl create -f cassandra-statefulset.yaml | ||||||
| kubectl create -f cassandra-statefulset.yaml |  | ||||||
| ``` |  | ||||||
| 
 | 
 | ||||||
| {% include code.html language="yaml" file="cassandra-statefulset.yaml" ghlink="/docs/tutorials/stateful-application/cassandra-statefulset.yaml" %} | {% include code.html language="yaml" file="cassandra-statefulset.yaml" ghlink="/docs/tutorials/stateful-application/cassandra-statefulset.yaml" %} | ||||||
| 
 | 
 | ||||||
|  | @ -139,131 +133,115 @@ kubectl create -f cassandra-statefulset.yaml | ||||||
| 
 | 
 | ||||||
| 1. Get the Cassandra StatefulSet: | 1. Get the Cassandra StatefulSet: | ||||||
| 
 | 
 | ||||||
| ```shell |        kubectl get statefulset cassandra | ||||||
| kubectl get statefulset cassandra |  | ||||||
| ``` |  | ||||||
| 
 | 
 | ||||||
|    The response should be |    The response should be | ||||||
| 
 | 
 | ||||||
| ```console |        NAME        DESIRED   CURRENT   AGE | ||||||
| NAME        DESIRED   CURRENT   AGE |        cassandra   3         0         13s | ||||||
| cassandra   3         0         13s |  | ||||||
| ``` |  | ||||||
| 
 | 
 | ||||||
|    The StatefulSet resource deploys pods sequentially.   |    The StatefulSet resource deploys Pods sequentially.   | ||||||
| 
 | 
 | ||||||
| {:start="2"} |  | ||||||
| 2. Get the Pods to see the ordered creation status: | 2. Get the Pods to see the ordered creation status: | ||||||
| 
 | 
 | ||||||
| ```shell |        kubectl get pods -l="app=cassandra" | ||||||
| kubectl get pods -l="app=cassandra" |         | ||||||
| NAME          READY     STATUS              RESTARTS   AGE |    The response should be     | ||||||
| cassandra-0   1/1       Running             0          1m |         | ||||||
| cassandra-1   0/1       ContainerCreating   0          8s |        NAME          READY     STATUS              RESTARTS   AGE | ||||||
| ``` |        cassandra-0   1/1       Running             0          1m | ||||||
|  |        cassandra-1   0/1       ContainerCreating   0          8s | ||||||
| 
 | 
 | ||||||
| **Note:** It can take up to ten minutes for all three pods to deploy.  |    **Note:** It can take up to ten minutes for all three Pods to deploy.  | ||||||
|  |    {: .note} | ||||||
| 
 | 
 | ||||||
| Once all pods are deployed, the same command returns: |     Once all Pods are deployed, the same command returns: | ||||||
| 
 | 
 | ||||||
| ```shell |        NAME          READY     STATUS    RESTARTS   AGE | ||||||
| kubectl get pods -l="app=cassandra" |        cassandra-0   1/1       Running   0          10m | ||||||
| NAME          READY     STATUS    RESTARTS   AGE |        cassandra-1   1/1       Running   0          9m | ||||||
| cassandra-0   1/1       Running   0          10m |        cassandra-2   1/1       Running   0          8m | ||||||
| cassandra-1   1/1       Running   0          9m |  | ||||||
| cassandra-2   1/1       Running   0          8m |  | ||||||
| ``` |  | ||||||
| 
 | 
 | ||||||
| {:start="3"} |  | ||||||
| 3. Run the Cassandra utility nodetool to display the status of the ring. | 3. Run the Cassandra utility nodetool to display the status of the ring. | ||||||
| 
 | 
 | ||||||
| ``` |        kubectl exec cassandra-0 -- nodetool status | ||||||
| kubectl exec cassandra-0 -- nodetool status |  | ||||||
| ``` |  | ||||||
| 
 | 
 | ||||||
| ```console |    The response is: | ||||||
| Datacenter: DC1-K8Demo | 
 | ||||||
| ====================== |        Datacenter: DC1-K8Demo | ||||||
| Status=Up/Down |        ====================== | ||||||
| |/ State=Normal/Leaving/Joining/Moving |        Status=Up/Down | ||||||
| --  Address   Load       Tokens       Owns (effective)  Host ID                               Rack |        |/ State=Normal/Leaving/Joining/Moving | ||||||
| UN  10.4.2.4  65.26 KiB  32           63.7%             a9d27f81-6783-461d-8583-87de2589133e  Rack1-K8Demo |        --  Address     Load       Tokens       Owns (effective)  Host ID                               Rack | ||||||
| UN  10.4.0.4  102.04 KiB  32           66.7%             5559a58c-8b03-47ad-bc32-c621708dc2e4  Rack1-K8Demo |        UN  172.17.0.5  83.57 KiB  32           74.0%             e2dd09e6-d9d3-477e-96c5-45094c08db0f  Rack1-K8Demo | ||||||
| UN  10.4.1.4  83.06 KiB  32           69.6%             9dce943c-581d-4c0e-9543-f519969cc805  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 | ||||||
| 
 | 
 | ||||||
| ## Modifying the Cassandra StatefulSet | ## Modifying the Cassandra StatefulSet | ||||||
| Use `kubectl edit` to modify the size of of a Cassandra StatefulSet.  | Use `kubectl edit` to modify the size of of a Cassandra StatefulSet.  | ||||||
| 
 | 
 | ||||||
| 1. Run the following command: | 1. Run the following command: | ||||||
| 
 | 
 | ||||||
| ```shell |        kubectl edit statefulset cassandra | ||||||
| kubectl edit statefulset cassandra | 
 | ||||||
| ``` |    This command opens an editor in your terminal. The line you need to change is the `replicas` field. | ||||||
|    This command opens an editor in your terminal. The line you need to change is `Replicas`. |  | ||||||
|     |     | ||||||
|    **Note:** The following sample is an excerpt of the StatefulSet file. |    **Note:** The following sample is an excerpt of the StatefulSet file. | ||||||
|  |    {: .note} | ||||||
| 
 | 
 | ||||||
| ```console |     ```yaml    | ||||||
| # Please edit the object below. Lines beginning with a '#' will be ignored, |     # 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 |     # and an empty file will abort the edit. If an error occurs while saving this file will be | ||||||
| # reopened with the relevant failures. |     # reopened with the relevant failures. | ||||||
| # |     # | ||||||
| apiVersion: apps/v1beta1 |     apiVersion: apps/v1beta1 | ||||||
| kind: StatefulSet |     kind: StatefulSet | ||||||
| metadata: |     metadata: | ||||||
|   creationTimestamp: 2016-08-13T18:40:58Z |      creationTimestamp: 2016-08-13T18:40:58Z | ||||||
|   generation: 1 |      generation: 1 | ||||||
|   labels: |      labels: | ||||||
|     app: cassandra |        app: cassandra | ||||||
|   name: cassandra |      name: cassandra | ||||||
|   namespace: default |      namespace: default | ||||||
|   resourceVersion: "323" |      resourceVersion: "323" | ||||||
|   selfLink: /apis/apps/v1beta1/namespaces/default/statefulsets/cassandra |      selfLink: /apis/apps/v1beta1/namespaces/default/statefulsets/cassandra | ||||||
|   uid: 7a219483-6185-11e6-a910-42010a8a0fc0 |      uid: 7a219483-6185-11e6-a910-42010a8a0fc0 | ||||||
| spec: |     spec: | ||||||
|   replicas: 3 |      replicas: 3 | ||||||
| ``` |     ```  | ||||||
| 
 | 
 | ||||||
| {:start="2"} | 2. Change the number of replicas to 4, and then save the manifest.  | ||||||
| 2. Increase the number of replicas to 4, and then save the manifest.  |  | ||||||
| 
 | 
 | ||||||
|    The StatefulSet now contains 4 pods. |    The StatefulSet now contains 4 Pods. | ||||||
| 
 | 
 | ||||||
| 3. Get the Cassandra StatefulSet to verify: | 3. Get the Cassandra StatefulSet to verify: | ||||||
| 
 | 
 | ||||||
| ```shell |        kubectl get statefulset cassandra | ||||||
| kubectl get statefulset cassandra |  | ||||||
| ``` |  | ||||||
| 
 | 
 | ||||||
|   The response should be |    The response should be | ||||||
| 
 | 
 | ||||||
| ```console |        NAME        DESIRED   CURRENT   AGE | ||||||
| NAME        DESIRED   CURRENT   AGE |        cassandra   4         4         36m | ||||||
| cassandra   4         4         36m |        | ||||||
| ``` |  | ||||||
| {% endcapture %} | {% endcapture %} | ||||||
| 
 | 
 | ||||||
| {% capture cleanup %} | {% capture cleanup %} | ||||||
| Deleting or scaling a StatefulSet down does not delete the volumes associated with the StatefulSet. This ensures safety first: your data is more valuable than an auto purge of all related StatefulSet resources.  | Deleting or scaling a StatefulSet down does not delete the volumes associated with the StatefulSet. This ensures safety first: your data is more valuable than an auto purge of all related StatefulSet resources.  | ||||||
| 
 | 
 | ||||||
| **Warning:** Depending on the storage class and reclaim policy, deleting the Persistent Volume Claims may cause the associated volumes to also be deleted. Never assume you’ll be able to access data if its volume claims are deleted.  | **Warning:** Depending on the storage class and reclaim policy, deleting the Persistent Volume Claims may cause the associated volumes to also be deleted. Never assume you’ll be able to access data if its volume claims are deleted. | ||||||
|  | {: .warning} | ||||||
| 
 | 
 | ||||||
| 1. Run the following commands to delete everything in a `StatefulSet`: | 1. Run the following commands to delete everything in a `StatefulSet`: | ||||||
| 
 | 
 | ||||||
| ```shell |        grace=$(kubectl get po cassandra-0 -o=jsonpath='{.spec.terminationGracePeriodSeconds}') \ | ||||||
| grace=$(kubectl get po cassandra-0 -o=jsonpath='{.spec.terminationGracePeriodSeconds}') \ |          && kubectl delete statefulset -l app=cassandra \ | ||||||
|   && kubectl delete statefulset -l app=cassandra \ |          && echo "Sleeping $grace" \ | ||||||
|   && echo "Sleeping $grace" \ |          && sleep $grace \ | ||||||
|   && sleep $grace \ |          && kubectl delete pvc -l app=cassandra | ||||||
|   && kubectl delete pvc -l app=cassandra |  | ||||||
| ``` |  | ||||||
| 
 | 
 | ||||||
| 2. Run the following command to delete the Cassandra `Service`. | 2. Run the following command to delete the Cassandra `Service`. | ||||||
| 
 | 
 | ||||||
| ```shell |        kubectl delete service -l app=cassandra | ||||||
| kubectl delete service -l app=cassandra |  | ||||||
| ``` |  | ||||||
| 
 | 
 | ||||||
| {% endcapture %} | {% endcapture %} | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -61,12 +61,12 @@ This tutorial shows you how to build and deploy a simple, multi-tier web applica | ||||||
| {% include task-tutorial-prereqs.md %} | {% include task-tutorial-prereqs.md %} | ||||||
| Download the following configuration files: | Download the following configuration files: | ||||||
| 
 | 
 | ||||||
| 1. [redis-master-deployment.yaml](/docs/tutorials/stateless-application/guestbook/redis-master-deployment.yaml) | 1. [redis-master-deployment.yaml](https://kubernetes.io/docs/tutorials/stateless-application/guestbook/redis-master-deployment.yaml) | ||||||
| 1. [redis-master-service.yaml](/docs/tutorials/stateless-application/guestbook/redis-master-service.yaml) | 1. [redis-master-service.yaml](https://kubernetes.io/docs/tutorials/stateless-application/guestbook/redis-master-service.yaml) | ||||||
| 1. [redis-slave-deployment.yaml](/docs/tutorials/stateless-application/guestbook/redis-slave-deployment.yaml) | 1. [redis-slave-deployment.yaml](https://kubernetes.io/docs/tutorials/stateless-application/guestbook/redis-slave-deployment.yaml) | ||||||
| 1. [redis-slave-service.yaml](/docs/tutorials/stateless-application/guestbook/redis-slave-service.yaml) | 1. [redis-slave-service.yaml](https://kubernetes.io/docs/tutorials/stateless-application/guestbook/redis-slave-service.yaml) | ||||||
| 1. [frontend-deployment.yaml](/docs/tutorials/stateless-application/guestbook/frontend-deployment.yaml) | 1. [frontend-deployment.yaml](https://kubernetes.io/docs/tutorials/stateless-application/guestbook/frontend-deployment.yaml) | ||||||
| 1. [frontend-service.yaml](/docs/tutorials/stateless-application/guestbook/frontend-service.yaml) | 1. [frontend-service.yaml](https://kubernetes.io/docs/tutorials/stateless-application/guestbook/frontend-service.yaml) | ||||||
| 
 | 
 | ||||||
| {% endcapture %} | {% endcapture %} | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue