说明

本文基于某GPON MDU产品的当前情况,提出OMCI升级的加速方案。

因时间仓促和水平限制,文中难免存在错漏和不足之处,敬请指正。

一  问题提出

根据G.988标准相关描述,软件升级过程可分为版本下载(Download)和激活提交(Activate&Commit)两个过程。

激活提交过程主要耗时在于激活操作后的自动重启,但其优化空间不大;而版本下载过程主要耗时在于分片传输,因此本文也将集中讨论分片传输的加速。

目前某MDU软件升级过程中,子卡首先接收OLT下发的版本镜像分片(Section)并写入内存,收到End Software Download消息后对内存版本进行CRC校验,校验通过后再将版本通过2000字节的分块(Block)发送给主控板。主控板接收完所有分块后进行本地校验,校验通过后将版本写入Flash,完成版本下载过程。

该产品主控版本的下载实测结果表明:ONU子卡约每50ms(Avg:53.6ms)接收一个Window,计31*32=992字节。子卡接收到完整版本后,约每60ms(Avg:68.7ms)向主控板发送一个Block,计2000字节。从开始下载到写入Flash共耗时约8.5分钟。

为便于说明,当前方案记为“串行”下载。可以看出,除去CRC校验过程,版本其实被重复下载两遍(虽然分块传输比分片传输耗时稍短)。下文将介绍“准并行”的下载加速方案。

二  解决方法

“准并行”下载,即ONU子卡每接收到N个下载窗口(Windows),向主控板发送N×Win字节的Block,从而实现接收和发送的“准并行”,以加快下载过程。

基于Block的度量方式,“准并行”下载可细分为分块粒度和分片粒度。

2.1 窗口粒度

假设OLT和ONU协商每个窗口含32个分片(Section),每个分片恒为31字节。则当N=2时升级加速过程如下图所示:

图2.1 OMCI升级加速窗口粒度示意图

为突出重点,图中未示出ONU对OLT升级消息的响应,也未体现本地消息交互所必须的进程协作。

START DOWNLOAD消息中携带初次计算的Block额定数目(也可由SEND BLOCK消息携带)。SEND BLOCK消息中携带Block当前序号,Block字节数以及根据窗口尺寸而调整的Block额定数目。该Block序号对应OLT下发的两个完整窗口。

关键的处理逻辑如下:

  • 若(当前序号≤前次序号)或(当前序号>额定序号),打印错序提示及前次、当前和额定序号值。
  • 若收到SEND_BLOCK消息,则依次发送(当前序号-前次序号)个Block。
  • 若收到END_DOWNLOAD消息,则依次发送(额定序号-当前序号)个Block。

可以看出,若当前序号始终等于前次序号,则“准并行”下载退化为“串行”下载。

注意,从OLT接收Section的代码段应确保发往主控的内存版本和Block序号正确性,亦即该代码段应根据下载窗口尺寸来调整Block大小。Block Interval时长应大于单个分块传输的处理时间。对于该产品,N≥2,即Block大小至少为2×32×31=1984≈2000字节,但也不宜过大。

2.2 分片粒度

假设OLT和ONU协商每个窗口含32个分片(Section),每个分片恒为31字节。则当N=2时升级加速过程如下图所示:

图2.2 OMCI升级加速分片粒度示意图

为突出重点,图中未示出ONU对OLT升级消息的响应,也未体现本地消息交互所必须的进程协作。

START DOWNLOAD消息中携带初次计算的Section额定数目(也可由SEND BLOCK消息携带)。SEND BLOCK消息中携带Section当前序号,该Section序号对应OLT下发的两个完整窗口。

关键的处理逻辑如下:

  • 若(当前序号≤前次序号)或(当前序号>额定序号),打印错序提示及前次、当前和额定序号值。
  • 若收到SEND_BLOCK消息,则依次发送(当前序号-前次序号)个Section的Block。
  • 若收到END_DOWNLOAD消息,则依次发送(额定序号-当前序号)个Section的Block。
  • Block大小应维持在2000字节左右,过大则需强制分多块传输。

可以看出,若当前序号始终等于前次序号,则“准并行”下载退化为“串行”下载。

注意,从OLT接收Section的代码段应确保发往主控的内存版本和Section序号正确性。因分片长度固定,故Section额定数目固定,无需调整。Block Interval时长应大于单个分块传输的处理时间。对于该产品,N≥2,即Block大小至少为2×32×31=1984≈2000字节,但也不宜过大。

三  效果评价

根据“串行”下载实测值,可估算“准并行”下载将缩短升级过程近3分钟,即加速约30%。该加速对于Flash较小下载较慢的ONU更为明显。

此外,“串行”下载向主控发送版本分块时,可能由于消息发送过快,主控CPU提包限速导致收到的消息存在未剥除消息头的概率。因而该产品子卡在向主控分块传输时进行30ms延迟。而“准并行”下载时,接收Block速度低于发送Block速度,因此不需要分块延迟。

