Transparent Flow Migration for NFV


摘要

因为SDN提供的灵活性,NF之间存在着流量的迁入和迁出问题。而且NF也要根据相关的状态信息处理数据包,所以流量迁移必须满足以下两点要求:

  1. 保持数据包和状态的迁移顺序,必须获取状态才能处理数据包。
  2. 想都不用想,这点一定是低开销、低时延~

目前现有的流量迁移架构,把流量迁移和状态迁移耦合在一起,这种架构不能实现安全、高效、低开销的迁移。
于是本篇论文提出了一个流量迁移架构,叫TFM(Transparent Flow Migration ),显然,TFM和以往的架构相反,解藕流量迁移和状态迁移,这样的好处是可以对两个过程分别的进行优化,并且实现两个过程的并行处理。
TFM通过TFM box实现了一系列的优化,TFM box是一个中间层,它可以提供NF之间透明的数据包迁移

INTRODUCTION

Background and Motivation

流量迁入迁出的目的是为了节约资源、规避SLA惩罚、负载均衡。
NF对流量的处理往往依赖于状态,在迁移后如果没有相应的状态信息,将很难重新对某条流量起到路由作用。
流量迁移的几种方法:

  1. 待源NF处理完所有in-flows,然后把新来的流量全部转移到目标NF。
    缺点:时间未知性,根本就无法预知当前处理的in-flow何时结束。举个例子:当一个NF已经过载并无法满足SLA,这时候还要它处理完剩余的in-flows,这显然是不合理的。而且即将被迁入NF也要等待它处理完剩余的in-flows,造成了资源的浪费。
  2. 立刻迁移,为了满足NF的带状态处理,数据包迁移要伴随着状态迁移一起进行。
    缺点:由于流量是源源不断的流入NF,这种方式比较害怕目标NF没有开启的情况。

流量迁移目前存在的问题

  • 如何协调状态迁移和数据包迁移,并确保状态一致性,同时提高效率和最小化开销。

设计一个合理的流量迁移架构必须满足以下要求

  • 状态一致性:迁移前后源NF和目标NF状态保持一致。
  • 保证安全性:无损,保序。
  • 高效率迁移:限的时间内完成,以减少迁移对控制和数据平面的影响。
  • 实现低开销:不用说我们都懂。

Summary and Limitations of Prior Art

