SDN开发笔记:md-sal应用程序开发
来源:互联网 发布:靠谱代购淘宝店 知乎 编辑:程序博客网 时间:2024/06/10 16:22
环境:ubuntu14.04,控制器:distribution-karaf-0.3.3-Lithium-SR3 jdk:1.8 maven:3.5.2
1 获取OpenDaylightsettings.xml文件的简单方法:执行如下命令
cp -n ~/.m2/settings.xml{,.orig} ; \wget -q-O -https://raw.githubusercontent.com/opendaylight/odlparent/stable/boron/settings.xml> ~/.m2/settings.xml
2 使用 Maven和一个叫做opendaylight-startup-archetype的原型创建一个模版工程。如果你第一次创建该工程,需要花费一些时间从远程仓库下载。
mvn archetype:generate-DarchetypeGroupId=org.opendaylight.controller-DarchetypeArtifactId=opendaylight-startup-archetype-DarchetypeRepository=https://nexus.opendaylight.org/content/repositories/public/-DarchetypeVersion=1.0.3-Lithium-SR3
3 按如下修改属性值,输入y进行骨架创建:
4生成hello文件夹,输入mvn clean install进行编译(编译过程较缓慢,请耐心等待)
这个hello文件夹的内容如下,表示一个hello的模块的骨架相关文件
5编译成功
6之后进入hello\karaf\target\assembly\bin,找到karaf,运行karaf启动控制器。
7 实现hello-world:
7.1 进入hello/api/src/main/yang目录,按照下面修改hello.yang,增加hello-world这个rpc:
module hello {yang-version 1;namespace “urn:opendaylight:params:xml:ns:yang:helloworld”;prefix “helloworld”;revision “2015-01-05” {description “Initial revision of helloworld model”;}rpc hello-world {input { leaf name { type string; } }output { leaf greating { type string; } }}}返回到hello/api,编译api:
cd ../../../mvn clean install
进入目录hello/impl/src/main/java/org/opendaylight/hello/impl,创建一个新的文件HelloWorldImpl.java:
package org.opendaylight.hello.impl;import java.util.concurrent.Future;import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.hello.rev150105.HelloService;import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.hello.rev150105.HelloWorldInput;import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.hello.rev150105.HelloWorldOutput;import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.hello.rev150105.HelloWorldOutputBuilder;import org.opendaylight.yangtools.yang.common.RpcResult;import org.opendaylight.yangtools.yang.common.RpcResultBuilder;public class HelloWorldImpl implements HelloService { @Override public Future<RpcResult<HelloWorldOutput>> helloWorld(HelloWorldInput input) { HelloWorldOutputBuilder helloBuilder = new HelloWorldOutputBuilder(); helloBuilder.setGreating("Hello " + input.getName()); return RpcResultBuilder.success(helloBuilder.build()).buildFuture(); }}
7.3.在当前目录中找到HelloProvider.java文件. 在该文件中注册你在hello.yang中定义的RPC。你可以按如下编辑该文件或者用下面的代码替换该文件。
/* * Copyright(c) Yoyodyne, Inc. and others. All rights reserved. * * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 which accompanies this distribution, * and is available at http://www.eclipse.org/legal/epl-v10.html */package org.opendaylight.hello.impl;import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.ProviderContext;import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.RpcRegistration;import org.opendaylight.controller.sal.binding.api.BindingAwareProvider;import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.hello.rev150105.HelloService;import org.slf4j.Logger;import org.slf4j.LoggerFactory;public class HelloProvider implements BindingAwareProvider, AutoCloseable { private static final Logger LOG = LoggerFactory.getLogger(HelloProvider.class); private RpcRegistration<HelloService> helloService; @Override public void onSessionInitiated(ProviderContext session) { LOG.info("HelloProvider Session Initiated"); helloService = session.addRpcImplementation(HelloService.class, new HelloWorldImpl()); } @Override public void close() throws Exception { LOG.info("HelloProvider Closed"); if (helloService != null) { helloService.close(); } } }
7.4 编译注册新RPC功能的java类。检查编写 HelloProvider.java和HelloWorldImpl.java是否正确
7.5 返回顶级目录,编译整个hello
7.6可在~/.m2/repository/org/opendaylight/hello2中找到编译好的文件:
7.7将hello集成到ODL发行版,我采用的发行版为OpenDaylight Lithium SR3,解压后进入目录,可以看到其中包含system子目录,该目录即为发行版所用的仓库(Repository)。进入system目录,创建子目录org/opendaylight/hello:
7.8 进入hello,复制~/.m2中相应内容,得到结果为:
7.9将hello集成到ODL发行版:添加仓库启动发行版的karaf,先安装odl-mdsal-clustering,再装odl-restconf,odldlux-all
7.10添加hello仓库,执行,且查看添加情况,执行安装:
7.11测试:登录页面http://localhost:8181/index.html,可在YANG UI/API中找到相应的功能,进行测试。
用户名和密码都是admin,找到hello,里面的helloworld:
- SDN开发笔记:md-sal应用程序开发
- OpenDaylight中MD-SAL学习笔记
- AD-SAL与MD-SAL的比较
- SDN开发环境搭建
- [Android] 开发规范.md
- OpenDaylight Controller:MD-SAL:Plugin Types
- Linux应用程序开发学习笔记
- BEA Tuxedo应用程序开发笔记
- 3sdn ArcGis engine + C#开发教程
- 基于floodlight开发SDN应用实例
- SDN笔记
- 《Series40可扩展应用程序开发》学习笔记
- GTK+图形化应用程序开发学习笔记
- Android开发笔记4----应用程序组成
- iphone应用程序开发指南(笔记1)
- iphone应用程序开发指南(笔记2)
- 嵌入式Linux应用程序开发详解-笔记1
- 《嵌入式linux应用程序开发详解》核心笔记
- 图片缩放动画
- mysql generator使用方法
- linux 下性能分析工具 Gprof
- 解决supervisord进程导致的队列时差问题
- cocos内存管理机制
- SDN开发笔记:md-sal应用程序开发
- springmvc 从入门到总结
- Spring+SpringMVC+hibernate spatial+oracle spatial 映射存储Geomety空间数据过程记录
- .net MVC前后端通信—SingleR,文件监控FileSystemWatcher
- 第一课:慕课网Vue.js音乐播放器
- 剑指offer 从上往下打印二叉树
- MySQL之进行行列转换
- Android TextView使用HTML处理字体样式、显示图片等
- LeetCode 191. Number of 1 Bits