Silvano Gai
Building a Future-Proof Cloud Infrastructure
A Unified Architecture for Network, Security, and Storage Services
Silvano Gai
Building a Future-Proof Cloud Infrastructure
A Unified Architecture for Network, Security, and Storage Services
- Broschiertes Buch
- Merkliste
- Auf die Merkliste
- Bewerten Bewerten
- Teilen
- Produkt teilen
- Produkterinnerung
- Produkterinnerung
In Building a Future-proof Cloud Infrastructure, network pioneer Silvano Gai shows how to implement Distributed Services Platforms with multiple service modules in diverse hardware. Focusing on business benefits throughout, Gai places Distributed Services Platforms in the context of current trends in network and cloud architecture and virtualization. He compares four leading architectures: Sea of Processors, FPGAs, ASIC, and P4, reviewing the advantages and tradeoffs of each, and illuminating key concepts with intuitive illustrations. By the time students have finished, they'll know how to…mehr
Andere Kunden interessierten sich auch für
- John DavisVcp-DCV for Vsphere 8.X Cert Guide76,99 €
- David JansenBuilding Data Centers with VXLAN BGP EVPN43,99 €
- Daniel WalshPodman in Action65,99 €
- Brandon ByarsTesting Microservices with Mountebank55,99 €
- Michael WashamAutomating Microsoft Azure Infrastructure Services34,99 €
- Richard HundhausenProfessional Scrum Development with Azure Devops32,99 €
- Ed BottWindows 10 Inside Out51,99 €
-
-
-
In Building a Future-proof Cloud Infrastructure, network pioneer Silvano Gai shows how to implement Distributed Services Platforms with multiple service modules in diverse hardware. Focusing on business benefits throughout, Gai places Distributed Services Platforms in the context of current trends in network and cloud architecture and virtualization. He compares four leading architectures: Sea of Processors, FPGAs, ASIC, and P4, reviewing the advantages and tradeoffs of each, and illuminating key concepts with intuitive illustrations. By the time students have finished, they'll know how to evaluate solutions, ask pertinent questions, and plan the best Distributed Services Platform strategies for their own environments.
Hinweis: Dieser Artikel kann nur an eine deutsche Lieferadresse ausgeliefert werden.
Hinweis: Dieser Artikel kann nur an eine deutsche Lieferadresse ausgeliefert werden.
Produktdetails
- Produktdetails
- Verlag: Pearson Education (US)
- Seitenzahl: 272
- Erscheinungstermin: 31. Januar 2020
- Englisch
- Abmessung: 231mm x 181mm x 17mm
- Gewicht: 462g
- ISBN-13: 9780136624097
- ISBN-10: 013662409X
- Artikelnr.: 57976282
- Herstellerkennzeichnung
- Libri GmbH
- Europaallee 1
- 36244 Bad Hersfeld
- 06621 890
- Verlag: Pearson Education (US)
- Seitenzahl: 272
- Erscheinungstermin: 31. Januar 2020
- Englisch
- Abmessung: 231mm x 181mm x 17mm
- Gewicht: 462g
- ISBN-13: 9780136624097
- ISBN-10: 013662409X
- Artikelnr.: 57976282
- Herstellerkennzeichnung
- Libri GmbH
- Europaallee 1
- 36244 Bad Hersfeld
- 06621 890
Silvano Gai, who grew up in a small village near Asti, Italy, has more than 35 years of experience in computer engineering and computer networks. He is the author of several books and technical publications on computer networking as well as multiple Internet Drafts and RFCs. He is responsible for 50 issued patents. His background includes seven years as a full professor of Computer Engineering, tenure track, at Politecnico di Torino, Italy, and seven years as a researcher at the CNR (Italian National Council for Scientific Research). For the past 20 years, he has been in Silicon Valley where, in the position of Cisco Fellow, he was an architect of the Cisco Catalyst family of network switches, of the Cisco MDS family of storage networking switches, of the Nexus family of data center switches, and the Cisco Unified Computing System (UCS). Silvano is currently a Fellow with Pensando Systems.
Preface
Chapter 1: Introduction to Distributed Platforms
1.1 The Need for a Distributed Services Platform
1.2 The Precious CPU Cycles
1.3 The Case for Domain-Specific Hardware
1.4 Using Appliances
1.5 Attempts at Defining a Distributed Services Platform
1.6 Requirements for a Distributed Services Platform
1.7 Summary
Chapter 2: Network Design
2.1 Bridging and Routing
2.1.1 L2 Forwarding
2.1.2 L3 Forwarding
2.1.3 LPM Forwarding in Hardware
2.1.4 VRF
2.2 Clos Topology
2.3 Overlays
2.3.1 IP in IP
2.3.2 GRE
2.3.3 Modern Encapsulations
2.3.4 VXLAN
2.3.5 MTU Considerations
2.4 Secure Tunnels
2.5 Where to Terminate the Encapsulation
2.6 Segment Routing
2.7 Using Discrete Appliance for Services
2.7.1 Tromboning with VXLAN
2.7.2 Tromboning with VRF
2.7.3 Hybrid Tromboning
2.8 Cache-Based Forwarding
2.9 Generic Forwarding Table
2.10 Summary
2.11 Bibliography
Chapter 3: Virtualization
3.1 Virtualization and Clouds
3.2 Virtual Machines and Hypervisors
3.2.1 VMware ESXi
3.2.2 Hyper-V
3.2.3 QEMU
3.2.4 KVM
3.2.5 XEN
3.3 Containers
3.3.1 Docker and Friends
3.3.2 Kata Containers
3.3.3 Container Network Interface
3.3.4 Kubernetes
3.4 The Microservice Architecture
3.4.1 REST API
3.4.2 gRPC
3.5 OpenStack
3.6 NFV
3.7 Summary
3.8 Bibliography
Chapter 4: Network Virtualization Services
4.1 Introduction to Networking Services
4.2 Software-Defined Networking
4.2.1 OpenFlow
4.2.2 SD-WAN
4.2.3 gRIBI
4.2.4 Data Plane Development Kit (DPDK)
4.3 Virtual Switches
4.3.1 Open vSwitch (OVS)
4.3.2 tc-flower
4.3.3 DPDK RTE Flow Filtering
4.3.4 VPP (Vector Packet Processing)
4.3.5 BPF and eBPF
4.3.6 XDP
4.3.7 Summary on Virtual Switches
4.4 Stateful NAT
4.5 Load Balancing
4.6 Troubleshooting and Telemetry
4.7 Summary
4.8 Bibliography
Chapter 5: Security Services
5.1 Distributed Firewalls
5.2 Microsegmentation
5.3 TLS Everywhere
5.4 Symmetric Encryption
5.5 Asymmetric Encryption
5.6 Digital Certificates
5.7 Hashing
5.8 Secure Key Storage
5.9 PUF
5.10 TCP/TLS/HTTP Implementation
5.11 Secure Tunnels
5.11.1 IPsec
5.11.2 TLS
5.11.3 DTLS
5.12 VPNs
5.13 Secure Boot
5.14 Summary
5.15 Bibliography
Chapter 6: Distributed Storage and RDMA Services
6.1 RDMA and RoCE
6.1.1 RDMA Architecture Overview
6.1.2 RDMA Transport Services
6.1.3 RDMA Operations
6.1.4 RDMA Scalability
6.1.5 RoCE
6.1.6 RoCE vs iWARP
6.1.7 RDMA Deployments
6.1.8 RoCEv2 and Lossy Networks
6.1.9 Continued Evolution of RDMA
6.2 Storage
6.2.1 The Advent of SSDs
6.2.2 NVMe over Fabrics
6.2.3 Data Plane Model of Storage Protocols
6.2.4 Remote Storage Meets Virtualization
6.2.5 Distributed Storages Services
6.2.6 Storage Security
6.2.7 Storage Efficiency
6.2.8 Storage Reliability
6.2.9 Offloading and Distributing Storage Services
6.2.10 Persistent Memory as a New Storage Tier
6.3 Summary
6.4 Bibliography
Chapter 7: CPUs and Domain-Specific Hardware
7.1 42 Years of Microprocessor Trend Data
7.2 Moore’s Law
7.3 Dennard Scaling
7.4 Amdahl’s Law
7.5 Other Technical Factors
7.6 Putting It All Together
7.7 Is Moore’s Law Dead or Not?
7.8 Domain-specific Hardware
7.9 Economics of the Server
7.10 Summary
7.11 Bibliography
Chapter 8: NIC Evolution
8.1 Understanding Server Buses
8.2 Comparing NIC Form Factors
8.2.1 PCI Plugin Cards
8.2.2 Proprietary Mezzanine Cards
8.2.3 OCP Mezzanine Cards
8.2.4 Lan On Motherboard
8.3 Looking at the NIC Evolution
8.4 Using Single Root Input/Output Virtualization
8.5 Using Virtual I/O
8.6 Defining “SmartNIC”
8.7 Summary
8.8 Bibliography
Chapter 9: Implementing a DS Platform
9.1 Analyzing the Goals for a Distributed Services Platform
9.1.1 Services Everywhere
9.1.2 Scaling
9.1.3 Speed
9.1.4 Low Latency
9.1.5 Low Jitter
9.1.6 Minimal CPU Load
9.1.7 Observability and Troubleshooting Capability
9.1.8 Manageability
9.1.9 Host Mode versus Network Mode
9.1.10 PCIe Firewall
9.2 Understanding Constraints
9.2.1 Virtualized versus Bare-metal Servers
9.2.2 Greenfield versus Brownfield Deployment
9.2.3 The Drivers
9.2.4 PCIe-only Services
9.2.5 Power Budget
9.3 Determining the Target User
9.3.1 Enterprise Data Centers
9.3.2 Cloud Providers and Service Providers
9.4 Understanding DSN Implementations
9.4.1 DSN in Software
9.4.2 DSN Adapter
9.4.3 DSN Bump-in-the-Wire
9.4.4 DSN in Switch
9.4.5 DSNs in an Appliance
9.5 Summary
9.6 Bibliography
Chapter 10: DSN Hardware Architectures
10.1 The Main Building Blocks of a DSN
10.2 Identifying the Silicon Sweet Spot
10.2.1 The 16 nm Process
10.2.2 The 7 nm Process
10.3 Choosing an Architecture
10.4 Having a Sea of CPU Cores
10.5 Understanding Field-Programmable Gate Arrays
10.6 Using Application-Specific Integrated Circuits
10.7 Determining DSN Power Consumption
10.8 Determining Memory Needs
10.8.1 Host Memory
10.8.2 External DRAM
10.8.3 On-chip DRAM
10.8.4 Memory Bandwidth Requirements
10.9 Summary
10.10 Bibliography
Chapter 11: The P4 Domain-Specific Language
11.1 P4 Version 16
11.2 Using the P4 Language
11.3 Getting to Know the Portable Switch Architecture
11.4 Looking at a P4 Example
11.5 Implementing the P4Runtime API
11.6 Understanding the P4 INT
11.7 Extending P4
11.7.1 Portable NIC Architecture
11.7.2 Language Composability
11.7.3 Better Programming and Development Tools
11.8 Summary
11.9 Bibliography
Chapter 12: Management Architectures for DS Platforms
12.1 Architectural Traits of a Management Control Plane
12.2 Declarative Configuration
12.3 Building a Distributed Control Plane as a Cloud-Native Application
12.4 Monitoring and Troubleshooting
12.5 Securing the Management Control Plane
12.6 Ease of Deployment
12.7 Performance and Scale
12.8 Failure Handling
12.9 API Architecture
12.10 Federation
12.10.1 Scaling a Single SDSP
12.10.2 Distributed Multiple SDSPs
12.10.3 Federation of Multiple SDSPs
12.11 Scale and Performance Testing
12.12 Summary
12.13 Bibliography
Index
Chapter 1: Introduction to Distributed Platforms
1.1 The Need for a Distributed Services Platform
1.2 The Precious CPU Cycles
1.3 The Case for Domain-Specific Hardware
1.4 Using Appliances
1.5 Attempts at Defining a Distributed Services Platform
1.6 Requirements for a Distributed Services Platform
1.7 Summary
Chapter 2: Network Design
2.1 Bridging and Routing
2.1.1 L2 Forwarding
2.1.2 L3 Forwarding
2.1.3 LPM Forwarding in Hardware
2.1.4 VRF
2.2 Clos Topology
2.3 Overlays
2.3.1 IP in IP
2.3.2 GRE
2.3.3 Modern Encapsulations
2.3.4 VXLAN
2.3.5 MTU Considerations
2.4 Secure Tunnels
2.5 Where to Terminate the Encapsulation
2.6 Segment Routing
2.7 Using Discrete Appliance for Services
2.7.1 Tromboning with VXLAN
2.7.2 Tromboning with VRF
2.7.3 Hybrid Tromboning
2.8 Cache-Based Forwarding
2.9 Generic Forwarding Table
2.10 Summary
2.11 Bibliography
Chapter 3: Virtualization
3.1 Virtualization and Clouds
3.2 Virtual Machines and Hypervisors
3.2.1 VMware ESXi
3.2.2 Hyper-V
3.2.3 QEMU
3.2.4 KVM
3.2.5 XEN
3.3 Containers
3.3.1 Docker and Friends
3.3.2 Kata Containers
3.3.3 Container Network Interface
3.3.4 Kubernetes
3.4 The Microservice Architecture
3.4.1 REST API
3.4.2 gRPC
3.5 OpenStack
3.6 NFV
3.7 Summary
3.8 Bibliography
Chapter 4: Network Virtualization Services
4.1 Introduction to Networking Services
4.2 Software-Defined Networking
4.2.1 OpenFlow
4.2.2 SD-WAN
4.2.3 gRIBI
4.2.4 Data Plane Development Kit (DPDK)
4.3 Virtual Switches
4.3.1 Open vSwitch (OVS)
4.3.2 tc-flower
4.3.3 DPDK RTE Flow Filtering
4.3.4 VPP (Vector Packet Processing)
4.3.5 BPF and eBPF
4.3.6 XDP
4.3.7 Summary on Virtual Switches
4.4 Stateful NAT
4.5 Load Balancing
4.6 Troubleshooting and Telemetry
4.7 Summary
4.8 Bibliography
Chapter 5: Security Services
5.1 Distributed Firewalls
5.2 Microsegmentation
5.3 TLS Everywhere
5.4 Symmetric Encryption
5.5 Asymmetric Encryption
5.6 Digital Certificates
5.7 Hashing
5.8 Secure Key Storage
5.9 PUF
5.10 TCP/TLS/HTTP Implementation
5.11 Secure Tunnels
5.11.1 IPsec
5.11.2 TLS
5.11.3 DTLS
5.12 VPNs
5.13 Secure Boot
5.14 Summary
5.15 Bibliography
Chapter 6: Distributed Storage and RDMA Services
6.1 RDMA and RoCE
6.1.1 RDMA Architecture Overview
6.1.2 RDMA Transport Services
6.1.3 RDMA Operations
6.1.4 RDMA Scalability
6.1.5 RoCE
6.1.6 RoCE vs iWARP
6.1.7 RDMA Deployments
6.1.8 RoCEv2 and Lossy Networks
6.1.9 Continued Evolution of RDMA
6.2 Storage
6.2.1 The Advent of SSDs
6.2.2 NVMe over Fabrics
6.2.3 Data Plane Model of Storage Protocols
6.2.4 Remote Storage Meets Virtualization
6.2.5 Distributed Storages Services
6.2.6 Storage Security
6.2.7 Storage Efficiency
6.2.8 Storage Reliability
6.2.9 Offloading and Distributing Storage Services
6.2.10 Persistent Memory as a New Storage Tier
6.3 Summary
6.4 Bibliography
Chapter 7: CPUs and Domain-Specific Hardware
7.1 42 Years of Microprocessor Trend Data
7.2 Moore’s Law
7.3 Dennard Scaling
7.4 Amdahl’s Law
7.5 Other Technical Factors
7.6 Putting It All Together
7.7 Is Moore’s Law Dead or Not?
7.8 Domain-specific Hardware
7.9 Economics of the Server
7.10 Summary
7.11 Bibliography
Chapter 8: NIC Evolution
8.1 Understanding Server Buses
8.2 Comparing NIC Form Factors
8.2.1 PCI Plugin Cards
8.2.2 Proprietary Mezzanine Cards
8.2.3 OCP Mezzanine Cards
8.2.4 Lan On Motherboard
8.3 Looking at the NIC Evolution
8.4 Using Single Root Input/Output Virtualization
8.5 Using Virtual I/O
8.6 Defining “SmartNIC”
8.7 Summary
8.8 Bibliography
Chapter 9: Implementing a DS Platform
9.1 Analyzing the Goals for a Distributed Services Platform
9.1.1 Services Everywhere
9.1.2 Scaling
9.1.3 Speed
9.1.4 Low Latency
9.1.5 Low Jitter
9.1.6 Minimal CPU Load
9.1.7 Observability and Troubleshooting Capability
9.1.8 Manageability
9.1.9 Host Mode versus Network Mode
9.1.10 PCIe Firewall
9.2 Understanding Constraints
9.2.1 Virtualized versus Bare-metal Servers
9.2.2 Greenfield versus Brownfield Deployment
9.2.3 The Drivers
9.2.4 PCIe-only Services
9.2.5 Power Budget
9.3 Determining the Target User
9.3.1 Enterprise Data Centers
9.3.2 Cloud Providers and Service Providers
9.4 Understanding DSN Implementations
9.4.1 DSN in Software
9.4.2 DSN Adapter
9.4.3 DSN Bump-in-the-Wire
9.4.4 DSN in Switch
9.4.5 DSNs in an Appliance
9.5 Summary
9.6 Bibliography
Chapter 10: DSN Hardware Architectures
10.1 The Main Building Blocks of a DSN
10.2 Identifying the Silicon Sweet Spot
10.2.1 The 16 nm Process
10.2.2 The 7 nm Process
10.3 Choosing an Architecture
10.4 Having a Sea of CPU Cores
10.5 Understanding Field-Programmable Gate Arrays
10.6 Using Application-Specific Integrated Circuits
10.7 Determining DSN Power Consumption
10.8 Determining Memory Needs
10.8.1 Host Memory
10.8.2 External DRAM
10.8.3 On-chip DRAM
10.8.4 Memory Bandwidth Requirements
10.9 Summary
10.10 Bibliography
Chapter 11: The P4 Domain-Specific Language
11.1 P4 Version 16
11.2 Using the P4 Language
11.3 Getting to Know the Portable Switch Architecture
11.4 Looking at a P4 Example
11.5 Implementing the P4Runtime API
11.6 Understanding the P4 INT
11.7 Extending P4
11.7.1 Portable NIC Architecture
11.7.2 Language Composability
11.7.3 Better Programming and Development Tools
11.8 Summary
11.9 Bibliography
Chapter 12: Management Architectures for DS Platforms
12.1 Architectural Traits of a Management Control Plane
12.2 Declarative Configuration
12.3 Building a Distributed Control Plane as a Cloud-Native Application
12.4 Monitoring and Troubleshooting
12.5 Securing the Management Control Plane
12.6 Ease of Deployment
12.7 Performance and Scale
12.8 Failure Handling
12.9 API Architecture
12.10 Federation
12.10.1 Scaling a Single SDSP
12.10.2 Distributed Multiple SDSPs
12.10.3 Federation of Multiple SDSPs
12.11 Scale and Performance Testing
12.12 Summary
12.13 Bibliography
Index
Preface
Chapter 1: Introduction to Distributed Platforms
1.1 The Need for a Distributed Services Platform
1.2 The Precious CPU Cycles
1.3 The Case for Domain-Specific Hardware
1.4 Using Appliances
1.5 Attempts at Defining a Distributed Services Platform
1.6 Requirements for a Distributed Services Platform
1.7 Summary
Chapter 2: Network Design
2.1 Bridging and Routing
2.1.1 L2 Forwarding
2.1.2 L3 Forwarding
2.1.3 LPM Forwarding in Hardware
2.1.4 VRF
2.2 Clos Topology
2.3 Overlays
2.3.1 IP in IP
2.3.2 GRE
2.3.3 Modern Encapsulations
2.3.4 VXLAN
2.3.5 MTU Considerations
2.4 Secure Tunnels
2.5 Where to Terminate the Encapsulation
2.6 Segment Routing
2.7 Using Discrete Appliance for Services
2.7.1 Tromboning with VXLAN
2.7.2 Tromboning with VRF
2.7.3 Hybrid Tromboning
2.8 Cache-Based Forwarding
2.9 Generic Forwarding Table
2.10 Summary
2.11 Bibliography
Chapter 3: Virtualization
3.1 Virtualization and Clouds
3.2 Virtual Machines and Hypervisors
3.2.1 VMware ESXi
3.2.2 Hyper-V
3.2.3 QEMU
3.2.4 KVM
3.2.5 XEN
3.3 Containers
3.3.1 Docker and Friends
3.3.2 Kata Containers
3.3.3 Container Network Interface
3.3.4 Kubernetes
3.4 The Microservice Architecture
3.4.1 REST API
3.4.2 gRPC
3.5 OpenStack
3.6 NFV
3.7 Summary
3.8 Bibliography
Chapter 4: Network Virtualization Services
4.1 Introduction to Networking Services
4.2 Software-Defined Networking
4.2.1 OpenFlow
4.2.2 SD-WAN
4.2.3 gRIBI
4.2.4 Data Plane Development Kit (DPDK)
4.3 Virtual Switches
4.3.1 Open vSwitch (OVS)
4.3.2 tc-flower
4.3.3 DPDK RTE Flow Filtering
4.3.4 VPP (Vector Packet Processing)
4.3.5 BPF and eBPF
4.3.6 XDP
4.3.7 Summary on Virtual Switches
4.4 Stateful NAT
4.5 Load Balancing
4.6 Troubleshooting and Telemetry
4.7 Summary
4.8 Bibliography
Chapter 5: Security Services
5.1 Distributed Firewalls
5.2 Microsegmentation
5.3 TLS Everywhere
5.4 Symmetric Encryption
5.5 Asymmetric Encryption
5.6 Digital Certificates
5.7 Hashing
5.8 Secure Key Storage
5.9 PUF
5.10 TCP/TLS/HTTP Implementation
5.11 Secure Tunnels
5.11.1 IPsec
5.11.2 TLS
5.11.3 DTLS
5.12 VPNs
5.13 Secure Boot
5.14 Summary
5.15 Bibliography
Chapter 6: Distributed Storage and RDMA Services
6.1 RDMA and RoCE
6.1.1 RDMA Architecture Overview
6.1.2 RDMA Transport Services
6.1.3 RDMA Operations
6.1.4 RDMA Scalability
6.1.5 RoCE
6.1.6 RoCE vs iWARP
6.1.7 RDMA Deployments
6.1.8 RoCEv2 and Lossy Networks
6.1.9 Continued Evolution of RDMA
6.2 Storage
6.2.1 The Advent of SSDs
6.2.2 NVMe over Fabrics
6.2.3 Data Plane Model of Storage Protocols
6.2.4 Remote Storage Meets Virtualization
6.2.5 Distributed Storages Services
6.2.6 Storage Security
6.2.7 Storage Efficiency
6.2.8 Storage Reliability
6.2.9 Offloading and Distributing Storage Services
6.2.10 Persistent Memory as a New Storage Tier
6.3 Summary
6.4 Bibliography
Chapter 7: CPUs and Domain-Specific Hardware
7.1 42 Years of Microprocessor Trend Data
7.2 Moore’s Law
7.3 Dennard Scaling
7.4 Amdahl’s Law
7.5 Other Technical Factors
7.6 Putting It All Together
7.7 Is Moore’s Law Dead or Not?
7.8 Domain-specific Hardware
7.9 Economics of the Server
7.10 Summary
7.11 Bibliography
Chapter 8: NIC Evolution
8.1 Understanding Server Buses
8.2 Comparing NIC Form Factors
8.2.1 PCI Plugin Cards
8.2.2 Proprietary Mezzanine Cards
8.2.3 OCP Mezzanine Cards
8.2.4 Lan On Motherboard
8.3 Looking at the NIC Evolution
8.4 Using Single Root Input/Output Virtualization
8.5 Using Virtual I/O
8.6 Defining “SmartNIC”
8.7 Summary
8.8 Bibliography
Chapter 9: Implementing a DS Platform
9.1 Analyzing the Goals for a Distributed Services Platform
9.1.1 Services Everywhere
9.1.2 Scaling
9.1.3 Speed
9.1.4 Low Latency
9.1.5 Low Jitter
9.1.6 Minimal CPU Load
9.1.7 Observability and Troubleshooting Capability
9.1.8 Manageability
9.1.9 Host Mode versus Network Mode
9.1.10 PCIe Firewall
9.2 Understanding Constraints
9.2.1 Virtualized versus Bare-metal Servers
9.2.2 Greenfield versus Brownfield Deployment
9.2.3 The Drivers
9.2.4 PCIe-only Services
9.2.5 Power Budget
9.3 Determining the Target User
9.3.1 Enterprise Data Centers
9.3.2 Cloud Providers and Service Providers
9.4 Understanding DSN Implementations
9.4.1 DSN in Software
9.4.2 DSN Adapter
9.4.3 DSN Bump-in-the-Wire
9.4.4 DSN in Switch
9.4.5 DSNs in an Appliance
9.5 Summary
9.6 Bibliography
Chapter 10: DSN Hardware Architectures
10.1 The Main Building Blocks of a DSN
10.2 Identifying the Silicon Sweet Spot
10.2.1 The 16 nm Process
10.2.2 The 7 nm Process
10.3 Choosing an Architecture
10.4 Having a Sea of CPU Cores
10.5 Understanding Field-Programmable Gate Arrays
10.6 Using Application-Specific Integrated Circuits
10.7 Determining DSN Power Consumption
10.8 Determining Memory Needs
10.8.1 Host Memory
10.8.2 External DRAM
10.8.3 On-chip DRAM
10.8.4 Memory Bandwidth Requirements
10.9 Summary
10.10 Bibliography
Chapter 11: The P4 Domain-Specific Language
11.1 P4 Version 16
11.2 Using the P4 Language
11.3 Getting to Know the Portable Switch Architecture
11.4 Looking at a P4 Example
11.5 Implementing the P4Runtime API
11.6 Understanding the P4 INT
11.7 Extending P4
11.7.1 Portable NIC Architecture
11.7.2 Language Composability
11.7.3 Better Programming and Development Tools
11.8 Summary
11.9 Bibliography
Chapter 12: Management Architectures for DS Platforms
12.1 Architectural Traits of a Management Control Plane
12.2 Declarative Configuration
12.3 Building a Distributed Control Plane as a Cloud-Native Application
12.4 Monitoring and Troubleshooting
12.5 Securing the Management Control Plane
12.6 Ease of Deployment
12.7 Performance and Scale
12.8 Failure Handling
12.9 API Architecture
12.10 Federation
12.10.1 Scaling a Single SDSP
12.10.2 Distributed Multiple SDSPs
12.10.3 Federation of Multiple SDSPs
12.11 Scale and Performance Testing
12.12 Summary
12.13 Bibliography
Index
Chapter 1: Introduction to Distributed Platforms
1.1 The Need for a Distributed Services Platform
1.2 The Precious CPU Cycles
1.3 The Case for Domain-Specific Hardware
1.4 Using Appliances
1.5 Attempts at Defining a Distributed Services Platform
1.6 Requirements for a Distributed Services Platform
1.7 Summary
Chapter 2: Network Design
2.1 Bridging and Routing
2.1.1 L2 Forwarding
2.1.2 L3 Forwarding
2.1.3 LPM Forwarding in Hardware
2.1.4 VRF
2.2 Clos Topology
2.3 Overlays
2.3.1 IP in IP
2.3.2 GRE
2.3.3 Modern Encapsulations
2.3.4 VXLAN
2.3.5 MTU Considerations
2.4 Secure Tunnels
2.5 Where to Terminate the Encapsulation
2.6 Segment Routing
2.7 Using Discrete Appliance for Services
2.7.1 Tromboning with VXLAN
2.7.2 Tromboning with VRF
2.7.3 Hybrid Tromboning
2.8 Cache-Based Forwarding
2.9 Generic Forwarding Table
2.10 Summary
2.11 Bibliography
Chapter 3: Virtualization
3.1 Virtualization and Clouds
3.2 Virtual Machines and Hypervisors
3.2.1 VMware ESXi
3.2.2 Hyper-V
3.2.3 QEMU
3.2.4 KVM
3.2.5 XEN
3.3 Containers
3.3.1 Docker and Friends
3.3.2 Kata Containers
3.3.3 Container Network Interface
3.3.4 Kubernetes
3.4 The Microservice Architecture
3.4.1 REST API
3.4.2 gRPC
3.5 OpenStack
3.6 NFV
3.7 Summary
3.8 Bibliography
Chapter 4: Network Virtualization Services
4.1 Introduction to Networking Services
4.2 Software-Defined Networking
4.2.1 OpenFlow
4.2.2 SD-WAN
4.2.3 gRIBI
4.2.4 Data Plane Development Kit (DPDK)
4.3 Virtual Switches
4.3.1 Open vSwitch (OVS)
4.3.2 tc-flower
4.3.3 DPDK RTE Flow Filtering
4.3.4 VPP (Vector Packet Processing)
4.3.5 BPF and eBPF
4.3.6 XDP
4.3.7 Summary on Virtual Switches
4.4 Stateful NAT
4.5 Load Balancing
4.6 Troubleshooting and Telemetry
4.7 Summary
4.8 Bibliography
Chapter 5: Security Services
5.1 Distributed Firewalls
5.2 Microsegmentation
5.3 TLS Everywhere
5.4 Symmetric Encryption
5.5 Asymmetric Encryption
5.6 Digital Certificates
5.7 Hashing
5.8 Secure Key Storage
5.9 PUF
5.10 TCP/TLS/HTTP Implementation
5.11 Secure Tunnels
5.11.1 IPsec
5.11.2 TLS
5.11.3 DTLS
5.12 VPNs
5.13 Secure Boot
5.14 Summary
5.15 Bibliography
Chapter 6: Distributed Storage and RDMA Services
6.1 RDMA and RoCE
6.1.1 RDMA Architecture Overview
6.1.2 RDMA Transport Services
6.1.3 RDMA Operations
6.1.4 RDMA Scalability
6.1.5 RoCE
6.1.6 RoCE vs iWARP
6.1.7 RDMA Deployments
6.1.8 RoCEv2 and Lossy Networks
6.1.9 Continued Evolution of RDMA
6.2 Storage
6.2.1 The Advent of SSDs
6.2.2 NVMe over Fabrics
6.2.3 Data Plane Model of Storage Protocols
6.2.4 Remote Storage Meets Virtualization
6.2.5 Distributed Storages Services
6.2.6 Storage Security
6.2.7 Storage Efficiency
6.2.8 Storage Reliability
6.2.9 Offloading and Distributing Storage Services
6.2.10 Persistent Memory as a New Storage Tier
6.3 Summary
6.4 Bibliography
Chapter 7: CPUs and Domain-Specific Hardware
7.1 42 Years of Microprocessor Trend Data
7.2 Moore’s Law
7.3 Dennard Scaling
7.4 Amdahl’s Law
7.5 Other Technical Factors
7.6 Putting It All Together
7.7 Is Moore’s Law Dead or Not?
7.8 Domain-specific Hardware
7.9 Economics of the Server
7.10 Summary
7.11 Bibliography
Chapter 8: NIC Evolution
8.1 Understanding Server Buses
8.2 Comparing NIC Form Factors
8.2.1 PCI Plugin Cards
8.2.2 Proprietary Mezzanine Cards
8.2.3 OCP Mezzanine Cards
8.2.4 Lan On Motherboard
8.3 Looking at the NIC Evolution
8.4 Using Single Root Input/Output Virtualization
8.5 Using Virtual I/O
8.6 Defining “SmartNIC”
8.7 Summary
8.8 Bibliography
Chapter 9: Implementing a DS Platform
9.1 Analyzing the Goals for a Distributed Services Platform
9.1.1 Services Everywhere
9.1.2 Scaling
9.1.3 Speed
9.1.4 Low Latency
9.1.5 Low Jitter
9.1.6 Minimal CPU Load
9.1.7 Observability and Troubleshooting Capability
9.1.8 Manageability
9.1.9 Host Mode versus Network Mode
9.1.10 PCIe Firewall
9.2 Understanding Constraints
9.2.1 Virtualized versus Bare-metal Servers
9.2.2 Greenfield versus Brownfield Deployment
9.2.3 The Drivers
9.2.4 PCIe-only Services
9.2.5 Power Budget
9.3 Determining the Target User
9.3.1 Enterprise Data Centers
9.3.2 Cloud Providers and Service Providers
9.4 Understanding DSN Implementations
9.4.1 DSN in Software
9.4.2 DSN Adapter
9.4.3 DSN Bump-in-the-Wire
9.4.4 DSN in Switch
9.4.5 DSNs in an Appliance
9.5 Summary
9.6 Bibliography
Chapter 10: DSN Hardware Architectures
10.1 The Main Building Blocks of a DSN
10.2 Identifying the Silicon Sweet Spot
10.2.1 The 16 nm Process
10.2.2 The 7 nm Process
10.3 Choosing an Architecture
10.4 Having a Sea of CPU Cores
10.5 Understanding Field-Programmable Gate Arrays
10.6 Using Application-Specific Integrated Circuits
10.7 Determining DSN Power Consumption
10.8 Determining Memory Needs
10.8.1 Host Memory
10.8.2 External DRAM
10.8.3 On-chip DRAM
10.8.4 Memory Bandwidth Requirements
10.9 Summary
10.10 Bibliography
Chapter 11: The P4 Domain-Specific Language
11.1 P4 Version 16
11.2 Using the P4 Language
11.3 Getting to Know the Portable Switch Architecture
11.4 Looking at a P4 Example
11.5 Implementing the P4Runtime API
11.6 Understanding the P4 INT
11.7 Extending P4
11.7.1 Portable NIC Architecture
11.7.2 Language Composability
11.7.3 Better Programming and Development Tools
11.8 Summary
11.9 Bibliography
Chapter 12: Management Architectures for DS Platforms
12.1 Architectural Traits of a Management Control Plane
12.2 Declarative Configuration
12.3 Building a Distributed Control Plane as a Cloud-Native Application
12.4 Monitoring and Troubleshooting
12.5 Securing the Management Control Plane
12.6 Ease of Deployment
12.7 Performance and Scale
12.8 Failure Handling
12.9 API Architecture
12.10 Federation
12.10.1 Scaling a Single SDSP
12.10.2 Distributed Multiple SDSPs
12.10.3 Federation of Multiple SDSPs
12.11 Scale and Performance Testing
12.12 Summary
12.13 Bibliography
Index