HPC Meets Cloud: Opportunities and Challenges in Designing High-Performance MPI and Big Data Libraries on Virtualized InfiniBand Clusters Keynote Talk at CloudCom (December 2016) by Dhabaleswar K. (DK) Panda The Ohio State University E-mail: [email protected]http://www.cse.ohio-state.edu/~panda
64
Embed
HPC Meets Cloud: Opportunities and Challenges in …mvapich.cse.ohio-state.edu/static/media/talks/slide/dk_keynote...Designing High-Performance MPI and Big Data Libraries on Virtualized
This document is posted to help you gain knowledge. Please leave a comment to let me know what you think about it! Share it to your friends and learn new things together.
Transcript
HPC Meets Cloud: Opportunities and Challenges in Designing High-Performance MPI and Big Data
CloudCom 2016 12Network Based Computing Laboratory
• Single Root I/O Virtualization (SR-IOV) is providing new opportunities to design
HPC cloud with very little low overhead
Single Root I/O Virtualization (SR-IOV)
• Allows a single physical device, or a
Physical Function (PF), to present itself as
multiple virtual devices, or Virtual
Functions (VFs)
• VFs are designed based on the existing
non-virtualized PFs, no need for driver
change
• Each VF can be dedicated to a single VM
through PCI pass-through
• Work with 10/40 GigE and InfiniBand
CloudCom 2016 13Network Based Computing Laboratory
• High-Performance Computing (HPC) has adopted advanced interconnects and protocols
– InfiniBand
– 10/40 Gigabit Ethernet/iWARP
– RDMA over Converged Enhanced Ethernet (RoCE)
• Very Good Performance
– Low latency (few micro seconds)
– High Bandwidth (100 Gb/s with EDR InfiniBand)
– Low CPU overhead (5-10%)
• OpenFabrics software stack with IB, iWARP and RoCE interfaces are driving HPC systems
• How to Build HPC Cloud with SR-IOV and InfiniBand for delivering optimal performance?
Building HPC Cloud with SR-IOV and InfiniBand
CloudCom 2016 14Network Based Computing Laboratory
HPC and Big Data on Cloud Computing Systems: Challenges
HPC and Big Data Middleware
Networking Technologies
(InfiniBand, Omni-Path, 1/10/40/100 GigE and Intelligent NICs)
Storage Technologies(HDD, SSD, NVRAM, and NVMe-SSD)
HPC (MPI, PGAS, MPI+PGAS, MPI+OpenMP, etc.)
Applications
Commodity Computing System Architectures
(Multi- and Many-core architectures and accelerators)
Communication and I/O Library
QoS-aware, etc.
Big Data (HDFS, MapReduce, Spark, HBase, Memcached, etc.)
Resource Management and Scheduling Systems for Cloud Computing(OpenStack Nova, Swift, Heat; Slurm, etc.)
Virtualization (Hypervisor and Container)
Locality-awareCommunication
Communication Channels
Task SchedulingData Placement & Fault-Tolerance
(Migration, Replication, etc.)
(SR-IOV, IVShmem, IPC-Shm, CMA)
CloudCom 2016 15Network Based Computing Laboratory
• Virtualization Support with Virtual Machines and Containers– KVM, Docker, Singularity, etc.
• Communication coordination among optimized communication channels on Clouds– SR-IOV, IVShmem, IPC-Shm, CMA, etc.
• Locality-aware communication
• Scalability for million processors– Support for highly-efficient inter-node and intra-node communication (both two-sided and one-sided)
• Scalable Collective communication– Offload
– Non-blocking
– Topology-aware
• Balancing intra-node and inter-node communication for next generation nodes (128-1024 cores)– Multiple end-points per node
• Support for efficient multi-threading
• Integrated Support for GPGPUs and Accelerators
• Fault-tolerance/resiliency– Migration support with virtual machines
• QoS support for communication and I/O
• Support for Hybrid MPI+PGAS programming (MPI + OpenMP, MPI + UPC, MPI + OpenSHMEM, MPI+UPC++, CAF, …)
• Energy-Awareness
• Co-design with resource management and scheduling systems on Clouds– OpenStack, Slurm, etc.
Broad Challenges in Designing Communication and I/O Middleware for HPC on Clouds
CloudCom 2016 16Network Based Computing Laboratory
• High-Performance designs for Big Data middleware– RDMA-based designs to accelerate Big Data middleware on high-performance Interconnects
– NVM-aware communication and I/O schemes for Big Data
– SATA-/PCIe-/NVMe-SSD support
– Parallel Filesystems support
– Optimized overlapping among Computation, Communication, and I/O
– Threaded Models and Synchronization
• Fault-tolerance/resiliency– Migration support with virtual machines
– Data replication
• Efficient data access and placement policies
• Efficient task scheduling
• Fast deployment and automatic configurations on Clouds
Additional Challenges in Designing Communication and I/O Middleware for Big Data on Clouds
CloudCom 2016 17Network Based Computing Laboratory
• MVAPICH2-Virt with SR-IOV and IVSHMEM
– Standalone, OpenStack
• MVAPICH2 with Containers
• MVAPICH2-Virt on SLURM
– SLURM alone, SLURM + OpenStack
• Big Data Libraries on Cloud
Approaches to Build HPC Clouds
CloudCom 2016 18Network Based Computing Laboratory
Overview of the MVAPICH2 Project• High Performance open-source MPI Library for InfiniBand, Omni-Path, Ethernet/iWARP, and RDMA over Converged Ethernet (RoCE)
– MVAPICH (MPI-1), MVAPICH2 (MPI-2.2 and MPI-3.0), Started in 2001, First version available in 2002
– MVAPICH2-X (MPI + PGAS), Available since 2011
– Support for GPGPUs (MVAPICH2-GDR) and MIC (MVAPICH2-MIC), Available since 2014
– Support for Virtualization (MVAPICH2-Virt), Available since 2015
– Support for Energy-Awareness (MVAPICH2-EA), Available since 2015
– Support for InfiniBand Network Analysis and Monitoring (OSU INAM) since 2015
– Used by more than 2,700 organizations in 83 countries
– More than 404,000 (> 0.4 million) downloads from the OSU site directly
– Empowering many TOP500 clusters (Nov ‘16 ranking)
• 1st ranked 10,649,640-core cluster (Sunway TaihuLight) at NSC, Wuxi, China
• 13th ranked 241,108-core cluster (Pleiades) at NASA
• 17th ranked 519,640-core cluster (Stampede) at TACC
• 40th ranked 76,032-core cluster (Tsubame 2.5) at Tokyo Institute of Technology and many others
– Available with software stacks of many vendors and Linux Distros (RedHat and SuSE)
– http://mvapich.cse.ohio-state.edu
• Empowering Top500 systems for over a decade
– System-X from Virginia Tech (3rd in Nov 2003, 2,200 processors, 12.25 TFlops) ->
Sunway TaihuLight at NSC, Wuxi, China (1st in Nov’16, 10,649,640 cores, 93 PFlops)
CloudCom 2016 52Network Based Computing Laboratory
Big Data on Cloud Computing Systems: Challenges Addressed by OSU So Far
HPC and Big Data Middleware
Networking Technologies
(InfiniBand, Omni-Path, 1/10/40/100 GigE and Intelligent NICs)
Storage Technologies(HDD, SSD, NVRAM, and NVMe-SSD)
Applications
Commodity Computing System Architectures
(Multi- and Many-core architectures and accelerators)
Communication and I/O Library
Future Studies
Resource Management and Scheduling Systems for Cloud Computing(OpenStack Swift, Heat)
Virtualization (Hypervisor)
Locality-awareCommunication
Communication Channels(SR-IOV)
Data Placement & Task Scheduling
Big Data (HDFS, MapReduce, Spark, HBase, Memcached, etc.)
Fault-Tolerance(Replication)
CloudCom 2016 53Network Based Computing Laboratory
High-Performance Apache Hadoop over Clouds: Challenges
• How about performance characteristics of native IB-based designs for Apache
Hadoop over SR-IOV enabled cloud environment?
• To achieve locality-aware communication, how can the cluster topology be
automatically detected in a scalable and efficient manner and be exposed to the
Hadoop framework?
• How can we design virtualization-aware policies in Hadoop for efficiently taking
advantage of the detected topology?
• Can the proposed policies improve the performance and fault tolerance of
Hadoop on virtualized platforms?
“How can we design a high-performance Hadoop library for Cloud-based systems?”
CloudCom 2016 54Network Based Computing Laboratory
• Network architectures
– IB QDR, FDR, EDR
– 40GigE
– 40G-RoCE
• Network protocols
– TCP/IP, IPoIB
– RC, UD, Others
• Cloud Technologies
– Bare-metal, SR-IOV
Impact of HPC Cloud Networking Technologies
IB-QDR 40GigE 40G-RoCE IB-FDR IB-EDR
Network Architecture
Network Protocol
IP-over-IB
RC
UD
Others
SR-IOV
Bare-Metal
Cloud Technologies
TCP/IP
Can existing designs of Hadoop components over InfiniBand need to be made “aware” of the underlying architectural trends and take advantage of the support for modern transport protocols that InfiniBand and RoCE provide?
CloudCom 2016 55Network Based Computing Laboratory
• Design Features
– SEDA-based Thread Management
– Support RC, UD, and Hybrid transport protocols
– Architecture-aware designs for Eager, packetized, and zero-copy transfers
– JVM-bypassed buffer management
– Intelligent buffer allocation and adjustment for serialization
– InfiniBand/RoCE support for bare-metal and SR-IOV
Overview of IB-based Hadoop-RPC and HBase Architecture
HBase
Native IB-/RoCE-based RPC Engine
RDMA Capable Networks(IB, RoCE ..)
Applications
1/10/40/100 GigE
Java Socket Interface Java Native Interface (JNI)
Our DesignDefault
X. Lu, D. Shankar, S. Gugnani, H. Subramoni, and D. K. Panda, Impact of HPC Cloud Networking Technologies on Accelerating
Hadoop RPC and HBase, CloudCom, 2016. (To be presented Session 6A: Architecture and Virtualization V, Thursday 11:00am)
CloudCom 2016 56Network Based Computing Laboratory
Performance Benefits for Hadoop RPC and HBase
Hadoop RPC Throughput on Chameleon-Cloud HBase YCSB Workload A on SDSC-Comet
• Hadoop RPC Throughput on Chameleon-Cloud-FDR– up to 2.6x performance speedup over IPoIB for throughput
• HBase YCSB Workload A (read: write=50:50) on SDSC-Comet-FDR– Native designs (RC/UD/Hybrid) always perform better than the IPoIB-UD transport
– up to 2.4x performance speedup over IPoIB for throughput
CloudCom 2016 57Network Based Computing Laboratory
Overview of RDMA-Hadoop-Virt Architecture• Virtualization-aware modules in all the four
main Hadoop components:
– HDFS: Virtualization-aware Block Management
to improve fault-tolerance
– YARN: Extensions to Container Allocation Policy
to reduce network traffic
– MapReduce: Extensions to Map Task Scheduling
Policy to reduce network traffic
– Hadoop Common: Topology Detection Module
for automatic topology detection
• Communications in HDFS, MapReduce, and RPC
go through RDMA-based designs over SR-IOV
enabled InfiniBand
5
HDFS
YARN
Hado
op
Com
mon
MapReduce
HBase Others
Virtual Machines Bare-Metal nodesContainers
Big Data ApplicationsT
op
olo
gy D
ete
ction M
od
ule Map Task Scheduling
Policy Extension
Container Allocation
Policy Extension
CloudBurst MR-MS Polygraph Others
Virtualization Aware
Block Management
S. Gugnani, X. Lu, D. K. Panda. Designing Virtualization-aware and Automatic Topology Detection Schemes for Accelerating Hadoop on
SR-IOV-enabled Clouds. CloudCom, 2016. (To be presented in Session 3C: Big Data, Tuesday, 16:25)
CloudCom 2016 58Network Based Computing Laboratory
Evaluation with Applications
– 14% and 24% improvement with Default Mode for CloudBurst and Self-Join
– 30% and 55% improvement with Distributed Mode for CloudBurst and Self-Join
5
0
20
40
60
80
100
Default Mode Distributed Mode
EXEC
UTI
ON
TIM
ECloudBurst
RDMA-Hadoop RDMA-Hadoop-Virt
0
50
100
150
200
250
300
350
400
Default Mode Distributed Mode
EXEC
UTI
ON
TIM
E
Self-Join
RDMA-Hadoop RDMA-Hadoop-Virt
30% reduction
55% reduction
CloudCom 2016 59Network Based Computing Laboratory
Available Appliances on Chameleon Cloud*Appliance Description
CentOS 7 KVM SR-IOV
Chameleon bare-metal image customized with the KVM hypervisor and a recompiled kernel to enable SR-IOV over InfiniBand.https://www.chameleoncloud.org/appliances/3/
MPI bare-metal cluster complex
appliance (Based on Heat)
This appliance deploys an MPI cluster composed of bare metal instances using the MVAPICH2 library over InfiniBand. https://www.chameleoncloud.org/appliances/29/
MPI + SR-IOV KVM cluster (Based on
Heat)
This appliance deploys an MPI cluster of KVM virtual machines using the MVAPICH2-Virt implementation and configured with SR-IOV for high-performance communication over InfiniBand. https://www.chameleoncloud.org/appliances/28/
CentOS 7 SR-IOV RDMA-Hadoop
The CentOS 7 SR-IOV RDMA-Hadoop appliance is built from the CentOS 7 appliance and additionally contains RDMA-Hadoop library with SR-IOV.https://www.chameleoncloud.org/appliances/17/
• Through these available appliances, users and researchers can easily deploy HPC clouds to perform experiments and run jobs with
– High-Performance SR-IOV + InfiniBand
– High-Performance MVAPICH2 Library over bare-metal InfiniBand clusters
– High-Performance MVAPICH2 Library with Virtualization Support over SR-IOV enabled KVM clusters
– High-Performance Hadoop with RDMA-based Enhancements Support[*] Only include appliances contributed by OSU NowLab
CloudCom 2016 60Network Based Computing Laboratory
MPI Complex Appliances based on MVAPICH2 on Chameleon1. Load VM Config 2. Allocate Ports 3. Allocate FloatingIPs 4. Generate SSH Keypair 5. Launch VM 6. Attach SR-IOV Device 7. Hot plug IVShmem