Dieser Inhalt ist in der von Ihnen ausgewählten Sprache nicht verfügbar.
Chapter 7. Redis high availability (HA) support for 3scale
				Red Hat does not officially support setting up Redis for zero downtime, configuring back-end components for 3scale, or Redis database replication and sharding. The content is for reference only. Additionally, Redis cluster mode is not supported in 3scale.
			
High availability (HA) is provided for most components by the OpenShift Container Platform (OCP). For more information see OpenShift Container Platform 3.11 Chapter 30. High Availability.
The database components for HA in Red Hat 3scale API Management include:
- 
					backend-redis: used for statistics storage and temporary job storage.
- 
					system-redis: provides temporary storage for background jobs for 3scale and is also used as a message bus for Ruby processes ofsystem-apppods.
			Both backend-redis and system-redis work with supported Redis high availability variants for Redis Sentinel and Redis Enterprise.
		
If the Redis pod comes to a stop, or if the OpenShift Container Platform stops it, a new pod is automatically created. Persistent storage will restore the data so the pod continues to work. In these scenarios, there will be a small amount of downtime while the new pod starts. This is due to a limitation in Redis that does not support a multi-master setup. You can reduce downtime by preinstalling the Redis images onto all nodes that have Redis deployed to them. This will speed up the pod restart time.
Set up Redis for zero downtime and configure back-end components for 3scale:
Prerequisites
- A 3scale account with an administrator role.
7.1. Setting up Redis for zero downtime
As a 3scale administrator, configure Redis outside of OCP if you require zero downtime. There are several ways to set it up using the configuration options of 3scale pods:
- Set up your own self-managed Redis
- Use Redis Sentinel: Reference Redis Sentinel Documentation
- Redis provided as a service: - For example by: - Amazon ElastiCache
- Redis Labs
 
Red Hat does not provide support for the above mentioned services. The mention of any such services does not imply endorsement by Red Hat of the products or services. You agree that Red Hat is not responsible or liable for any loss or expenses that may result due to your use of (or reliance on) any external content.
7.2. Configuring back-end components for 3scale
				As a 3scale administrator, configure Redis HA (failover) for the back-end component environment variables in the following deployment configurations: backend-cron, backend-listener, and backend-worker. These configurations are necessary for Redis HA in 3scale.
			
					If you want to use Redis with sentinels, you must provide sentinel configuration in either backend-redis, system-redis, or both secrets.
				
7.2.1. Creating backend-redis and system-redis secrets
					Follow these steps to create backend-redis and system-redis secrets accordingly:
				
7.2.2. Deploying a fresh installation of 3scale for HA
Procedure
- Create the - backend-redisand- system-redissecrets with the fields below:- backend-redis - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - system-redis - NAMESPACE SENTINEL_HOSTS SENTINEL_ROLE URL - NAMESPACE SENTINEL_HOSTS SENTINEL_ROLE URL- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - When configuring for Redis with sentinels, the corresponding - URLfields in- backend-redisand- system-redisrefer to the Redis group in the format- redis://[:redis-password@]redis-group[/db], where [x] denotes optional element x and- redis-password,- redis-group, and- dbare variables to be replaced accordingly:- Example - redis://:redispwd@mymaster/5 - redis://:redispwd@mymaster/5- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- The - SENTINEL_HOSTSfields are comma-separated lists of sentinel connection strings in the following format:- redis://:sentinel-password@sentinel-hostname-or-ip:port - redis://:sentinel-password@sentinel-hostname-or-ip:port- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - For each element of the list, [x] denotes optional element x and - sentinel-password,- sentinel-hostname-or-ip, and- portare variables to be replaced accordingly:- Example - :sentinelpwd@123.45.67.009:2711,:sentinelpwd@other-sentinel:2722 - :sentinelpwd@123.45.67.009:2711,:sentinelpwd@other-sentinel:2722- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- 
									The SENTINEL_ROLEfields are eithermasterorslave.
 
- Deploy 3scale as indicated in Deploying 3scale using the operator. - 
									Ignore the errors due to backend-redisandsystem-redisalready present.
 
- 
									Ignore the errors due to 
7.2.3. Migrating a non-HA deployment of 3scale to HA
- 
							Edit the backend-redisandsystem-redissecrets with all fields as shown in Deploying a fresh installation of 3scale for HA.
- Make sure the following - backend-redisenvironment variables are defined for the back-end pods.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Make sure the following - system-redisenvironment variables are defined for the- system-(app|sidekiq|sphinx)pods.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Proceed with instructions to continue Upgrading 3scale using templates.
7.2.3.1. Using Redis Enterprise
- Use Redis Enterprise deployed in OpenShift, with three different - redis-enterpriseinstances:- Edit - system-redissecret:- 
												Set the system redis database in system-redistoURL.
 
