引言


在网络发展速度如此之快的今天,传统网络的架构充满了危机,主要有这四个问题:

  • 传统网络部署管理困难。
  • 分布式架构瓶颈出现。
  • 流量控制难真正实现。
  • 设备不可编程

现在的网络厂商


  • 种类繁多的网络厂商。

如何对网络设备进行操作?


  • 从图中可以看到,不同厂商的网络设备混杂在一起使用。
  • 但是不同厂商的网络设备要通过不同的方式进行部署(一般是通过Web和命令行),这就使得,对目前这种鱼龙混杂的网络进行统一配置,是一件很困难的事情。
  • 但是它们的底层协议相同,互操作没有问题。

如何管理这么多网络设备?


  • 目前我们通过搭建在服务器上的网管软件来管理。
  • 比如比如学校利用的就是网管软件,架设在服务器中;网管软件生成网络的拓扑图,知道哪一台PC在哪里,出现故障能够进行报警
  • 主流的SNMP(网络管理协议),更多侧重于监控,而不是分配和部署。也就是说,如果网络出出现故障,通过网管报警,还是需要人为修理。

问题一:传统网络布署和管理非常麻烦


网络设备间如何协同工作?


  • 网络设备之间,大部分都是采用 路由交换协议等 网络协议 来进行信息的交互。
  • 协议的逻辑基础:
    1. 邻居建立
    2. 信息共享
    3. 选择路径
  • 大部分网络采用的是典型的分布式网络架构:设备和设备之间相互交流路由信息,然后根据这些信息建立拓扑信息库,按照一些选路的算法计算路径。
  • 说白了就是接力棒式的流程,你交给我,我交给他。
  • 每个设备都有独立的CPU,独立运算。
  • 协议是 网络设备的语言,相当于人类沟通的语言。

如果网络发生动荡,设备如何交互?


  • 网络设备以接力棒的形式不断告诉下一跳邻居设备,然后将故障的链路删除。
  • 但是可能会有多余的重复的信息。

当流量暴增或拓扑暴增时...


  • 现在的云计算,大数据等互联技术的发展,导致网络中的流量越来越多,几乎以指数增长的形式上升,这使得底层网络设备的数量不断增加,压力越来越大,路由收敛的时间越来越长,效率越来越低。
  • 数据中心网(互联网公司)、电信网(运营商),需要变革的意愿最强。

问题二:分布式架构瓶颈


网络带宽分配如何解决?


  • 目前的负载均衡,并不是真正的负载均衡!下面的案例很大可能出现!

前往同一个目的地的带宽相同的路径A和B,有可能 A 95%的带宽都用于承担数据了,压力非常大,而 路径B 的带宽则只有20%利用率。

  • 这张拓扑时数据中心里是非常容易发生的一件事情,当非常多的数据进来的时候,并没有完全的实现路径的负载均衡,这就很可能出现这种很危险的情况:某一个设备,在某一个瞬间压力过大崩溃了
  • 因此,当今网络最大的一个问题之一,就是流量的可视化。现在的流量控制设备,并不能做到对全网,全链路进行流量控制,进行合理的负载均衡

有人可能会问,为什么不使得所有的 交换机和流量控制网络设备,实时监控和共享链路状态信息:是否拥塞,这样的话就能构建成一幅实时的流量图,根据这个流量图来进行流量控制?

虽然这个想法很不错,但是很遗憾,目前并没有一项技术能够支持构造实时的流量图:大部分流量控制设备都是独立进行控制的。

流量可视化难!


  • 常规的网管软件,只能对故障进行监视,无法实现全网全局的链路状态检测。
  • 常规的流量控制软件,只能实现区域化的流量控制,以及区域化的流量可视化。
  • 理想化模型如下

问题三:流量控制是棘手难题!


能否自定义设备的转发策略?


  • 传统的网络设备,工作方式是固定的:不修改目的IP地址和源IP地址,交换机根据MAC地址表进行转发,路由器根据路由表转发(不修改目的IP地址,不修改源IP地址,只修改MAC地址)。
  • 根据业务需求,也就是客户需求,对转发设备的策略进行自定义,这和传统固定的转发策略大为不同:传统是厂商决定,用户很难对固定的策略做出改变;而SDN允许用户通过编程的方式,来实现自定义转发策略,达到一些特定的目的

能否将软件运行在设备上?


  • 我们买来设备的时候,里面的协议已经被订好。我们不能通过安装软件的方式来增加设备的功能。就算能的话我们也要通过重装OS等复杂的手段来实现。

问题四:无法按需,不可编程


总结:这些需求催生了SDN。

