DATA CACHING IN SERVERLESS APPLICATIONS
DOI:
https://doi.org/10.32782/IT/2024-2-6Keywords:
software, cloud technologies, serverless architecture, web service, caching, load testingAbstract
The response time of a modern web service is a crucial characteristic that has significant importance for meeting user needs. Users who receive instant responses from a web service perceive it as more convenient and appealing to use. At the same time, it is important for developers to quickly and efficiently deploy and scale their applications with minimal costs for maintenance and infrastructure. Therefore, the widespread adoption of cloud technologies for developing and deploying various applications is gaining popularity, and the ability to cache data allows for significant improvements in the performance of developed software. The purpose of the work is to consider various existing options for data caching in the cloud environment using AWS as an example and to justify the use of serverless architecture, which has become a new approach for deploying web services in the cloud environment. The methodology of the comparative analysis involves presenting the main principles of operation, features, and limitations for FaaS (Function as a Service) on AWS, reviewing existing tools for implementing data caching, such as Amazon ElastiCache for Redis, API Gateway Caching, and CloudFront in front of API Gateway. The use of a simple web service to retrieve a schedule of classes in an educational institution for a specified day of the week, consisting of serverless components such as Amazon API Gateway, AWS Lambda, and Amazon DynamoDB, is considered. A comparison of the performance of the created web service using different approaches to data caching is conducted by deploying four different application variants with the mentioned data caching options and preparing tests for load testing using the Locust framework. The scientific novelty of the results obtained in the work is formulating possible strategies for implementing caching for web services deployed in a cloud environment. Conclusions. The implementation of data caching has shown its effectiveness in increasing the performance of the web service. Furthermore, justifying the choice of serverless components for implementing data caching remains relevant in the future.
References
Adzic, Gojko; Chatley, Robert. Serverless computing: Economic and architectural impact. In Proceedings of the 2017 11th Joint Meeting on Foundations of Software Engineering (ESEC/FSE’17). ACM, New York, NY, pp. 884–889.
Miller, Ron. Amazon Launches Lambda, An Event-Driven Compute Service: веб-сайт. URL: https://techcrunch.com/2014/11/13/amazon-launches-lambda-an-event-driven-compute-service/ (дата звернення: 19.03.2024).
Cloud functions.: веб-сайт. URL: https://cloud.google.com/functions (дата звернення 17.03.24).
Azure Functions.: веб-сайт. URL: https://azure.microsoft.com/en-us/products/functions (дата звернення 01.03.24).
Roberts, Mike. Serverless Architectures : веб-сайт. URL: https://martinfowler.com/articles/serverless.html (дата звернення 01.03.24).
Mohak Chadha, Anshul Jindal, and Michael Gerndt. Architecture-Specific Performance Optimization of Compute-Intensive FaaS Functions. In 2021 IEEE 14th International Conference on Cloud Computing (CLOUD). 478–483.
W. Lloyd, M. Vu, B. Zhang, O. David and G. Leavesley. Improving Application Migration to Serverless Computing Platforms: Latency Mitigation with Keep-Alive Workloads. 2018 IEEE/ACM International Conference on Utility and Cloud Computing Companion (UCC Companion), Zurich, Switzerland, 2018, pp. 195-200, doi: 10.1109/UCC-Companion.2018.00056.
B. C. Ghosh, S. K. Addya, N. B. Somy, S. B. Nath, S. Chakraborty and S. K. Ghosh. Caching Techniques to Improve Latency in Serverless Architectures. 2020 International Conference on COMmunication Systems & NETworkS (COMSNETS), Bengaluru, India, 2020, P. 666-669. doi: 10.1109/COMSNETS48256.2020.9027427.
Amazon API Gateway: Create, maintain, and secure APIs at any scale. : веб-сайт. URL: https://aws.amazon.com/api-gateway/ (дата звернення 17.03.24).
Amazon DynamoDB: Serverless, NoSQL, fully managed database with single-digit millisecond performance at any scale.: веб-сайт. URL: https://aws.amazon.com/dynamodb/ (дата звернення 17.03.24).
AWS Caching Solutions.: веб-сайт. URL: https://aws.amazon.com/caching/aws-caching/ (дата звернення 17.03.24).
Amazon ElastiCache pricing.: веб-сайт. URL: https://aws.amazon.com/elasticache/pricing/?nc=sn&loc=5 (дата звернення 17.03.24)
Hugo Tota. AWS Gateway Cache Strategy to Improve Performance: веб-сайт. URL: https://www.linkedin.com/pulse/aws-gateway-cache-strategy-improve-performance-hugo-tota (дата звернення 23.03.24).
Bhargav Shah. API Gateway & Caching.: веб-сайт. URL: https://shahbhargav.medium.com/apigateway-caching-3f86034ca491 (дата звернення 23.03.24).
Gabin Lee, Byounghwan Oh. Amazon CloudFront Cache Strategy for Successful Global Game Deployment.: веб-сайт. URL: https://aws.amazon.com/blogs/apn/amazon-cloudfront-cache-strategy-forsuccessful-global-game-deployment/ (дата звернення 21.03.24).
Jeiman Jeya. Let’s Dive into AWS CloudFront.: веб-сайт. URL: https://community.ops.io/jei/lets-diveinto-aws-cloudfront-3i3k (дата звернення 10.03.24).
Load Testing: What is Load Testing & Why is Load Testing Important?: веб-сайт. URL: https://www.loadview-testing.com/learn/load-testing/ (дата звернення 23.03.24).
Jonatan Heyman, Lars Holmberg, Andrew Baldwin, Carl Byström, Joakim Hamrén, Hugo Heyman. What is Locust?: веб-сайт. URL: https://docs.locust.io/en/stable/what-is-locust.html (дата звернення 20.03.24).