From 11607eccdd5944f61f3b45e3512c905fd8e8891b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bal=C3=A1zs=20Czoma?= Date: Thu, 21 Dec 2017 22:30:06 -0500 Subject: [PATCH] Updates for delivery - GKE (#15) * editorial updates * formatting * updated links --- README.md | 113 ++++++++++++++++++++++++------------------------------ 1 file changed, 50 insertions(+), 63 deletions(-) diff --git a/README.md b/README.md index c220d57..93cc5d2 100644 --- a/README.md +++ b/README.md @@ -2,14 +2,14 @@ ## Purpose of this repository -This repository expands on [Solace Kubernetes Quickstart](https://github.com/SolaceProducts/solace-kubernetes-quickstart) to provide a concrete example of how to deploy redundent Solace VMRs in HA configuration on Google Kubernetes Engine on a 3 node GKE cluster across 3 zones. If you are looking for a simple way to install a single Solace message router into GCP, please see [Solace GCP Quickstart](https://github.com/SolaceLabs/solace-gcp-quickstart). +This repository expands on [Solace Kubernetes Quickstart](https://github.com/SolaceProducts/solace-kubernetes-quickstart) to provide a concrete example of how to deploy redundant Solace VMRs in HA configuration on Google Kubernetes Engine on a 3 node GKE cluster across 3 zones. If you are looking for a simple way to install a single Solace message router into GCP, please see [Solace GCP Quickstart](https://github.com/SolaceLabs/solace-gcp-quickstart). ![alt text](/images/network_diagram.png "Network Diagram") -- Purple - Data – Client data including active node mgmt. -- Blue - DNS – HA node discovery. -- Black - Disk – Persistent disk mount. -- Orange - Mgmt – Direct CLI/SEMP. +- Purple - Data – Client data including active node mgmt. +- Blue - DNS – HA node discovery. +- Black - Disk – Persistent disk mount. +- Orange/Yellow - Mgmt – Direct CLI/SEMP. ## Description of Solace VMR @@ -21,30 +21,33 @@ This is a 5 step process: [//]:# (Section 1 prereq is direct copy from here: https://cloud.google.com/container-registry/docs/quickstart) -1. Create a project in Google Cloud Platform and enable prerequisites: +**Step 1**: Create a project in Google Cloud Platform and enable prerequisites: + * In the Cloud Platform Console, go to the Manage resources page and select or create a new project. - [GO TO THE MANAGE RESOURCES PAGE](https://console.cloud.google.com/projectselector/iam-admin/projects) + [GO TO THE MANAGE RESOURCES PAGE](https://console.cloud.google.com/projectselector/iam-admin/projects) * Enable billing for your project. Follow the guide from the below link. - [ENABLE BILLING](https://support.google.com/cloud/answer/6293499#enable-billing) + [ENABLE BILLING](https://support.google.com/cloud/answer/6293499#enable-billing) * Enable the Container Registry API. Follow the below link and select the project you created from above. - [ENABLE THE API](https://console.cloud.google.com/flows/enableapi?apiid=containerregistry.googleapis.com) + [ENABLE THE API](https://console.cloud.google.com/flows/enableapi?apiid=containerregistry.googleapis.com)

-2. Use the button below to go to the Solace Developer portal and request a Solace Evaluation edition VMR. This process will return an email with a Download link. Do a right click "Copy Hyperlink" on the "Download the VMR Evaluation Edition for Docker" hyperlink. This link is of the form "http://em.solace.com/" and will be needed in the following section. +**Step 2**: Use the button below to go to the Solace Developer portal and request a Solace Evaluation edition VMR. This process will return an email with a Download link. In the email do a right click "Copy Hyperlink" on the "Download the VMR Evaluation Edition for Docker" hyperlink. This link is of the form "http://em.solace.com/" and will be needed in the following section. + +Note: The Evaluation edition VMR is required to support HA deployment. -3. Place Solace VMR in Google Container Registry: +**Step 3**: Place Solace VMR in Google Container Registry: * Open a Google Cloud Shell from the Cloud Platform Console used to create the project, like this: @@ -53,68 +56,70 @@ This is a 5 step process:

-* In the Cloud Shell paste the following, (replace http://em.solace.com/ with the link recieved in email from step 2.) +* In the Cloud Shell paste the following, (replace http://em.solace.com/ with the link received in email from step 2.) ```sh -wget https://raw.githubusercontent.com/SolaceProducts/solace-gke-quickstart/SOL-1245/scripts/copy_vmr_to_gkr.sh +wget https://raw.githubusercontent.com/SolaceProducts/solace-gke-quickstart/master/scripts/copy_vmr_to_gkr.sh chmod 755 copy_vmr_to_gkr.sh ./copy_vmr_to_gkr.sh -u http://em.solace.com/ ``` -

-* The script will end with a link required for next step. You can view the new entry on the google container registry in the Cloud Platform Console. +* The script will end with a link required for Step 5. You can view the new entry on the google container registry in the Cloud Platform Console: ![alt text](/images/google_container_registry.png "Google Container Registry")

-4. Use Google Cloud Shell to create GKE cluster of one node. +**Step 4**: Use Google Cloud Shell to create GKE cluster of three nodes. -* Download and execute the cluster create script in the Google Cloud Shell. All argument defaults would be ok if you want a single VMR, or HA Cluster in a single GCP zone. If you want the VMR cluster spead across 3 zones within a region,(Recommended for production), the speficy the 3 zones as per the example below: +* Download and execute the cluster create script in the Google Cloud Shell. All argument defaults would be ok if you want a single non-HA VMR. Specify `-n = 3` as number of nodes per zone and a single `-z ` for an HA Cluster in a single GCP zone. If you want the VMR cluster spread across 3 zones within a region (recommended for production), then specify the 3 zones as per the example below but leave the number of nodes per zone at default 1: ```sh -wget https://raw.githubusercontent.com/SolaceProducts/solace-gke-quickstart/SOL-1245/scripts/create_cluster.sh +wget https://raw.githubusercontent.com/SolaceProducts/solace-gke-quickstart/master/scripts/create_cluster.sh chmod 755 create_cluster.sh ./create_cluster.sh -z us-central1-b,us-central1-c,us-central1-f ``` This will create a GKE cluster of 3 nodes spread across 3 zones: -![alt text](/images/Nodes_across_zones.png "Google Contain Engine nodes") +![alt text](/images/Nodes_across_zones.png "Google Container Engine nodes") + +Here are some more GKE `create_cluster.sh` arguments: +* The default cluster name is "solace-vmr-cluster", which can be changed by specifying the `-c ` command line argument. +* The default machine type is "n1-standard-4". To use a different [Google machine type](https://cloud.google.com/compute/docs/machine-types ), specify `-m `. Note that the minimum CPU and memory requirements must be satisfied for the targeted VMR size, see the next step. + +
-You can sets that the Kubernetes deployment on GKE is healthy with the following command, which should retun a single line with svc/kubernetes: +You can check that the Kubernetes deployment on GKE is healthy with the following command, which should return a single line with svc/kubernetes: ```sh kubectl get services ``` -If this fails, you will need to [troubleshoot GKE](https://cloud.google.com/kubernetes-engine/docs/support). +If this fails, you will need to [troubleshoot GKE](https://cloud.google.com/kubernetes-engine/docs/support ). -Also note that during install of GKE and release Solace HA, several GCP resources such as GCE nodes, Disks, and Loadbalancers are created. After deleting kubernetes release you should validate all resources created are deleted. The [Solace Kubernetes Quickstart](https://github.com/SolaceProducts/solace-kubernetes-quickstart) describes how to delete a release. +Also note that during install of GKE and release Solace HA, several GCP resources such as GCE nodes, Disks, and Loadbalancers are created. After deleting a Kubernetes release you should validate that all resources created are deleted. The [Solace Kubernetes Quickstart](https://github.com/SolaceProducts/solace-kubernetes-quickstart(https://github.com/SolaceProducts/solace-kubernetes-quickstart/tree/master#deleting-a-deployment) ) describes how to delete a _release_. If it is necessary to delete the GKE _cluster_ refer to the [Google Cloud Platform documentation](https://cloud.google.com/sdk/gcloud/reference/container/clusters/delete ).

-5. Use Google Cloud Shell to deploy Pod and Service to that cluster. This will finish with a Solace VMR deployed to GKE. +**Step 5**: Use Google Cloud Shell to deploy Pod and Service to that cluster. This will finish with a Solace VMR HA configuration deployed to GKE. * Download and execute the cluster create and deployment script in the Google Cloud Shell. Replace `` with the desired password for the management `admin` user. Replace `` with the release tag of the image in the container registry. ```sh -wget https://raw.githubusercontent.com/SolaceProducts/solace-kubernetes-quickstart/SOL-1244/scripts/start_vmr.sh +wget https://raw.githubusercontent.com/SolaceProducts/solace-kubernetes-quickstart/master/scripts/start_vmr.sh chmod 755 start_vmr.sh -./start_vmr.sh -p -i gcr.io/${DEVSHELL_PROJECT_ID}/solos-vmr: +./start_vmr.sh -p -i gcr.io/${DEVSHELL_PROJECT_ID}/solos-vmr: -v values-examples/small-persist-ha-provisionPvc.yaml ``` -
-
- #### Using other VMR deployment configurations -In current configuration above script has created and started a small size non-HA VMR deployment with simple local non-persistent storage. +In current configuration above script has created and started a small-size HA VMR deployment with a provisioned PersistentVolume (PV) storage. -For other deployment configuration options refer to the [Solace Kubernetes Quickstart README](https://github.com/SolaceProducts/solace-kubernetes-quickstart/blob/master/README.md). +For other deployment configuration options refer to the [Solace Kubernetes Quickstart README](https://github.com/SolaceProducts/solace-kubernetes-quickstart/tree/master#using-other-vmr-deployment-configurations ). ### Validate the Deployment @@ -122,21 +127,21 @@ Now you can validate your deployment in the Google Cloud Shell: ```sh prompt:~$ kubectl get statefulsets,services,pods,pvc,pv -NAME DESIRED CURRENT AGE +NAME DESIRED CURRENT AGE statefulsets/XXX-XXX-solace 3 3 3m -NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE -svc/XXX-XXX-solace LoadBalancer 10.15.249.186 35.202.131.158 22:32656/TCP,8080:32394/TCP,55555:31766/TCP 3m +NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE +svc/XXX-XXX-solace LoadBalancer 10.15.249.186 104.154.54.154 22:32656/TCP,8080:32394/TCP,55555:31766/TCP 3m svc/XXX-XXX-solace-discovery ClusterIP None 8080/TCP 3m -svc/kubernetes ClusterIP 10.15.240.1 443/TCP 6d -NAME READY STATUS RESTARTS AGE +svc/kubernetes ClusterIP 10.15.240.1 443/TCP 6d +NAME READY STATUS RESTARTS AGE po/XXX-XXX-solace-0 1/1 Running 0 3m po/XXX-XXX-solace-1 0/1 Running 0 3m po/XXX-XXX-solace-2 0/1 Running 0 3m -NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE +NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE pvc/data-XXX-XXX-solace-0 Bound pvc-74d9ceb3-d492-11e7-b95e-42010a800173 30Gi RWO XXX-XXX-standard 3m pvc/data-XXX-XXX-solace-1 Bound pvc-74dce76f-d492-11e7-b95e-42010a800173 30Gi RWO XXX-XXX-standard 3m pvc/data-XXX-XXX-solace-2 Bound pvc-74e12b36-d492-11e7-b95e-42010a800173 30Gi RWO XXX-XXX-standard 3m -NAME CAPACITY ACCESS MODES RECLAIM POLICY STATUS CLAIM STORAGECLASS REASON AGE +NAME CAPACITY ACCESS MODES RECLAIM POLICY STATUS CLAIM STORAGECLASS REASON AGE pv/pvc-74d9ceb3-d492-11e7-b95e-42010a800173 30Gi RWO Delete Bound default/data-XXX-XXX-solace-0 XXX-XXX-standard 3m pv/pvc-74dce76f-d492-11e7-b95e-42010a800173 30Gi RWO Delete Bound default/data-XXX-XXX-solace-1 XXX-XXX-standard 3m pv/pvc-74e12b36-d492-11e7-b95e-42010a800173 30Gi RWO Delete Bound default/data-XXX-XXX-solace-2 XXX-XXX-standard 3m @@ -153,7 +158,7 @@ Annotations: Selector: app=solace,release=XXX-XXX Type: LoadBalancer IP: 10.15.249.186 -LoadBalancer Ingress: 35.202.131.158 +LoadBalancer Ingress: 104.154.54.154 Port: ssh 22/TCP TargetPort: 22/TCP NodePort: ssh 32656/TCP @@ -175,7 +180,7 @@ External Traffic Policy: Cluster
-Note here serveral IPs and port. In this example 104.154.54.154 is the external IP to use, This can also be seen from the google cloud console: +Note here several IPs and port. In this example 104.154.54.154 is the external Public IP to use. This can also be seen from the google cloud console: ![alt text](/images/google_container_loadbalancer.png "GKE Load Balancer") @@ -188,35 +193,17 @@ It is possible to watch the VMR come up via logs in the Google Cloud Platform lo

-## Gaining admin access to the VMR +## Gaining admin and ssh access to the VMR -For persons used to working with Solace message router console access, this is still available with standard ssh session from any internet at port 22 by default: +The external management IP will be the Public IP associated with your GCE instance. Access will go through the load balancer service as described in the introduction and will always point to the active VMR. The default port is 22 for CLI and 8080 for SEMP/SolAdmin. -```sh -$ssh -p 22 admin@104.154.54.154 -Solace - Virtual Message Router (VMR) -Password: +See the [Solace Kubernetes Quickstart README](https://github.com/SolaceProducts/solace-kubernetes-quickstart/tree/master#gaining-admin-access-to-the-vmr ) for more details including admin and ssh access to the individual VMRs. -System Software. SolOS-TR Version 8.6.0.1010 - -Virtual Message Router (Message Routing Node) - -Copyright 2004-2017 Solace Corporation. All rights reserved. - -This is the Community Edition of the Solace VMR. - -XXX-XXX-solace-0> -``` - -For persons who are unfamiliar with the Solace mesage router or would prefer an administration application the SolAdmin management application is available. For more information on SolAdmin see the [SolAdmin page](http://dev.solace.com/tech/soladmin/). To get SolAdmin, visit the Solace [download page](http://dev.solace.com/downloads/) and select OS version desired. Management IP will be the Public IP associated with youe GCE instance and port will be 8080 by default. - -![alt text](/images/gce_soladmin.png "soladmin connection to gce") - -
+## Testing Data access to the VMR -## Testing data access to the VMR +To test data traffic though the newly created VMR instance, visit the Solace developer portal and select your preferred programming language to [send and receive messages](http://dev.solace.com/get-started/send-receive-messages/ ). Under each language there is a Publish/Subscribe tutorial that will help you get started. -To test data traffic though the newly created VMR instance, visit the Solace developer portal and select your preferred programming langauge to [send and receive messages](http://dev.solace.com/get-started/send-receive-messages/). Under each language there is a Publish/Subscribe tutorial that will help you get started. +Note: the Host will be the Public IP. It may be necessary to [open up external access to a port](https://github.com/SolaceProducts/solace-kubernetes-quickstart/tree/master#upgradingmodifying-the-vmr-cluster) used by the particular messaging API if it is not already exposed. ![alt text](/images/solace_tutorial.png "getting started publish/subscribe")