Floodlight实践-通过域名标签实现家庭网络控制(1)

-写在前面的废话-

自从今年接触到了SDN(软件定义网络),就觉得进入了一个全新的领域。毕设做的Floodlight(一种Openflow控制器)更是一度让我觉得无从下手,概念理解的不透彻,安装中遇到奇奇怪怪的问题,第一次用ubuntu,几乎等于没有的中文资料,完全在官网上看英语自学,着实让我头疼了好久。虽然出国有一些时日了,但是依然是习惯看中文的资料学习,这个习惯看来是有必要改改了,大多数时候官网上给出的例子都十分有代表性,是学习的好地方。由于英语理解能力一般以及部分术语难以理解等原因,在学习floodlight和sdn前期花了不少功夫。最近刚刚看到一篇博文说总结项目也是取得进步的重要一环,于是回头看看自己的代码,真是不忍直视。虽说是第一次写python代码,代码量也不大,但现在看起来真的是乱糟糟一片,想修改都无从下手,正好借此写博客总结的机会,把代码总结修改一下,顺便学习一下github,把代码push上去。第一次写博客,第一次用markdown,第一次用github,最难的大概就是从0到1的过程吧,这应该也算是向着成为一个技术大牛的梦想上迈出了一步吧~如果文中有什么问题或疏漏,都欢迎指出讨论。

先给出逻辑框架图,然后每个模块逐步介绍。

architecture

整个系统可以简单的分为2个部分。左下角是虚拟网络和floodlight控制器,在虚线以内的是域名管理服务器模块。

普通的家庭路由器屏蔽网站一般是通过IP地址(说实话我也不知道现在的家用路由有什么高级功能),这样一来管理员如果想屏蔽某一类网址就不得不输入大量的IP地址,即浪费时间也不方便修改。所以这个项目中提出了通过域名和域名的标签(tags)来管理家庭网络。比如google和baidu的标签都是“search engine”,那么我们把相应的主机屏蔽掉“search engine”,就能屏蔽掉大部分的搜索引擎,方便且容易修改。

我们用Mininet创建一个虚拟网络来进行模拟实验。当虚拟网络中的某个主机想访问某个域名时,它会首先发送一条DNS请求来获取该域名的IP地址,当Openflow交换机收到了DNS请求时,便会发送一条Packet_in消息给floodlight控制器,在控制器里这个DNS请求将会被解析,取出请求中的域名地址,然后发送给域名管理服务器。域名管理服务器会通过该域名的标签来判断该主机是否有权限访问相应的域名,然后返回一个Permit/Deny响应给floodlight控制器,如果是Permit,则该DNS请求则正常转发;如果是Deny,floodlight控制器会丢弃掉这条请求,该主机便无法访问此域名。

首先介绍虚拟网络和floodlight控制器部分。

环境:Ubuntu14.04.1;Mininet 2.2;Floodlight v1.2

Mininet 是轻量级的软件定义网络系统平台,同时提供了对 OpenFlow 协议的支持。通俗一点说就是,Mininet可以创建虚拟主机虚拟交换机实现虚拟网络。

安装教程链接在此

http://mininet.org/download/

Mininet网上的中文教程其实很多了,就不再赘述,聊一聊折腾了好久的问题。其实安装Mininet时非常简单的,git clone之后install.sh -a就行。但是不知道为什么在我的ubuntu上一直安装失败。然后当我输入Mininet创建网络的指令的时候,他会提示

sudo mn

这时如果你按照提示通过apt-get安装Mininet,会默认安装Mininet2.1版本(当时最新的版本是2.2,apt-get默认2.1),而我需要使用2.2的一些新功能(后面会提到),只用将安装的指令改为install.sh -nfv就行,当初固执的想-all,结果浪费了好多时间。

Mininet安装好之后用sudo mn测试,会自动创建一个包含两个主机和一个交换机的虚拟网络。接下来是安装Floodlight控制器,官网链接在此

https://floodlight.atlassian.net/wiki/display/floodlightcontroller/Installation+Guide#InstallationGuide-FloodlightMasterandAbove

Floodlight是一种Java的Openflow控制器。SDN的核心理念之一便是控制模块和数据模块分开,Openflow控制器连在Openflow交换机上,交换机收到数据包后会发送Packet_in消息将数据包发送给Openflow控制器,经过处理后发送Packet_out消息返回给交换机,然后交换机进行转发。

