From 45bcd44b937d463390b6f18b56358a8896515682 Mon Sep 17 00:00:00 2001 From: Lydia Date: Tue, 26 Oct 2021 20:00:55 -0700 Subject: [PATCH 1/5] revisions as a training exercise --- .../docs/reference/caching-and-clustering.md | 62 ++++++++----------- 1 file changed, 26 insertions(+), 36 deletions(-) diff --git a/vuepress/docs/v6.3.2/docs/reference/caching-and-clustering.md b/vuepress/docs/v6.3.2/docs/reference/caching-and-clustering.md index 81cdc6a52a..e070aa8fb1 100644 --- a/vuepress/docs/v6.3.2/docs/reference/caching-and-clustering.md +++ b/vuepress/docs/v6.3.2/docs/reference/caching-and-clustering.md @@ -1,52 +1,43 @@ # Caching and Clustering in an Entando Application - ## App Engine Clustering and High Availability -The Entando App Engine can be deployed as a clustered set of instances using the clustering and replication ability of Kubernetes. The App Engine is -backed by a shared cache with two chioices of implementation out of the box. +Entando App Engine can be deployed as a clustered set of instances using the clustering and replication ability of Kubernetes. Entando App Engine is backed by a shared cache with two default choices for implementation. -See this tutorial for configuring and testing a clustered instance of the App Engine. +This guide demonstrates how to configure and test a clustered instance of Entando App Engine. -The clustering of microservices built to add functionality to an Entando application is separate from the clustering used by the App Engine. The microservices -have a separate clustering configuration and setup depending on the implementation and choices made in creating those microservices. See the documentation -for your microservices caching implementation for details on configuring and deploying clustered microservices. +Microservices clustering that adds functionality to an Entando Application is different from clustering used by Entando App Engine. Microservices rely on a custom clustering configuration and setup based on implementation and selections made during their creation. Refer to documentation addressing clustered microservices and caching implementation for configuration and deployment details. ## Storage Requirements for Clustered Entando Apps -In order to scale an Entando Application across multiple nodes you must provide a storage class that supports -a `ReadWriteMany` access policy. There are many ways to accomplish this including using dedicated storage providers -like GlusterFS or others. The cloud Kubernetes providers also provide clustered storage options specific to their implementation like Google Cloud File in GKE or Azure Files in AKS. +To scale an Entando Application across multiple nodes a storage class that supports a `ReadWriteMany` access policy must be instantiated. There are a number of ways to accomplish this, inclusive of dedicated storage providers such as GlusterFS. Cloud Kubernetes providers also offer clustered storage options specific to their implementation, such as Google Cloud File in GKE or Azure Files in AKS. -You can use two different storage classes for your clustered vs non-clustered storage if your default class doesn't support `ReadWriteMany`. To do this add the following properties to your config map for the operator in the helm templates: +Two different storage classes can be used for clustered vs non-clustered storage if the default class doesn't support `ReadWriteMany`. To achieve this, add the following properties to the operator config map in the helm templates: -``` -entando.k8s.operator.default.clustered.storage.class: "[your clustered RWX storage class]" -entando.k8s.operator.default.non.clustered.storage.class: "[your RWO storage class]" +```jsp +entando.k8s.operator.default.clustered.storage.class: "[clustered RWX storage class]" +entando.k8s.operator.default.non.clustered.storage.class: "[RWO storage class]" ``` -Set the values of both to the appropriate storage class for your configuration. +Set both values to the storage class appropriate to the configuration. -::: tip -You can also scale an Entando Application without clustered storage using a `ReadWriteOnce (RWO)` policy by ensuring that the -instances are all scheduled to the same node. This can be accomplished using taints on other nodes. Be aware of the pros and cons of scheduling -instances to the same node. This will give you protection if the application instance itself dies or becomes unreachable and will help -you get the most utilization of node resources. However, if the node dies or is shutdown you will have to wait for Kubernetes to reschedule the pods to a different node and your application will be down. +::: **TIP:** +To scale an Entando Application without the use of clustered storage assumes all instances are scheduled to a single node and requires a `ReadWriteOnce (RWO)` policy in conjunction with taints on other nodes. Understanding the pros and cons of same-node scheduling is critical for node resource optimization and Application recovery, should the instance become unreachable. Note that if the node quits or is shut down the Application will be nonoperational until Kubernetes reschedules the pods to an alternate node. ::: ## Caching ### Data Management -At startup time the App Engine will load all database data into the shared cache. When a page is rendered or content is fetched that content will be served from the cache. In the event of a write to the cache the cache and database will both be updated. +At startup Entando App Engine will load all database data into the shared cache. Applicable content will be served from the cache when a page is rendered or content is fetched. In the event of a write to the cache, both the cache and database will be updated. -The following objects are cached in the base App Engine implementation +The following objects are cached in the base implementation of Entando App Engine: - Pages - Page templates - Categories - Widgets -- Configuration (application level configuration) +- Configuration (Application level configuration) - Roles - Groups - Languages @@ -57,35 +48,34 @@ The following objects are cached in the base App Engine implementation ## Infinispan Implementation (Default) -The default implementation, included in the quickstart and base images of the release, of the cache for the App Engine utilizes [Infinispan in Library Mode](https://infinispan.org/docs/stable/titles/embedding/embedding.html#install_library) and it is managed via configuration in the app server hosting the Entando App Engine. +The default implementation of the Entando App Engine cache is included in the quickstart and base images of the release and utilizes [Infinispan in Library Mode](https://infinispan.org/docs/stable/titles/embedding/embedding.html#install_library). It is managed through configuration of the Application server hosting Entando App Engine. ![Infinispan Caching](./infinispan-caching.png) -To utilize this implementation you can add replicas of the app engine (entando-de-app) to your deployment. New pods will automatically join the cluster. Ensuring a high availability deployment distributed across nodes depends on the underlying Kubernetes implementation and goals of the deployment. It is up to the implementor of the cluster and the application to ensure that the applications are scheduled to nodes and deployed in a fashion that meets the uptime and performance goals of the Entando Application. - -[Read more here](../../tutorials/devops/clustering-caching/caching-and-clustering) for tutorials and step by step instructions on using the Infinispan cache in an Entando App. +Add replicas of Entando App Engine (entando-de-app) to a deployment to take advantage of the base implementation. Note that new pods will automatically join the cluster. A high availability deployment distributed across nodes is a function of the deployment objectives and underlying Kubernetes implementation. The party responsible for cluster and Application implementation must ensure that Applications are scheduled and deployed in accordance with uptime and performance goals. +[Read more here](../../tutorials/devops/clustering-caching/caching-and-clustering) for tutorials and step-by-step instructions to use the Infinispan cache in an Entando Application. ## Redis Implementation -An Entando App can also be configured to utilize an external [Redis](https://redis.io/) cache. In a Redis implementation of an Entando App the cache is deployed separately from the App Engine and the App Engine is configured to connect to the deployed instance. +An Entando Application can also be configured to utilize an external [Redis](https://redis.io/) cache. In a Redis implementation of an Entando Application the cache is deployed independently of Entando App Engine and Entando App Engine is configured to connect to the deployed instance. ![Redis Caching](./redis-caching.png) -The Redis cache is not deployed by the Entando Operator and must be managed by the implementing teams dev ops or Kubernetes cluster administrators. +The Redis cache is not deployed by the Entando Operator and must be managed by the DevOps of implementation teams or Kubernetes cluster administrators. -[Read more here](../../tutorials/devops/clustering-caching/caching-and-clustering#configuring-and-deploying-with-redis) for tutorials and step by step instructions on using a Redis cache in an Entando App. +[Read more here](../../tutorials/devops/clustering-caching/caching-and-clustering#configuring-and-deploying-with-redis) for tutorials and step-by-step instructions to use a Redis cache in an Entando Application. ## Performance -As you design your Entando App Engine cluster there are a couple of things to keep in mind: +Consider the following when designing an Entando App Engine cluster: -- In a read only implementation, or an implementation with infrequent writes to the cached objects listed above, the network latency between pods on different nodes will not be a major driver of runtime performance. Each pod will have a fully replicated copy of the cache -- In write heavy implementations network latency between nodes can be a factor in performance - - The overall performance impact of network latency will vary depending on the implementation. The performance depends on the types of objects being written, the size of those objects, and whether the writes invalidate single objects or entire lists of objects in the cache. +- In a read only implementation, or an implementation with infrequent writes to the cached objects listed above, the network latency between pods on different nodes will not be a major driver of runtime performance. Each pod will have a fully replicated copy of the cache. +- In write heavy implementations network latency between nodes can factor into performance. +- The overall performance impact of network latency will vary depending upon implementation. Performance is impacted by the types of objects written, the size of those objects, and whether the writes invalidate single or entire lists of objects in the cache. -In general, it is recommended that performance testing on clustered instances matches the expected runtime traffic pattern of a live application. Every application will have a unique performance profile. +It is generally recommended that performance testing on clustered instances correlates to the expected runtime traffic pattern of a live Application. Every Application will have a unique performance profile. ### Cache Management -When a new replica of an Entando App joins a cluster of applications the cache is replicated to that node. If the cache is very large or the network is slow this may add to the total startup time of the new instance. Existing instances will continue to function. +When a new replica of an Entando Application joins a cluster of Applications the cache is replicated to that node. If the cache is relatively large or the network is slow this may add to the total startup time of the new instance. Existing instances will continue to function. From 1019ebf806c3ce8abbeb7eee4bad06753239e2b4 Mon Sep 17 00:00:00 2001 From: Lydia Date: Wed, 27 Oct 2021 12:09:34 -0700 Subject: [PATCH 2/5] changes to next rev of doc --- .../docs/reference/caching-and-clustering.md | 64 ++++++++----------- .../docs/reference/caching-and-clustering.md | 24 +++---- 2 files changed, 39 insertions(+), 49 deletions(-) diff --git a/vuepress/docs/next/docs/reference/caching-and-clustering.md b/vuepress/docs/next/docs/reference/caching-and-clustering.md index 81cdc6a52a..0e81ef7fc5 100644 --- a/vuepress/docs/next/docs/reference/caching-and-clustering.md +++ b/vuepress/docs/next/docs/reference/caching-and-clustering.md @@ -1,52 +1,43 @@ # Caching and Clustering in an Entando Application - ## App Engine Clustering and High Availability -The Entando App Engine can be deployed as a clustered set of instances using the clustering and replication ability of Kubernetes. The App Engine is -backed by a shared cache with two chioices of implementation out of the box. +The Entando App Engine can be deployed as a clustered set of instances using the clustering and replication ability of Kubernetes. It is backed by a shared cache with two default choices for implementation. -See this tutorial for configuring and testing a clustered instance of the App Engine. +This guide demonstrates how to configure and test a clustered instance of the Entando App Engine. -The clustering of microservices built to add functionality to an Entando application is separate from the clustering used by the App Engine. The microservices -have a separate clustering configuration and setup depending on the implementation and choices made in creating those microservices. See the documentation -for your microservices caching implementation for details on configuring and deploying clustered microservices. +Microservices clustering that adds functionality to an Entando Application is different from clustering used by the Entando App Engine. Microservices rely on a custom clustering configuration and setup based on implementation and selections made during their creation. Refer to documentation addressing clustered microservices and caching implementation for configuration and deployment details. -## Storage Requirements for Clustered Entando Apps +## Storage Requirements for Clustered Entando Applications -In order to scale an Entando Application across multiple nodes you must provide a storage class that supports -a `ReadWriteMany` access policy. There are many ways to accomplish this including using dedicated storage providers -like GlusterFS or others. The cloud Kubernetes providers also provide clustered storage options specific to their implementation like Google Cloud File in GKE or Azure Files in AKS. +To scale an Entando Application across multiple nodes a storage class that supports a `ReadWriteMany` access policy must be instantiated. There are a number of ways to accomplish this, inclusive of dedicated storage providers such as GlusterFS. Cloud Kubernetes providers also offer clustered storage options specific to their implementation, such as Google Cloud File in GKE or Azure Files in AKS. -You can use two different storage classes for your clustered vs non-clustered storage if your default class doesn't support `ReadWriteMany`. To do this add the following properties to your config map for the operator in the helm templates: +Two different storage classes can be used for clustered vs non-clustered storage if the default class doesn't support `ReadWriteMany`. To achieve this, add the following properties to the operator config map in the helm templates: -``` -entando.k8s.operator.default.clustered.storage.class: "[your clustered RWX storage class]" -entando.k8s.operator.default.non.clustered.storage.class: "[your RWO storage class]" +```jsp +entando.k8s.operator.default.clustered.storage.class: "[clustered RWX storage class]" +entando.k8s.operator.default.non.clustered.storage.class: "[RWO storage class]" ``` -Set the values of both to the appropriate storage class for your configuration. +Set both values to the storage class appropriate to the configuration. -::: tip -You can also scale an Entando Application without clustered storage using a `ReadWriteOnce (RWO)` policy by ensuring that the -instances are all scheduled to the same node. This can be accomplished using taints on other nodes. Be aware of the pros and cons of scheduling -instances to the same node. This will give you protection if the application instance itself dies or becomes unreachable and will help -you get the most utilization of node resources. However, if the node dies or is shutdown you will have to wait for Kubernetes to reschedule the pods to a different node and your application will be down. +::: **TIP** +To scale an Entando Application without the use of clustered storage assumes all instances are scheduled to a single node and requires a `ReadWriteOnce (RWO)` policy in conjunction with taints on other nodes. Understanding the pros and cons of same-node scheduling is critical for node resource optimization and application recovery, should the instance become unreachable. Note that if the node quits or is shut down the application will be nonoperational until Kubernetes reschedules the pods to an alternate node. ::: ## Caching ### Data Management -At startup time the App Engine will load all database data into the shared cache. When a page is rendered or content is fetched that content will be served from the cache. In the event of a write to the cache the cache and database will both be updated. +At startup the Entando App Engine will load all database data into the shared cache. Applicable content will be served from the cache when a page is rendered or content is fetched. In the event of a write to the cache, both the cache and database will be updated. -The following objects are cached in the base App Engine implementation +The following objects are cached in the base implementation of Entando App Engine: - Pages - Page templates - Categories - Widgets -- Configuration (application level configuration) +- Configuration (Application level configuration) - Roles - Groups - Languages @@ -57,35 +48,34 @@ The following objects are cached in the base App Engine implementation ## Infinispan Implementation (Default) -The default implementation, included in the quickstart and base images of the release, of the cache for the App Engine utilizes [Infinispan in Library Mode](https://infinispan.org/docs/stable/titles/embedding/embedding.html#install_library) and it is managed via configuration in the app server hosting the Entando App Engine. +The default implementation of the Entando App Engine cache is included in the quickstart and base images of the release and utilizes [Infinispan in Library Mode](https://infinispan.org/docs/stable/titles/embedding/embedding.html#install_library). It is managed through configuration of the application server hosting the Entando App Engine. ![Infinispan Caching](./infinispan-caching.png) -To utilize this implementation you can add replicas of the app engine (entando-de-app) to your deployment. New pods will automatically join the cluster. Ensuring a high availability deployment distributed across nodes depends on the underlying Kubernetes implementation and goals of the deployment. It is up to the implementor of the cluster and the application to ensure that the applications are scheduled to nodes and deployed in a fashion that meets the uptime and performance goals of the Entando Application. - -[Read more here](../../tutorials/devops/clustering-caching/caching-and-clustering) for tutorials and step by step instructions on using the Infinispan cache in an Entando App. +Add replicas of the Entando App Engine (entando-de-app) to a deployment to take advantage of the base implementation. Note that new pods will automatically join the cluster. A high availability deployment distributed across nodes is a function of the deployment objectives and underlying Kubernetes implementation. The party responsible for cluster and application implementation must ensure that applications are scheduled and deployed in accordance with uptime and performance goals. +[Read more here](../../tutorials/devops/clustering-caching/caching-and-clustering) for tutorials and step-by-step instructions to use the Infinispan cache in an Entando Application. ## Redis Implementation -An Entando App can also be configured to utilize an external [Redis](https://redis.io/) cache. In a Redis implementation of an Entando App the cache is deployed separately from the App Engine and the App Engine is configured to connect to the deployed instance. +An Entando Application can also be configured to utilize an external [Redis](https://redis.io/) cache. In a Redis implementation of an Entando Application the cache is deployed independently of the Entando App Engine and the Entando App Engine is configured to connect to the deployed instance. ![Redis Caching](./redis-caching.png) -The Redis cache is not deployed by the Entando Operator and must be managed by the implementing teams dev ops or Kubernetes cluster administrators. +The Redis cache is not deployed by the Entando Operator and must be managed by the DevOps of implementation teams or Kubernetes cluster administrators. -[Read more here](../../tutorials/devops/clustering-caching/caching-and-clustering#configuring-and-deploying-with-redis) for tutorials and step by step instructions on using a Redis cache in an Entando App. +[Read more here](../../tutorials/devops/clustering-caching/caching-and-clustering#configuring-and-deploying-with-redis) for tutorials and step-by-step instructions to use a Redis cache in an Entando Application. ## Performance -As you design your Entando App Engine cluster there are a couple of things to keep in mind: +Consider the following when designing an Entando App Engine cluster: -- In a read only implementation, or an implementation with infrequent writes to the cached objects listed above, the network latency between pods on different nodes will not be a major driver of runtime performance. Each pod will have a fully replicated copy of the cache -- In write heavy implementations network latency between nodes can be a factor in performance - - The overall performance impact of network latency will vary depending on the implementation. The performance depends on the types of objects being written, the size of those objects, and whether the writes invalidate single objects or entire lists of objects in the cache. +- In a read only implementation, or an implementation with infrequent writes to the cached objects listed above, the network latency between pods on different nodes will not be a major driver of runtime performance. Each pod will have a fully replicated copy of the cache. +- In write heavy implementations network latency between nodes can factor into performance. +- The overall performance impact of network latency will vary depending upon implementation. Performance is impacted by the types of objects written, the size of those objects, and whether the writes invalidate single or entire lists of objects in the cache. -In general, it is recommended that performance testing on clustered instances matches the expected runtime traffic pattern of a live application. Every application will have a unique performance profile. +It is generally recommended that performance testing on clustered instances correlates to the expected runtime traffic pattern of a live application. Every application will have a unique performance profile. ### Cache Management -When a new replica of an Entando App joins a cluster of applications the cache is replicated to that node. If the cache is very large or the network is slow this may add to the total startup time of the new instance. Existing instances will continue to function. +When a new replica of an Entando Application joins a cluster of applications the cache is replicated to that node. If the cache is relatively large or the network is slow this may add to the total startup time of the new instance. Existing instances will continue to function. diff --git a/vuepress/docs/v6.3.2/docs/reference/caching-and-clustering.md b/vuepress/docs/v6.3.2/docs/reference/caching-and-clustering.md index e070aa8fb1..0e81ef7fc5 100644 --- a/vuepress/docs/v6.3.2/docs/reference/caching-and-clustering.md +++ b/vuepress/docs/v6.3.2/docs/reference/caching-and-clustering.md @@ -2,13 +2,13 @@ ## App Engine Clustering and High Availability -Entando App Engine can be deployed as a clustered set of instances using the clustering and replication ability of Kubernetes. Entando App Engine is backed by a shared cache with two default choices for implementation. +The Entando App Engine can be deployed as a clustered set of instances using the clustering and replication ability of Kubernetes. It is backed by a shared cache with two default choices for implementation. -This guide demonstrates how to configure and test a clustered instance of Entando App Engine. +This guide demonstrates how to configure and test a clustered instance of the Entando App Engine. -Microservices clustering that adds functionality to an Entando Application is different from clustering used by Entando App Engine. Microservices rely on a custom clustering configuration and setup based on implementation and selections made during their creation. Refer to documentation addressing clustered microservices and caching implementation for configuration and deployment details. +Microservices clustering that adds functionality to an Entando Application is different from clustering used by the Entando App Engine. Microservices rely on a custom clustering configuration and setup based on implementation and selections made during their creation. Refer to documentation addressing clustered microservices and caching implementation for configuration and deployment details. -## Storage Requirements for Clustered Entando Apps +## Storage Requirements for Clustered Entando Applications To scale an Entando Application across multiple nodes a storage class that supports a `ReadWriteMany` access policy must be instantiated. There are a number of ways to accomplish this, inclusive of dedicated storage providers such as GlusterFS. Cloud Kubernetes providers also offer clustered storage options specific to their implementation, such as Google Cloud File in GKE or Azure Files in AKS. @@ -21,15 +21,15 @@ entando.k8s.operator.default.non.clustered.storage.class: "[RWO storage class]" Set both values to the storage class appropriate to the configuration. -::: **TIP:** -To scale an Entando Application without the use of clustered storage assumes all instances are scheduled to a single node and requires a `ReadWriteOnce (RWO)` policy in conjunction with taints on other nodes. Understanding the pros and cons of same-node scheduling is critical for node resource optimization and Application recovery, should the instance become unreachable. Note that if the node quits or is shut down the Application will be nonoperational until Kubernetes reschedules the pods to an alternate node. +::: **TIP** +To scale an Entando Application without the use of clustered storage assumes all instances are scheduled to a single node and requires a `ReadWriteOnce (RWO)` policy in conjunction with taints on other nodes. Understanding the pros and cons of same-node scheduling is critical for node resource optimization and application recovery, should the instance become unreachable. Note that if the node quits or is shut down the application will be nonoperational until Kubernetes reschedules the pods to an alternate node. ::: ## Caching ### Data Management -At startup Entando App Engine will load all database data into the shared cache. Applicable content will be served from the cache when a page is rendered or content is fetched. In the event of a write to the cache, both the cache and database will be updated. +At startup the Entando App Engine will load all database data into the shared cache. Applicable content will be served from the cache when a page is rendered or content is fetched. In the event of a write to the cache, both the cache and database will be updated. The following objects are cached in the base implementation of Entando App Engine: @@ -48,17 +48,17 @@ The following objects are cached in the base implementation of Entando App Engin ## Infinispan Implementation (Default) -The default implementation of the Entando App Engine cache is included in the quickstart and base images of the release and utilizes [Infinispan in Library Mode](https://infinispan.org/docs/stable/titles/embedding/embedding.html#install_library). It is managed through configuration of the Application server hosting Entando App Engine. +The default implementation of the Entando App Engine cache is included in the quickstart and base images of the release and utilizes [Infinispan in Library Mode](https://infinispan.org/docs/stable/titles/embedding/embedding.html#install_library). It is managed through configuration of the application server hosting the Entando App Engine. ![Infinispan Caching](./infinispan-caching.png) -Add replicas of Entando App Engine (entando-de-app) to a deployment to take advantage of the base implementation. Note that new pods will automatically join the cluster. A high availability deployment distributed across nodes is a function of the deployment objectives and underlying Kubernetes implementation. The party responsible for cluster and Application implementation must ensure that Applications are scheduled and deployed in accordance with uptime and performance goals. +Add replicas of the Entando App Engine (entando-de-app) to a deployment to take advantage of the base implementation. Note that new pods will automatically join the cluster. A high availability deployment distributed across nodes is a function of the deployment objectives and underlying Kubernetes implementation. The party responsible for cluster and application implementation must ensure that applications are scheduled and deployed in accordance with uptime and performance goals. [Read more here](../../tutorials/devops/clustering-caching/caching-and-clustering) for tutorials and step-by-step instructions to use the Infinispan cache in an Entando Application. ## Redis Implementation -An Entando Application can also be configured to utilize an external [Redis](https://redis.io/) cache. In a Redis implementation of an Entando Application the cache is deployed independently of Entando App Engine and Entando App Engine is configured to connect to the deployed instance. +An Entando Application can also be configured to utilize an external [Redis](https://redis.io/) cache. In a Redis implementation of an Entando Application the cache is deployed independently of the Entando App Engine and the Entando App Engine is configured to connect to the deployed instance. ![Redis Caching](./redis-caching.png) @@ -74,8 +74,8 @@ Consider the following when designing an Entando App Engine cluster: - In write heavy implementations network latency between nodes can factor into performance. - The overall performance impact of network latency will vary depending upon implementation. Performance is impacted by the types of objects written, the size of those objects, and whether the writes invalidate single or entire lists of objects in the cache. -It is generally recommended that performance testing on clustered instances correlates to the expected runtime traffic pattern of a live Application. Every Application will have a unique performance profile. +It is generally recommended that performance testing on clustered instances correlates to the expected runtime traffic pattern of a live application. Every application will have a unique performance profile. ### Cache Management -When a new replica of an Entando Application joins a cluster of Applications the cache is replicated to that node. If the cache is relatively large or the network is slow this may add to the total startup time of the new instance. Existing instances will continue to function. +When a new replica of an Entando Application joins a cluster of applications the cache is replicated to that node. If the cache is relatively large or the network is slow this may add to the total startup time of the new instance. Existing instances will continue to function. From b288e14e6b42b2d4c134cc4e1faea575e84112bd Mon Sep 17 00:00:00 2001 From: Lydia Date: Wed, 27 Oct 2021 12:43:55 -0700 Subject: [PATCH 3/5] fix requests for changes to next --- .../docs/next/docs/reference/caching-and-clustering.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/vuepress/docs/next/docs/reference/caching-and-clustering.md b/vuepress/docs/next/docs/reference/caching-and-clustering.md index 0e81ef7fc5..78571e06b2 100644 --- a/vuepress/docs/next/docs/reference/caching-and-clustering.md +++ b/vuepress/docs/next/docs/reference/caching-and-clustering.md @@ -14,15 +14,15 @@ To scale an Entando Application across multiple nodes a storage class that suppo Two different storage classes can be used for clustered vs non-clustered storage if the default class doesn't support `ReadWriteMany`. To achieve this, add the following properties to the operator config map in the helm templates: -```jsp +``` entando.k8s.operator.default.clustered.storage.class: "[clustered RWX storage class]" entando.k8s.operator.default.non.clustered.storage.class: "[RWO storage class]" ``` Set both values to the storage class appropriate to the configuration. -::: **TIP** -To scale an Entando Application without the use of clustered storage assumes all instances are scheduled to a single node and requires a `ReadWriteOnce (RWO)` policy in conjunction with taints on other nodes. Understanding the pros and cons of same-node scheduling is critical for node resource optimization and application recovery, should the instance become unreachable. Note that if the node quits or is shut down the application will be nonoperational until Kubernetes reschedules the pods to an alternate node. +::: tip +To scale an Entando Application without the use of clustered storage assumes all instances are scheduled to a single node and requires a `ReadWriteOnce (RWO)` policy in conjunction with taints on other nodes. Understanding the pros and cons of same-node scheduling is critical for node resource optimization and application recovery, should the instance become unreachable. Note that if the node quits or is shut down the application will be unavailable until Kubernetes reschedules the pods to an alternate node. ::: ## Caching @@ -62,7 +62,7 @@ An Entando Application can also be configured to utilize an external [Redis](htt ![Redis Caching](./redis-caching.png) -The Redis cache is not deployed by the Entando Operator and must be managed by the DevOps of implementation teams or Kubernetes cluster administrators. +The Redis cache is not deployed by the Entando Operator and must be managed by the DevOps team member or Kubernetes cluster administrators. [Read more here](../../tutorials/devops/clustering-caching/caching-and-clustering#configuring-and-deploying-with-redis) for tutorials and step-by-step instructions to use a Redis cache in an Entando Application. From e6a31910111b8c9dec2554e8900475614936d329 Mon Sep 17 00:00:00 2001 From: Lydia Date: Wed, 27 Oct 2021 12:53:14 -0700 Subject: [PATCH 4/5] correct minor grammatical error --- vuepress/docs/next/docs/reference/caching-and-clustering.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/vuepress/docs/next/docs/reference/caching-and-clustering.md b/vuepress/docs/next/docs/reference/caching-and-clustering.md index 78571e06b2..bf705d8b29 100644 --- a/vuepress/docs/next/docs/reference/caching-and-clustering.md +++ b/vuepress/docs/next/docs/reference/caching-and-clustering.md @@ -62,7 +62,7 @@ An Entando Application can also be configured to utilize an external [Redis](htt ![Redis Caching](./redis-caching.png) -The Redis cache is not deployed by the Entando Operator and must be managed by the DevOps team member or Kubernetes cluster administrators. +The Redis cache is not deployed by the Entando Operator and must be managed by a DevOps team member or Kubernetes cluster administrators. [Read more here](../../tutorials/devops/clustering-caching/caching-and-clustering#configuring-and-deploying-with-redis) for tutorials and step-by-step instructions to use a Redis cache in an Entando Application. From 69560020a09c817b33358346052db6fa360b8808 Mon Sep 17 00:00:00 2001 From: Lydia Date: Wed, 27 Oct 2021 15:30:54 -0700 Subject: [PATCH 5/5] apply latest fixes to V6.3.2 --- .../docs/v6.3.2/docs/reference/caching-and-clustering.md | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/vuepress/docs/v6.3.2/docs/reference/caching-and-clustering.md b/vuepress/docs/v6.3.2/docs/reference/caching-and-clustering.md index 0e81ef7fc5..b8622310ec 100644 --- a/vuepress/docs/v6.3.2/docs/reference/caching-and-clustering.md +++ b/vuepress/docs/v6.3.2/docs/reference/caching-and-clustering.md @@ -14,15 +14,15 @@ To scale an Entando Application across multiple nodes a storage class that suppo Two different storage classes can be used for clustered vs non-clustered storage if the default class doesn't support `ReadWriteMany`. To achieve this, add the following properties to the operator config map in the helm templates: -```jsp +``` entando.k8s.operator.default.clustered.storage.class: "[clustered RWX storage class]" entando.k8s.operator.default.non.clustered.storage.class: "[RWO storage class]" ``` Set both values to the storage class appropriate to the configuration. -::: **TIP** -To scale an Entando Application without the use of clustered storage assumes all instances are scheduled to a single node and requires a `ReadWriteOnce (RWO)` policy in conjunction with taints on other nodes. Understanding the pros and cons of same-node scheduling is critical for node resource optimization and application recovery, should the instance become unreachable. Note that if the node quits or is shut down the application will be nonoperational until Kubernetes reschedules the pods to an alternate node. +::: tip +To scale an Entando Application without the use of clustered storage assumes all instances are scheduled to a single node and requires a `ReadWriteOnce (RWO)` policy in conjunction with taints on other nodes. Understanding the pros and cons of same-node scheduling is critical for node resource optimization and application recovery, should the instance become unreachable. Note that if the node quits or is shut down the application will be unavailable until Kubernetes reschedules the pods to an alternate node. ::: ## Caching @@ -62,7 +62,7 @@ An Entando Application can also be configured to utilize an external [Redis](htt ![Redis Caching](./redis-caching.png) -The Redis cache is not deployed by the Entando Operator and must be managed by the DevOps of implementation teams or Kubernetes cluster administrators. +The Redis cache is not deployed by the Entando Operator and must be managed by a DevOps team member or Kubernetes cluster administrators. [Read more here](../../tutorials/devops/clustering-caching/caching-and-clustering#configuring-and-deploying-with-redis) for tutorials and step-by-step instructions to use a Redis cache in an Entando Application. @@ -79,3 +79,4 @@ It is generally recommended that performance testing on clustered instances corr ### Cache Management When a new replica of an Entando Application joins a cluster of applications the cache is replicated to that node. If the cache is relatively large or the network is slow this may add to the total startup time of the new instance. Existing instances will continue to function. +