Amazon ElastiCache is a fully managed in-memory data store and cache service by
Amazon Web Services (AWS). The service improves the performance of web applications by retrieving information from managed
in-memory caches, instead of relying entirely on slower disk-based databases. ElastiCache supports three in-memory caching engines:
Valkey,
Memcached
Memcached (pronounced variously /mɛmkæʃˈdiː/ ''mem-cash-dee'' or /ˈmɛmkæʃt/ ''mem-cashed'') is a general-purpose distributed memory-caching system. It is often used to speed up dynamic database-driven websites by caching data and object ...
, and
Redis
Redis (; Remote Dictionary Server) is an in-memory key–value database, used as a distributed cache and message broker, with optional durability. Because it holds all data in memory and because of its design, Redis offers low- latency reads ...
.
As a
web service
A web service (WS) is either:
* a service offered by an electronic device to another electronic device, communicating with each other via the Internet, or
* a server running on a computer device, listening for requests at a particular port over a n ...
running in the
computing cloud, Amazon ElastiCache is designed to simplify the setup, operation, and scaling of Valkey, Memcached, and Redis deployments. Complex administration processes like patching software, backing up and restoring data sets and dynamically adding or removing capabilities are managed automatically. Scaling ElastiCache resources can be performed by a single
API
An application programming interface (API) is a connection between computers or between computer programs. It is a type of software interface, offering a service to other pieces of software. A document or standard that describes how to build ...
call.
Amazon ElastiCache was first released on August 22, 2011, supporting memcached. This was followed by support for reserved instances on April 5, 2012 and Redis on September 4, 2013.
Uses
As a managed database service with multiple supported engines, Amazon ElastiCache has a wide range of uses, including
Performance acceleration
Database limitations are often a bottleneck for application performance. By placing Amazon ElastiCache between an
application and its database
tier, database operations can be accelerated.
Cost reduction
Using ElastiCache for database performance acceleration can significantly reduce the infrastructure needed to support the database. In many cases, the cost savings outweigh the cache costs.
Expedia
Expedia Inc. is an online travel agency owned by Expedia Group, based in Seattle. The website and mobile app can be used to book airline tickets, hotel reservations, car rentals, cruise ships, and vacation packages. Expedia.com was launched on ...
was able to use ElastiCache to reduce provisioned DynamoDB capacity by 90%, reducing total database cost by 6x.
Processing time series data
Using the Redis engine, ElastiCache can rapidly process
time-series
In mathematics, a time series is a series of data points indexed (or listed or graphed) in time order. Most commonly, a time series is a sequence taken at successive equally spaced points in time. Thus it is a sequence of discrete-time data. E ...
data, quickly selecting newest or oldest records or events within range of a point-in-time.
Leaderboards
Leaderboards are an effective way to show a user quickly where they currently stand within a gamified system. For systems with large numbers of gamers, calculating and publishing player ranks can be challenging. Using Amazon ElastiCache with the Redis engine can enable high-speed at scale for leaderboards.
Rate limitation
Some APIs only allow a limited number of requests per time period. Amazon ElastiCache for Redis engine can use incremental counters and other tools to throttle API access to meet restrictions.
Atomic counter
Programs can use incremental
counters to limit allowed quantities, such as the maximum number of students enrolled in a course or ensuring a game has at least 2 but not more than 8 players. Using counters can create a
race condition
A race condition or race hazard is the condition of an electronics, software, or other system where the system's substantive behavior is dependent on the sequence or timing of other uncontrollable events, leading to unexpected or inconsistent ...
where an operation is allowed because a counter was not updated promptly. Using the ElastiCache for Redis atomic counter functions, where a single operation both checks and increments the counter's value, prevents race conditions.
Chat rooms and message boards
ElastiCache for Redis supports
publish-subscribe patterns, which enable the creation of
chat rooms
The term chat room, or chatroom (and sometimes group chat; abbreviated as GC), is primarily used to describe any form of synchronous conferencing, occasionally even asynchronous conferencing. The term can thus mean any technology, ranging from ...
and message boards where messages are automatically distributed to interested users.
Deployment options
Amazon ElastiCache can use on-demand cache nodes or reserved cache nodes.
On-demand nodes provide cache capacity by the hour, with resources in the AWS cloud assigned when a cache node is provisioned. An on-demand node can be removed from service by its owner at any time. Each month, the owner will be billed for the hours used.
Reserved nodes require a 1-year or 3-year commitment, which dedicates cache resources to the owner. The hourly cost of reserved nodes is significantly lower than the hourly cost of on-demand nodes.
Performance
An efficient
cache
Cache, caching, or caché may refer to:
Science and technology
* Cache (computing), a technique used in computer storage for easier data access
* Cache (biology) or hoarding, a food storing behavior of animals
* Cache (archaeology), artifacts p ...
can significantly increase application's performance and user navigation speed.
Amazon CloudWatch exposes ElastiCache performance metrics that can be tracked.
Key performance metrics
* Client metrics (measure the volume of client connections and requests): Number of current client connections to the cache, Get and Set commands received by the cache
* Cache performance: Hits, misses, Replication Lag,
Latency
* Memory metrics: Memory usage, Evictions, Amount of free memory available on the host, Swap Usage, Memory fragmentation ratio
* Other host-level metrics:
CPU utilization, Number of bytes read from the network by the host, Number of bytes written to the network by the host
Metric collection
Many ElastiCache metrics can be collected from AWS via
CloudWatch or directly from the cache engine, whether Redis or Memcached, with a monitoring tool integrating with it:
* Using th
AWS Management ConsoleUsing the online management console is the simplest way to monitor ElastiCache with CloudWatch. It allows to set up basic automated alerts and to get a visual picture of recent changes in individual metrics.
* CloudWatch
command-line interface
A command-line interface (CLI) is a means of interacting with software via command (computing), commands each formatted as a line of text. Command-line interfaces emerged in the mid-1960s, on computer terminals, as an interactive and more user ...
Metrics related to ElastiCache can also be retrieved using command lines. It can be used for spot checks and ad hoc investigations.
* Monitoring tool integrated with CloudWatch
The third way to collect ElastiCache metrics is via a dedicated monitoring tool integrating with Amazon CloudWatch.
Notable customers
Users of Amazon ElastiCache include
Airbnb
Airbnb, Inc. ( , an abbreviation of its original name, "Air Bed and Breakfast") is an American company operating an online marketplace for short-and-long-term homestays, experiences and services in various countries and regions. It acts as a ...
,
Expedia
Expedia Inc. is an online travel agency owned by Expedia Group, based in Seattle. The website and mobile app can be used to book airline tickets, hotel reservations, car rentals, cruise ships, and vacation packages. Expedia.com was launched on ...
,
Zynga
Zynga Inc. () is an American video game developer and Video game publisher, publisher known for its social video game services. It was founded in April 2007, with headquarters in San Mateo, California. The company primarily focuses on mobile an ...
,
Tinder
Tinder is easily Combustibility and flammability, combustible material used to Firemaking, start a fire. Tinder is a finely divided, open material which will begin to glow under a shower of sparks. Air is gently wafted over the glowing tinder unt ...
,
FanDuel
FanDuel Group is an American gambling company that offers sportsbook, daily fantasy sports, horse racing, and online casino services. The company operates sportsbooks in a number of states including New Jersey, Pennsylvania, Indiana and West Vir ...
, and
Mapbox
Limitations
As an AWS service, ElastiCache is designed to be accessed exclusively from within AWS, though it is possible to connect the service to applications and databases that are not hosted by AWS.
Alternatives
Other vendors provide cloud data cache services comparable to Amazon ElastiCache, includin
Azure Cache for Redis Redis Ltd (company behind open source Redis and Redis Enterprise),
Redis To Go, IBM Compose,
Oracle Application Container Cloud Service, and
Rackspace ObjectRocket.
References
External links
*
{{Amazon
2006 software
Amazon Web Services
Cloud computing providers
Cloud databases
Cloud infrastructure
Cloud platforms
Cloud storage
Distributed data stores
NoSQL products
Structured storage
Web hosting