Aggregated HPC resources have rigid allocation systems and programming models which struggle to adapt to diverse and changing workloads. Consequently, HPC systems fail to efficiently use the large pools of unused memory and increase the utilization of idle computing resources. Prior work attempted to increase the throughput and efficiency of supercomputing systems through workload co-location and resource disaggregation. However, these methods fall short of providing a solution that can be applied to existing systems without major hardware modifications and performance losses. In this paper, we improve the utilization of supercomputers by employing the new cloud paradigm of serverless computing. We show how serverless functions provide fine-grained access to the resources of batch-managed cluster nodes. We present an HPC-oriented Function-as-a-Service (FaaS) that satisfies the requirements of high-performance applications. We demonstrate a software resource disaggregation approach where placing functions on unallocated and underutilized nodes allows idle cores and accelerators to be utilized while retaining near-native performance.
翻译:聚合式高性能计算资源具有僵化的分配系统和编程模型,难以适应多样化和动态变化的工作负载。因此,高性能计算系统未能有效利用大量未使用的内存池,也无法提高闲置计算资源的利用率。先前的研究尝试通过工作负载共置和资源解耦来提升超级计算系统的吞吐量和效率。然而,这些方法未能提供一种无需重大硬件改造和性能损失即可应用于现有系统的解决方案。本文通过采用无服务器计算这一新型云范式来提升超级计算机的利用率。我们展示了无服务器函数如何实现对批处理管理集群节点资源的细粒度访问。我们提出了一种面向高性能计算的无服务器函数即服务架构,该架构能够满足高性能应用的需求。我们演示了一种软件资源解耦方法,通过将函数部署在未分配和未充分利用的节点上,使得闲置的计算核心和加速器得以利用,同时保持接近原生性能。