SDN前瞻 传统网络的缺陷的更多相关文章

  1. SDN前瞻 传统网络架构的危机:危机“四”起

    本文基于SDN导论的视频而成:SDN导论 在网络发展速度如此之快的今天,传统网络的架构充满了危机,主要有这四个问题(3+1). 1)传统网络的部署和管理 非常困难 2)分布式网络架构凸显瓶颈 3)流量 ...

  2. SDN前瞻 软件定义网络的一些概念

    SDN的核心:可编程性 SDN的思想:SOA面向服务 面向服务的体系结构(service-oriented architecture SOA) 使网络连接的大量计算机易于合作,以 服务 而不是人工交互 ...

  3. SDN前瞻 该来的来了!SDN 软件定义网络

    SDDC:Software Defined Data Center 软件定义数据中心,全数据中心软件化. 在我们接触SDN概念之前,服务器虚拟化,软件虚拟化技术已经是非常成熟了.如果网络能够被虚拟化, ...

  4. SDN前瞻 网络的前世今生

    本文基于SDN导论的视频而成:SDN导论 目前网络层面流行的技术概念:虚拟中心:公有云私有云:数据中心等等. SDN主要的模拟器:Mininet OpenDaylight(Cisco) ONOS(AT ...

  5. 华为SDN:解决传统网络3大问题

    转:http://mp.ofweek.com/tele/a145613326756 科技潮人 2013-08-05 14:20 传统网络之困 互联网爆炸式增长,除了规模和发展速度远超之前所有曾出现的数 ...

  6. SDN:软件定义网络

    近期高级网络课的小组任务是在老师给定的范围内自选方向主题研究并做展示报告.我们组选了sdn.原以为这东西会是工业界无人问津的概念化产品,Google了一下却发现事实上sdn挺火的,因为它可能带来的可扩 ...

  7. 传统网络栈与InfiniBand栈对比图

    熟悉传统网络协议栈但对InfiniBand协议栈好奇的朋友可以通过下图有一个宏观上的印象. IB实现了"高带宽,低延时"的网络互联,最大的魅力就是支持RDMA,而RDMA就其本质, ...

  8. 什么是SDN(软件定义网络)(转载)

    软件定义网络(Software Defined Network, SDN)在InfoWorld于2011年11月公布的将影响未来10年的十项新技术中排名第二.2012年7月,SDN代表厂商Nicira ...

  9. java 基础之--传统网络编程

    什么是socket ? socket 是连接运行在网络上的两个程序间的双向通讯端点 服务器将某一套接字绑定到一个特定的端口,并通过这一套接字等待和监听客户端的的连接请求 客户端通过这个端口与服务器进行 ...

随机推荐

  1. 学习tp5的第二天(路由)

    一.学习路由 1.phpstudy版本的环境去掉indx.php 直接访问url phpstudy配置的环境需要设置 入口目录的 .htaccess文件如下: <IfModule mod_rew ...

  2. PHP程序员的技术成长规划 第二阶段:提高阶段

    第二阶段:提高阶段 (中级PHP程序员) 重点:提高针对LNMP的技能,能够更全面的对LNMP有熟练的应用.目标:能够随时随地搭建好LNMP环境,快速完成常规配置:能够追查解决大部分遇到的开发和线上环 ...

  3. windbg调试虚拟机XP系统

    一.先介绍一下被调试的虚拟机系统环境: 虚拟机:vmware workstation 10.0版本 虚拟机操作系统: Microsoft windows xp professional 2002 se ...

  4. keil编译运行错误,缺少error:#5:#include "core_cm3.h"

    用Keil  vision5编译时出现以下错误:error:  #5: cannot open source input file "core_cm3.h": No such fi ...

  5. Python--通过索引excel表将文件进行文件夹分类的脚本+读取指定目录下所有文件名的脚本

    1.通过索引excel表将文件进行文件夹分类的脚本,此脚本由于将ip和id对应并生成对应id的文件夹将文件进行分类,也可以任意规定表格内容,通过vul_sc_ip.txt和xlsx文件进行索引. # ...

  6. ACM1019:Least Common Multiple

    Problem Description The least common multiple (LCM) of a set of positive integers is the smallest po ...

  7. sublime install package没反应,以及安装后没有出现install package选项

    离线安装Package Control 一般出现这种问题的是网络原因,我们可以下载离线安装包 连接地址:https://github.com/wbond/package_control 安装完成后解压 ...

  8. ubuntu 和windows 分别在anaconda上安装tensorflow

    windows下 的anaconda安装tensorflow: 在Anaconda Prompt中:conda install tensorflow python=3.5一直下载失败.总结一下原因可能 ...

  9. 数据结构与算法之排序(2)选择排序 ——in dart

    选择排序的算法复杂度与冒泡排序类似,其比较的时间复杂度仍然为O(N2),但减少了交换次数,交换的复杂度为O(N),相对冒泡排序提升很多.算法的核心思想是每次选出一个最小的,然后与本轮循环中的第一个进行 ...

  10. node升级7.0以上版本使用gulp时报错

    今天使用gulp时 ,出现了以下报错信息: Error: Cannot find module 'internal/fs'at Object.<anonymous> (/home/XXX/ ...