Python调用OpenDaylight REST API实验

本文介绍如何使用Python及pycurl库调用OpenDaylight REST API进行网络设备管理,包括实验环境搭建、Mininet网络创建及Python脚本编写。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  作为一种简洁易用的编程语言,Python现在广泛应用于Web开发,网络开发等场景中。OpenDaylight为开发者提供了基于REST的API,以开发上层网络应用程序。在另一种云操作系统OpenStack中,使用了Python + Django的MTV网页开发框架,因此,使用Python对OpenDaylight API进行调用实验,以探索未来OpenDaylight整合进入OpenStack的Web界面中进行网络管控,是很有必要的。


  下文将就使用Python调用OpenDaylight REST API的实验过程进行详述,在本文中,默认读者已经可以搭建好OpenDaylight + Mininet的开发环境,且能正常编译通过controller项目。实验环境版本及相关实验工具罗列如下:


1. 实验环境

  • 操作系统版本:Ubuntu 14.04 LTS
  • ODL版本:OpenDaylight Helium Stable
  • Mininet版本:Mininet 2.2.1
  • Python版本:2.7.6

2.实验工具

  • ODL项目:controller
  • Python库:pycurl, StringIO

鉴于读者对于实验环境已经比较熟悉,下面首先简单介绍一下pycurl库。pycurl库是基于libcurl库开发的Python开发库,在Python 2.7.6发行版中,已经集成了该模块,主要用于对REST API的读/写操作。具有效率高与操作简单的特性。下面简单介绍一下我们的实验中需要使用的相关函数:

  • c = pycurl.Curl():初始化一个Curl实例c以用于我们的后续操作。
  • c.setopt(c.foo, ‘bar’):对于我们的Curl实例c的某一个参数进行设置。
  • c.perform():根据前述的设置的参数进行执行API调用操作。
  • c.close():关闭当前Curl实例。

更多详细的资料读者可以参考以下两个网页:

  • pycurl:http://pycurl.sourceforge.net/doc/curlobject.html
  • libcurl:http://curl.haxx.se/libcurl/c/curl_easy_setopt.html

在完成以上先导知识的介绍后,下面正式开始介绍我们的实验过程。

一、 启动OpenDaylight controller项目


1.工作目录:root@ubuntu:/home/odl/opendaylight-helium/controller-stable-helium(请读者自行切换到自己的工作目录下)

2.进入到以下目录:

3.执行以下命令:

4.浏览器打开:http://127.0.0.1:8080/,如果可以登入OpenDaylight controller,则证明启动成功。如下图:

二、启动Mininet并创建网络

1.开启另一个控制台;

2.普通用户权限下执行:

3.执行完以上命令后,打开Web UI控制界面,可以看到网络的拓扑结构,如下图:

4.证明网络已经创建成功,且已经连接到OpenDaylight控制器。

三、查找OpenDaylight REST API

1.在OpenDaylight的相关模块的目录下,会自动生成html格式的REST API接口文档,读者可以根据需要自行查询相关API文档。本文以ConnectionManagerNorthbound为例对API接口的调用进行演示。

查询到需要的API接口之后,可以根据需要自行修改相关参数,本文使用如下图所示API来查询OpenDaylight监视的网络中的交换机节点的id信息:

四、编写Python程序

1.在特权用户模式下创建文件夹Applications:

2.在Applications文件夹中创建test.py文件,并输入如下代码:

3.由代码中我们可以看到,该测试程序使用pycurl工具对API进行调用,使用StringIO缓存读取到的信息,使用xml.dom.minidom对提取的xml文件进行内容解析。

4.保存好输入的Python程序,在Applications文件夹下,执行以下命令:

出现以下结果则证明实验成功:

总结

  通过本次实验,可以基本实现对OpenDaylight REST API的调用,为以后开发基于OpenDaylight的大型应用程序做好技术积累。在学习过程中,针对不同的API,可以进行举一反三,熟练的整合各个模块功能以及Python相关开发工具。

作者简介:

郝鹏,毕业于美国宾夕法尼亚大学,电子工程硕士,从事SDN相关研发工作。

### OpenDaylight 氧版本特性 OpenDaylight氧版本引入了一系列新特性和改进,增强了网络功能虚拟化(NFV)的支持能力[^1]。此版本特别强调了性能优化和服务可用性的提升。 #### 主要特性包括: - **增强的安全框架**:提供更强大的安全机制来保护SDN控制器免受潜在威胁。 - **分布式数据存储(DDS)**:支持大规模部署场景下的高效状态管理和同步。 - **YANG工具链升级**:提升了配置管理效率并简化了设备建模流程。 - **多租户隔离**:实现了更好的资源分配策略以满足不同业务需求之间的独立运作。 ```bash # 查看已安装的karaf特性列表 feature:list | grep odl-l2switch ``` ### 安装指南 对于OpenDaylight氧版本而言,官方推荐采用Apache Karaf容器来进行安装操作。通过这种方式可以方便地管理依赖关系,并且能够灵活定制所需模块集合。 #### 准备工作 确保操作系统已经预先安装好Java运行环境(JRE),并且设置好了相应的环境变量`JAVA_HOME`指向JDK路径。 下载Karaf发行包并解压到指定目录下;进入该文件夹执行启动命令即可初始化一个新的ODL实例。 ```bash wget https://downloads.opendaylight.org/release/.../apache-karaf-x.x.x.tar.gz tar -xzvf apache-karaf-x.x.x.tar.gz cd apache-karaf-x.x.x/ bin/karaf clean ``` ### 配置说明 完成基本安装之后,可以根据实际应用场景调整一些关键参数设定。例如修改日志级别、开启RESTCONF API服务端口监听等。 编辑位于`${KARAF_HOME}/etc/org.ops4j.pax.logging.cfg`的日志配置文档,在其中定义合适的记录规则以便于后续排查问题时定位错误信息源。 为了启用REST接口访问权限控制,则需前往相同位置找到名为`org.opendaylight.controller.config.yang.restconf.cfg` 的属性文件进行相应条目的激活处理。 ```properties restconf.http.port=8080 restconf.https.enabled=true restconf.https.port=8443 ``` ### 使用教程 初次接触OpenDaylight平台的新手用户可以从以下几个方面入手学习如何利用其核心功能构建自动化运维解决方案: - 学习掌握基础概念如拓扑发现、流表编程原理; - 尝试编写简单的Python脚本调用北向API实现流量监控统计分析任务; - 参考官方Wiki页面获取更多关于特定插件使用的指导材料。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值