Enhancing Performance of Cloud-based Software Applications with GraalVM and Quarkus
M. Sipek,D. Muharemagic,B. Mihaljevic,A. Radovan
DOI: https://doi.org/10.23919/MIPRO48935.2020.9245290
2021-12-16
Abstract:Increased complexity of network-based software solutions and the ever-rising number of concurrent users forced a shift of the IT industry to cloud computing. Conventional network software systems commonly based on monolithic application stack running on costly physical single-purpose servers are affected by significant problems of resource management, computing power distribution, and <a class="link-external link-http" href="http://scalability.Such" rel="external noopener nofollow">this http URL</a> implementation is restricting applications to be reduced to smaller, independent services that can be more easily deployed, managed, and scaled dynamically; therefore, embellishing environmental uniformity across development, testing, and production. Current cloud-based infrastructure frequently runs on containers placed in Kubernetes or Docker-based cluster, and the system configuration is considerably different compared to the environment prevailed with common virtualizations. This paper discusses the usage of GraalVM, a polyglot high-performance virtual machine for JVM-based and other languages, combined with new Kubernetes native Java tailored stacked framework named Quarkus, formed from enhanced Java libraries. Moreover, our research explores GraalVMs creation of native images using Ahead-Of-Time (AOT) compilation and Quarkus deployment to Kubernetes. Furthermore, we examined the architectures of given systems, various performance variables, and differing memory usage cases within our academic testing environment and presented the comparison results of selected performance measures with other traditional and contemporary solutions
Distributed, Parallel, and Cluster Computing