Evolution of OpenCache: an OpenSource Virtual Content Distribution Network (vCDN) Platform Daniel King [email protected] Matthew Broadbent [email protected] David Hutchison [email protected] Network Evolution SDN, A reality check • Why Software Defined Networking? – – There‘s a hype in the industry! (no, really?) Where are we on the hype cycle? • Dispelling some myths – SDN is not a provisioning system or configuration management tool • SDN is not a new protocol • You do not buy “off the shelf” SDN – It‘s an architectural approach 2 Cloud Evolution Defining Network Functions Virtualization • Operators use a variety of proprietary appliances to provide network functions when delivering services • Deploying a new network function often requires new hardware components – Integrating new equipment into the network takes space, power, and the technical knowledge – This problem is compounded by function and technology lifecycles which are becoming shorter as innovation accelerates • The concept of virtualization is well-known and has been used for many years – Operating system virtualization (Virtual Machines) – Computational and application resource virtualisation (Cloud Computing) • Network Function Virtualization – Virtualize the class of network function – Replace specialist hardware with instances of virtual services provided on service nodes in the network – Enables high volume services and functions on generic platforms 3 Content is King The Content Distribution Network (CDN) • Delivery of content, especially of video, is one of the major challenges of all operator networks due to massive growing amount of traffic. – Growth of video traffic is driven by the shift from broadcast media to unicast delivery via IP. • Complementary to the growth of today’s Video Traffic – On-demand Content Services to internet end-users, with similar quality constraints as for traditional TV Service of Network Operators • Operators to deploy their proprietary cache nodes into the ISP network. – CDN cache nodes are dedicated physical appliances or software with specific requirements on standard but dedicated hardware. • CDN controller objective is to select a cache node (or a pool of cache nodes) for answering to the end-user request, and then redirect the end-user to the selected Cache Node. – – The Cache Node shall answer to the end-user request and deliver the requested content to the end user. The CDN controller is a centralized component, and CDN cache nodes are distributed within the Network and in N-PoPs. 4 CDN Architecture Key Components Functional Components of the CDN – Content Distribution Management • Deploy content as close to each user as possible. – Content Routing • Route the users request for content to the closest available content store or content engine. – Content Switching & Load Balancing • Distribute user requests across one or multiple servers. – Surrogate servers • Mirrored web content servers – Content Proxies • • Master proxy Cache proxy – Content DNS servers – GeoIP information servers – Content Peering Gateways 5 SDN & NFV “Killer Application” The Virtualized CDN (vCDN) • SDN Network Control – – Dynamic connectivity Elastic bandwidth • NFV Flexibility, Performance & Predictability – – – Performance: Mean Response Time, Latency, Hit Ratio Percentage, Number of Completed Requests, Rejection rate and Mean CDN load. Dimensioning: remaining stable whatever the use of virtualized HW resources for CDN components Resource management: allow the right balance of network i/o to CPU power to storage i/o performance (e.g., RAM and HDD). • Efficient use of resources (storage) – Fulfil specific storage density requirements, e.g. to cache a large catalog of popular content. • Deployment & Operational tools – Compliance of cache nodes with main monitoring and reporting requirements (e.g., SNMP, syslog, etc.) so that operator is able to manage different types of cache nodes together for a Delivery Service. • Content Management – Ability to select specific cached content (e.g., video/HTTP) and replicate/duplicate these selected content items during delivery via virtual switching to a Quality of Experience (QoE) virtualized function without degrading the overall performance of the virtualized CDN function 6 SDN & NFV “Killer Application” Content Distribution Network (CDN) • Design principles require an efficient, reliable and responsive CDN – Fault-tolerant network with appropriate load balancing – Performance of a CDN is typically characterized by the response time (i.e. latency) perceived by the end-users – Slow response time is the single greatest contributor to users abandoning content and web sites and processes – The performance of a CDN is affected by • • • • Distributed content location Switching mechanism Data replication and caching strategies Reliable functions and network connectivity 7 OpenCache A Software-defined Content Caching Platform • “OpenCache” a vCDN Platform • • • • Open API facilitating control of a distributed cache nodes Deployment via online and “real-time” software interface An application that bridges SDN and NFV capabilities Designed to be deployed anywhere in a network; one codebase • OpenCache nodes can load balanced, support fail-over and matched to anticipated demands • Operates in a controller-node architecture and maps to ETSI NFV architecture • The API is currently exposed in full as an external northbound interface, enabling applications to be built on-top of a cache deployment – QoE-driven content placement – Cross-layer load balancing • Feasible to implement a standalone controller or build a plugin for the existing OpenCache controller 8 OpenCache Control & Orchestration Reference Controller Architecture Network Control Orchestrator NFV Management Operational Support System (OSS) Orchestrator Os-Ma Element Management System (EMS) ABNO Controller GMPLS VNF 1 OC Load Balancer VNF 2 OC Cache Node VNF 3 OC Fail-over Monitor VNF Manager vCDN Controller Ve-Vnfm Vn-Nf Vn-Nf Virtual Compute Virtual Compute Virtual Compute Virtual Storage Virtual Storage Virtual Storage Virtual Network Virtual Network Virtual Network Virtualisation Layer Flexible Optical Switches VI-Ha VI-Ha Storage Hardware Compute Hardware NFV Infrastructure 9 Network Hardware Nf-Vi Virtual Infrastructure Manager OpenStack CDN Control & Orchestration Other Notable Controllers Exist • Network Control – – – – – Floodlight RYU POX Trema ABNO • IT Resource Management – Cloud Stack – Open Mano 10 OpenCache Current Capability • OpenCache Expressions • An OpenCache expression describes a set of content which an operator desires to be cached • Content will only be cached if it is explicitly included in an expression • A single definition can express multiple locations to be served by the same service • Cache Functions • create – build a new OpenCache node • destroy – destroy an OpenCache node • start – create a new service on a given node, caching content matching the given expression • stop – destroy a service, removing the stored content • pause – destroy a service, without removing the stored content • move – modify the forwarding layer to route requests to a different node • fetch – retrieve the content from a remote location before a cache-miss even occurs • seed – define identical content stored a multiple alternative locations 11 vCDN Evolution Variety of Research Challenges • Workload Management • Resource Management & Optimisation • Service Level Agreement Management • Performance Monitoring, Measurement & Benchmarking • Resilience • Security 12 vCDN Function Placement Workload Management • Which services/resources to use for a CDN activity, when, where, how? • A particular consumer, application, or function needs for an activity one or several services/resources under given constraints: – – – – – – – Policy Trust Security Timing & Economics Functionality & Service level Application-specifics & Inter-dependencies Scheduling and Access Policies 13 vCDN Function Placement Resource Management & Optimisation • CDN Resource representation – Meta models for VNFs and network infrastructure • Consideration and operation of various optimisation goals: – – – – – – Time Performance Cost Reliability Minimising the resource footprint Power Consumption 14 vCDN Quality of Experience Service Level Agreement Management • Translate consumer demands into a service and application definition – Encode performance qualities – Specify resource and QoS requirements – Mask resource details, queue data and current workload • Combination and management of several SLAs relevant at various levels – High-level, human-readable SLAs – Technology SLAs within the middleware to guarantee service provisioning 15 vCDN Performance Monitoring, Measurement & Benchmarking • Infrastructure analytics and visualisation – Existing web-based GUI used to interact with an OpenCache controller – Visualises OpenCache nodes in real-time; hits and misses per second, object size, resource utilisation etc. • Composite metrics • Simulations and “what if” scenario testing • Hardware performance monitoring 16 vCDN Resilience Key Requirements & Challenges • Definition of VNF Resilience Classes – Application-based, priority, etc. • VNF Resource Monitoring – Capacity (memory and CPU) limitations per instance to avoid overbooking, and failure of end-to-end services • Automatic Detection of Application Failure, or Performance Degradation – – Proactive health checking should also be supported Isolation and reporting of failures • Failover to other VNFs or physical function – – Storage and transfer of state information within the VSN Replication of state for active/standby network functions • Resilience of VSN Network Connectivity – – – Automatic detection of link failure Failover to another usable link Automated routing recovery These capabilities are not limited to vCDN’s! 17 vCDN Resilience Role of Standards Organisations • Solving the VNF Resilience Requirements – – – – – – Auto Scale of Virtual Network Function Instances Reliable Network Connectivity between Network Nodes Existing Operating Virtual Network Function Instance Replacement Combining Different VNF Functions (a VNF Set) VNF Resilience Classes Multi-tier Network Service • IETF VNF Pool datatracker.ietf.org/wg/vnfpool/charter/ – – – Requirements and Use Cases for Virtual Network Functions draft-xia-vnfpool-use-cases-01 Virtualisation of Mobile Core Network Use Case draft-king-vnfpool-mobile-use-case-01 Virtualisation of Content Distribution Network Use Case draft-aranda-vnfpool-cdn-use-case-00 18 Thank You! Any comments or questions are welcome. Daniel King [email protected] Matthew Broadbent [email protected] David Hutchison [email protected] 19
© Copyright 2024