Skip to Main content Skip to Navigation
Journal articles

Cacol: a zero overhead and non-intrusive double caching mitigation system

Abstract : In a virtualized server, a page cache (which caches I/O data) is managed in both the hypervisor and the guest Operating System (OS). This leads to a well-known issue called double caching. Double caching is the presence of the same data in both the hypervisor page cache and guest OS page caches. Some experiments we performed show that almost 64% of the hypervisor page cache content is also present in guest page caches.Therefore, double caching is a huge source of memory waste in virtualized servers, particularly when I/O disk-intensive workloads are executed (which is common in today’s data centers). Knowing that memory is the limiting resource for workload consolidation, double caching is a critical issue.This paper presents a novel solution (called Cacol) to avoid double caching. Unlike existing solutions, Cacol is not intrusive as it does not require guest OS modification and induces very little performance overhead for user applications. We implemented Cacol in KVM hypervisor, a very popular virtualization system. We evaluated Cacol and compared it with Linux default solutions. The results confirm the advantages (no guest modification and no overhead) of Cacol against existing solutions.
Complete list of metadata

Cited literature [21 references]  Display  Hide  Download
Contributor : Open Archive Toulouse Archive Ouverte (OATAO) Connect in order to contact the contributor
Submitted on : Wednesday, July 8, 2020 - 7:17:51 PM
Last modification on : Thursday, August 4, 2022 - 4:53:09 PM
Long-term archiving on: : Monday, November 30, 2020 - 4:30:51 PM


Files produced by the author(s)



Grégoire Todeschi, Boris Djomgwe Teabe, Alain Tchana, Daniel Hagimont. Cacol: a zero overhead and non-intrusive double caching mitigation system. Future Generation Computer Systems, Elsevier, 2020, 106, pp.14-21. ⟨10.1016/j.future.2019.11.035⟩. ⟨hal-02894310⟩



Record views


Files downloads