- 
												Set the system redis database in 
- 
										Set the back-end database in backend-redistoREDIS_QUEUES_URL.
- 
										Set the third database to REDIS_STORAGE_URLforbackend-redis.
 
7.2.3.2. Using Redis Sentinel
You can optionally apply Redis Sentinels to any of the databases. However, Red Hat recommends that you apply Redis Sentinels to all of them for HA.
- Backend redis for statistics: update - backend-redissecret and provide values for:- 
										REDIS_STORAGE_URL
- 
										REDIS_STORAGE_SENTINEL_ROLE
- REDIS_STORAGE_SENTINEL_HOSTS- Set - REDIS_STORAGE_SENTINEL_ROLEto a comma-separated list of sentinels hosts and ports, for example:- :sentinelpwd@123.45.67.009:2711,:sentinelpwd@other-sentinel:2722
 
- 
										
- Backend redis for queue: update - backend-redissecret and provide values for:- 
										REDIS_QUEUES_URL
- 
										REDIS_QUEUES_SENTINEL_ROLE
- REDIS_QUEUES_SENTINEL_HOSTS- Set - REDIS_QUEUES_SENTINEL_ROLEto a comma-separated list of sentinels hosts and ports, for example:- :sentinelpwd@123.45.67.009:2711,:sentinelpwd@other-sentinel:2722
 
- 
										
- Use Redis Sentinel, with these Redis databases:
- System redis for data: update - system-redissecret and provide values for:Note- Edit - system-redissecret:- URL- 
										SENTINEL_ROLE
- 
										NAMESPACE
- 
										URL
- SENTINEL_HOSTS- Set - SENTINEL_HOSTSto a comma-separated list of sentinels hosts and ports, for example:- :sentinelpwd@123.45.67.009:2711,:sentinelpwd@other-sentinel:2722
 
- 
										
Notes
- The system-app and system-sidekiq components connect directly to - back-endRedis for retrieving statistics.- 
										As of 3scale 2.7, these system components can also connect to back-endRedis (storage) when using sentinels.
 
- 
										As of 3scale 2.7, these system components can also connect to 
- The system-app and system-sidekiq components uses only - backend-redisstorage, not- backend-redisqueues.- 
										Changes made to the system components support backend-redisstorage with sentinels.
 
- 
										Changes made to the system components support 
7.3. Redis database sharding and replication
Sharding, sometimes referred to as partitioning, separates large databases in to smaller databases called shards. With replication, your database is set up with copies of the same dataset hosted on separate machines.
Sharding
Sharding facilitates adding more leader instances, which is also useful when you have so much data that it does not fit in a single database, or when the CPU load is close to 100%.
With Redis HA for 3scale, the following two reasons are why sharding is important:
- Spliting and scaling large volumes of data and adjusting the number of shards for a particular index to help avoid bottlenecks.
- Distributing operations across different node, therefore increasing performance, for example, when multiple machines are working on the same query.
The three main solutions for Redis database sharding with cluster mode disabled are:
- Amazon ElastiCache
- Standard Redis via Redis sentinels
- Redis Enterprise
Replication
Redis database replication ensures redundancy by having your dataset replicated across different machines. Using replication allows you to keep Redis working when the leader goes down. Data is then pulled from a single instance, the leader, ensuring high availability.
With Redis HA for 3scale, database replication ensures high availability replicas of a primary shard. The principles of operation involve:
- When the primary shard fails, the replica shard will automatically be promoted to the new primary shard.
- Upon recovery of the original primary shard, it automatically becomes the replica shard of the new primary shard.
The three main solutions for Redis database replication are:
- Redis Enterprise
- Amazon ElastiCache
- Standard Redis via Redis sentinels
Sharding with twemproxy
					For Amazon ElastiCache and Standard Redis, sharding involves splitting data up based on keys. You need a proxy component that given a particular key knows which shard to find, for example twemproxy. Also known as nutcracker, twemproxy is a lightweight proxy solution for Redis protocols that finds shards based on specific keys or server maps assigned to them. Adding sharding capabilities to your Amazon ElastiCache or Standard Redis instance with twemproxy, has the following advantages:
				
- The capability of sharding data automatically across multiple servers.
- Support of multiple hashing modes and consistent hashing and distribution.
- The capability to run in multiple instances, which allows clients to connect to the first available proxy server.
- Reduce the number of connections to the caching servers on the backend.
					Redis Enterprise uses its own proxy, so it does not need twemproxy.
				
Additional resources
7.4. Additional information
- For more information about 3scale and Redis database support, see Red Hat 3scale API Management Supported Configurations.
- For more information about Amazon ElastiCache for Redis, see the official Amazon ElastiCache Documentation.
- For more information about Redis Enterprise, see the latest Documentation.