Floodlight控制器安装好后下一步便是将控制器连接到Openflow交换机上,即由Mniniet创建的虚拟交换机。首先,我们需要用一段简单的python代码实现想要的拓扑结构。

#!/usr/bin/python  
from mininet.topo import Topo  
from mininet.net import Mininet  
from mininet.node import RemoteController, Controller  
from mininet.cli import CLI  
from mininet.link import TCLink  
from mininet.log import setLogLevel  
  
class MyTopo(Topo):  
    def __init__(self):  
        Topo.__init__(self)  
        Host1 = self.addHost('Child_1', ip='10.0.0.1')  
        Host2 = self.addHost('Child_2', ip='10.0.0.2')  
        Host3 = self.addHost('Father', ip='10.0.0.3')  
        Host4 = self.addHost('Mother', ip='10.0.0.4')  
  
        switch1 = self.addSwitch('s1')    
   
        self.addLink(switch1, Host1)  
        self.addLink(switch1, Host2)  
        self.addLink(switch1, Host3)  
        self.addLink(switch1, Host4)  
  
topos = {'mytopo': (lambda: MyTopo())}  

在我们的拓扑图中,创建了四个主机和一个交换机,并且四个主机都直接连在交换机上。接下来在eclipse中运行floodlight,这时的floodlight还是没有任何功能的,可以看做一个正常的交换机。运行后用下面的命令创建网络拓扑并且连接floodlight到我们创建的虚拟交换机上。


sudo mn --custom MyTopo.py --topo mytopo --mac --nat --controller=remote,ip=127.0.0.1,port=6653

mn即创建拓扑;

--custom 使用自己定义的拓扑;

--mac 使mac地址简化;

--nat 使我们创建的网络可以连接到Internet,如果没有这条指令,我们创建的网络是没有连接的外网的,也就是无法ping通Internet的,--nat只有在2.2及以上版本才有;

--controller 选择虚拟网络的控制,因为我的Mininet和floodlight都在一台虚拟机上,所以IP地址是本机地址,端口6653,可能有些老版的教程还是6633,这里要注意下,已经统一改为6653端口了。

创建拓扑

如图所示,我们的虚拟网络搭建好了,在eclipse的控制台中也能看到,已经连接上交换机。

但是依然高兴的太早,这时候使用Ping指令你会发现,依然是Ping不通外网的。

Ping失败

首先,我们用xterm进入任意一个host,然后进入/etc/resolv.conf这个配置文件,如图所示。

resolv.conf
修改配置文件

按下i修改这个配置文件,如果发现在修改过程中键盘失灵,请先安装vim。

将nameserver的ip地址改为8.8.8.8,这是Google提供的免费DNS服务器的IP地址,然后删掉后面的localdomain。接着按下esc,输入:wq保存退出,然后exit退出xterm,回到Mininet的命令行,重新执行Ping指令,我们会发现,现在已经可以Ping通了。

Ping成功

关于刚才修改文件的内容,第一行是默认的DNS服务器地址;第二行这个local domain我一直没有找到相关的资料,但是根据最后运行的结论我觉得,这个应该是本地缓存域名之类的,因为在后面的实验中,当我用floodlight控制器丢弃主机发送的DNS请求后,比如请求域名为www.baidu.com,主机收不到DNS响应后,会发送一条新的DNS请求,这时的请求域名变成了www.baidu.com.localdomain,如果删除了localdomain那一行,便不会有这条新的DNS请求。所以我猜测,这个localdomain应该是存在交换机上的域名-IP缓存,主机在第一次请求失败后,试图从交换机的缓存中取得请求域名的IP地址。

OK了~Mininet和floodlight的配置结束,下一步便是在floodlight中实现功能了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • 1、第八章 Samba服务器2、第八章 NFS服务器3、第十章 Linux下DNS服务器配站点,域名解析概念命令:...
    哈熝少主阅读 3,702评论 0 10
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,585评论 18 139
  • DNS(Domain Name System,域名系统),因特网上作为域名和IP地址相互映射的一个分布式数据库,能...
    一直在努力hard阅读 4,606评论 3 19
  • 人们总是一边说着要开心快乐的祝福语,而同时又尽一切的可能陷入多愁善感。经典的悲剧甚至从古代流传到今天,从某种意义上...
    2020号阅读 979评论 21 40
  • 中国式众筹的基本逻辑有哪些? 中国式众筹的基本逻辑大致有以下几个: 众筹相对论、长板理论、动车理论、三位一体、变外...
    robot_liu阅读 303评论 0 0