某MDU产品OMCI软件升级加速方案的更多相关文章

  1. MDU某产品OMCI模块代码质量现状分析

    说明 本文参考MDU系列某产品OMCI模块现有代码,提取若干实例以说明目前的代码质量,亦可作为甄别不良代码的参考. 本文旨在就事论事,而非否定前人(没有前人的努力也难有后人的进步).希望以史为鉴,不破 ...

  2. EPON ONU软件升级的若干优化方案

    1 说明 目前EPON ONU软件升级主要有IP方式(如SNMP/TR069)和TFTP+OAM两种.前者需占用大量IP地址,且配置ONU的IP地址需要手工操作,给业务开通和系统维护带来较大不便:后者 ...

  3. MTM量身定制系统 - 富友ERP产品 - 信息化推动服装行业管理软件升级

    MTM量身定制系统 - 富友ERP产品 - 信息化推动服装行业管理软件升级 国内第一款量体定制管理系统               结合富友软件10年服装行业经验和多家大型量身定制企业管理经验,推出的 ...

  4. Enea推出Linux实时加速方案专门针对Xilinx UltraScale+

    导读 Enea(纳斯达克OMX Nordic:ENEA)Linux实时加速方案的扩展版本,完全集成了Xilinx UltraScale +系列的所有处理单元.借助Xilinx开发者大会(XDF)201 ...

  5. “DNAT+云链接+CDN”加速方案,助力出海企业落地生长

    摘要:“DNAT+云链接+CDN”加速方案,真正释放技术红利,真诚助力企业出海. 随着国内互联网行业的人口红利逐渐消失,本土互联网市场竞争不断加剧,加之国家多项“走出去”政策的推动,越来越多的中国互联 ...

  6. TODO:软件升级的那些事

    TODO:软件升级的那些事 软件升级,指软件从低版本向高版本的更新.由于高版本常常修复低版本的部分BUG,所以经历了软件升级,一般都会比原版本的性能更好,得到优化的效果,用户也能有更好的体验. 最近常 ...

  7. OpenVZ VPS加速方案–Final Speed

    body,td { font-family: 微软雅黑; font-size: 10pt }   OpenVZ VPS加速方案–Final Speed OpenVZ VPS加速方案–Final Spe ...

  8. 【swupdate文档 三】SWUpdate: 嵌入式系统的软件升级

    SWUpdate: 嵌入式系统的软件升级 概述 本项目被认为有助于从存储媒体或网络更新嵌入式系统.但是,它应该主要作为一个框架来考虑,在这个框架中可以方便地向应用程序添加更多的协议或安装程序(在SWU ...

  9. python环境搭建-设置PyCharm软件的配色方案和Python解释器

    设置PyCharm软件的配色方案 设置Python解释器(用于Python2 or 3 的切换)

随机推荐

  1. R语言ggplot2-labs 函数

    labs 函数主要有以下三个用途: 1) 设置图片的标题(title), 子标题(subtitle), 引用(caption) 代码示例: ggplot(mtcars, aes(mpg, wt, co ...

  2. Yii2 中cookie的用法(1)

    Yii使用 yii\web\Cookie对象来代表每个cookie,yii\web\Request 和 yii\web\Response 通过名为’cookies’的属性维护一个cookie集合, 前 ...

  3. Request获取用户真实IP(用作白名单过滤)

    在Servlet里,获取客户端的IP地址的方法是:request.getRemoteAddr(),这种方法在大部分情况下都是有效的.但是在通过了Apache,Squid,Nginx等反向代理软件就不能 ...

  4. Memcached存储机制

    Memcached存储机制 memcached 内存管理 分析(转) 缓存.缓存算法和缓存框架简介 memcached全面剖析–PDF总结篇

  5. 有限状态机(FSM)的Java 演示

    本文从简单的样例入手,逐步演变成很复杂的程序. 在简明 状态模式(5.8)中,状态之间的变换由外界控制,或者说.多种状态是切割的.无关的.状态模式最有趣的地方正是讨论其状态的变迁. 1.引子 空调(a ...

  6. svn管理码云项目

    1.设置SVN管理项目 进入项目->管理 2.获取SVN地址 3.SVN添加项目.单击右键 -> 检出->版本库Url(这里填写svn地址)

  7. MSM--Memcached_Session_Manager介绍及使用

    MSM--Memcached_Session_Manager介绍及使用 http://www.iteye.com/topic/1125301 我们都知道对于一些大型的web2.0的网站,在正式部署时一 ...

  8. linux echo命令

    该篇文章转载于:http://www.cnblogs.com/ZhangShuo/articles/1829589.html linux的echo命令, 在shell编程中极为常用, 在终端下打印变量 ...

  9. zookeeper入门系列讲解

    zookeeper可谓是目前使用最广泛的分布式组件了.其功能和职责单一,但却非常重要.    在现今这个年代,介绍zookeeper的书和文章可谓多如牛毛,本人不才,试图通过自己的理解来介绍zooke ...

  10. Python 程序员都会喜欢的 6 个库

    在编程时,小挫折可能与大难题一样令人痛苦.没人希望在费劲心思之后,只是做到弹出消息窗口或是快速写入数据库.因此,程序员都会喜欢那些能够快速处理这些问题,同时长远来看也很健壮的解决方案. 下面这6个Py ...