现有的流量迁移架构有两个:Split/Merge和OpenNF。(状态迁移和数据包迁移耦合

  • 共同点:
    通过一个中央控制器缓存状态迁移过程中到来的数据包,这样不会丢包,也不会丢失状态信息。等待状态迁移结束之后,把缓存的数据包发送给目标NF。但需要中央控制器拥有足够多的缓冲资源
  • 差异点:
    两种方法的区别在于in-transit数据包处理(in-transit数据包:实例A迁移到实例B当,实例A开始迁移的时候它还有一些数据报等待处理或者正在发往目标NF的路上,但是不会被A处理因为迁移开始了)

    • Split/Merge:直接丢弃in-transit数据包,
    • OpenNF:将in-transit数据包重定向到控制器,然后交给目的NF(三角形路由),但是这种操作可能会引起额外的迁移时间

以往方法把状态迁移和数据包迁移耦合在一起(按照顺序执行),虽然实现了状态的一致性,但是存在着以下两个问题:

  1. 额外的时间:因为在状态迁移的过程中到达的数据包无法得到处理,增加了它们的处理时延。
  2. 更重要的问题是,执行迁出操作时不能保证安全性(不丢包、保持包的顺序)。这是因为已经超载的源NF在状态迁移完毕之前必须继续处理进入的数据包。这样会造成很高的丢包率。而且超载的源NF还加剧了包处理线程状态迁移线程之间的锁争用,这也会增加额外的时间开销。

TFM

TFM把状态迁移和数据包迁移解耦,这样带来的好处是:

  1. 二者可以并行,状态迁移时同时完成两件事情:

    • 告诉switch立刻把要迁移的流量转移到目标NF。
    • 告诉源NF立刻开始向目标NF传输状态。
  2. 不必等待状态迁移完毕结束,就可以提前转移数据包,避免“三角形路由”,节约了时间和空间。

实现TFM的三个技术挑战:

  1. 解决带状态的数据包处理问题:
    根据TFM的做法,状态迁移开始时,所有的数据流立刻转向到目标NF。那么这就要求源NF和目的NF用对应的状态信息来处理对应的数据包。如何区分状态迁移前的数据包和状态迁移后的数据包
    解决方案
    打标签,通过标签来标记迁移前数据包和迁移后数据包,首先处理迁移前数据包,接着处理迁移后数据包。
  2. 保持状态迁移的透明性:
    处理被状态迁移所影响的数据包,最简单的方法就是将它们转移到目标NF并进行缓存,但是这需要NF具备相应的功能,但是增加这些功能会影响NF的性能。
    解决方案
    加入一个TFM box(数据包处理单元)来实现这些功能。(缓存、区分数据包、协调状态迁移的过程),TFM box在那些被迁移的流量到达NF之前,直接把它们处理掉,也就是说TFM box是被专门用来处理迁移流量的,这对源NF和目标NF来说是透明的。
  3. 最小化迁移开销:
    各个TFM box之间交换状态信息,需要额外的开销(生成携带控制信息的数据包,通过三角形路由的形式传递)。
    解决方案
    通过流量来携带控制信息,在数据平面范围内解决这个问题。

DESIGN OVERVIEW


  • TFM Controller:提供北向接口,以及Flow Migration Orchestrator。
  • Flow Migration Orchestrator:由State Manager、Flow Manager、Forwarding Manager组成,提供状态迁移期间的:状态迁移(State Manager)、数据包迁移(Flow Manager)以及流量转向功能(Forwarding Manager)。
  • State Manager:依靠现有的南向API工作。
  • Flow Manager:管理TFM box。
  • TFM box:在状态迁移期间,为被迁移的流量提供数据包缓存,和处理。
  • Forwarding Manager:调用SDN控制器,在状态迁移开始时,更改流表项,迅速的把要迁移的流量导向到目标NF。

总体功能细化分成三部分可以增加TFM的灵活性,三者间相互独立,改变一个并不会影响其他两个:

Working with a new NF with a specific southbound state import/export API only needs to update the State manager; using a new type of OpenFlow or SDN controller only needs to change the forwarding manager,

Transparent Flow Migration for NFV的更多相关文章

  1. Optimized Flow Migration for NFV Elasticity Control

    NFV弹性控制中的流迁移优化 ABSTRACT 基于动态创建和移除网络功能实例,NFV在网络功能控制上有很大的弹性.比如,网络功能和并,网络功能拆分,负载均衡等等. 那么为了实现弹性控制,就需要网络流 ...

  2. ORADEBUG DOC 12.1.0.2

     https://berxblog.blogspot.com/2015/01/oradebug-doc-12102.html   this is just an online docu of ORAD ...

  3. Oracle Created Database Users: Password, Usage and Files References (文档 ID 160861.1)

    This document is no longer actively maintained, for info on specific (new) users in recent product e ...

  4. Ping CAP CTO、Codis作者谈redis分布式解决方案和分布式KV存储

    此文根据[QCON高可用架构群]分享内容,由群内[编辑组]志愿整理,转发请注明出处. 苏东旭,Ping CAP CTO,Codis作者 开源项目Codis的co-author黄东旭,之前在豌豆荚从事i ...

  5. [转载] Codis作者黄东旭细说分布式Redis架构设计和踩过的那些坑们

    原文: http://mp.weixin.qq.com/s?__biz=MzAwMDU1MTE1OQ==&mid=208733458&idx=1&sn=691bfde670fb ...

  6. 豌豆夹Redis解决方式Codis源代码剖析:Proxy代理

    豌豆夹Redis解决方式Codis源代码剖析:Proxy代理 1.预备知识 1.1 Codis Codis就不详细说了,摘抄一下GitHub上的一些项目描写叙述: Codis is a proxy b ...

  7. ORACLE 11G R2 RAC classical install OGG12.1(LINUX) 经典抽取模式单项同步配置OGG12.1

    博文结构图如下: 一.环境描述以及注意事项 1.1 环境简介 IP 系统 Oracle版本 OGG版本 源端 172.16.10.16/36 RHEL6.5 oracle11204 12.1 目标端 ...

  8. 豌豆夹Redis解决方案Codis源码剖析:Proxy代理

    豌豆夹Redis解决方案Codis源码剖析:Proxy代理 1.预备知识 1.1 Codis Codis就不详细说了,摘抄一下GitHub上的一些项目描述: Codis is a proxy base ...

  9. Oracle 所有字典

    select * from DBA_CONS_COLUMNS ; ---Information about accessible columns in constraint definitions s ...

随机推荐

  1. vim8配置python3补全

    安装Python3 卸载编译安装的python3 rm -rf /usr/local/lib/python3.7/ rm -rf /usr/local/bin/2to3* rm -rf /usr/lo ...

  2. Contract Helper

    using System; using Microsoft.Xrm.Sdk; using Microsoft.Crm.Sdk.Messages; using Microsoft.Xrm.Sdk.Que ...

  3. KKT原理以及SVM数学的理论推导分析

    一直很好奇机器学习实战中的SVM优化部分的数学运算式是如何得出的,如何转化成了含有内积的运算式,今天上了一节课有了让我很深的启发,也明白了数学表达式推导的全过程. 对于一个SVM问题,优化的关键在于 ...

  4. ajax渲染swiper问题

    由于ajax异步请求的关系,所以之前将swiper初始化写在请求外面时总是不能达到效果.下面是能正常渲染的效果示例: $http({ method:"GET", url:" ...

  5. 百度地图api 常用 例子

    功能一:获取map地图窗口的可视区域: var map = new BMap.Map("allmap");            // 创建Map实例 map.centerAndZ ...

  6. 优步uber司机申请了为什么一直没有通过审核,帐号也显示未激活

    优步uber现在是越来越火,申请注册成为优步uber司机的人数也日剧增多,申请了的车主都知道,申请后要等待审核,审核通过才可以激活帐号,快的运气好的,三五天不到一个星期就激活了,慢点的得大半个月,还有 ...

  7. c++ 参数个数可变的函数

    #include <stdio.h> #include <string.h> #include <stdarg.h> int addnum(int i,...) { ...

  8. Android:反编译apk

    一.所需工具 1. apktool (1)作用:获取资源文件,例如图片.布局文件 (2)下载地址:https://bitbucket.org/iBotPeaches/apktool/downloads ...

  9. 抓包工具Charles学习总结

    最近由于工作需要对App进行测试,功能方面还好说,但是在网络测试方面遇到了一些问题.由于公司App是使用https进行通信,直接在路由器上抓包下来,数据包都是加密的,没法看到接口返回的内容,给测试的B ...

  10. 你的第一个接口测试:Python 接口测试

    前言: 首先我们先明确一个概念,什么叫接口.什么叫接口测试? 接口的全称叫[Application Programming Interface 又叫API],是提供应用程序与开发人员基于某软件或硬件得 ...