zoukankan      html  css  js  c++  java
  • 工作经验总结

    团队管理

    开发管理

    1. 系统联调

    场景描述

      当前的智能音箱项目组由 音箱设备端 -> Proxy代理 -> 语音语义及技能 三大系统组成。设备端负责用户语音数据的采集、上传至Proxy端,Proxy负责数据透传,语音语义团队将接收到的音频数据进行解析并实现相应技能。技能按照相反的顺序返回至音箱设备端。目前的现状是整个工作流程不可靠,究竟是哪个环节也都说不清,可定性的定位故障点在Proxy与语音语义环节,至少proxy发送的音频与语音语义接收到的数据是不一致的。整个调试还得三个小组分别派人联调。

    解决方法

    • 从逻辑上来说应把这三个团队划分明确的边界,对接部分确定明确的输入输出。
    • [ 用户语音(输入) - 智能音箱 - 音频数据(输出) ]    =>    [ 音频数据(输入) - Proxy - 音频数据(输出)]    =>    [ 音频数据(输入) - 语音语义 - 技能结果(输出) ]。
    • 从上述流程可知各团队真正依赖的是音频数据,所以各个环节均应生成相应的音频数据文件,通过 BeyondCompare 等文件比较工具进行差异比较。
    • 各团队对接部分只需确保各自环节的输入输出正确性即可,这样可避免相互的依赖关系。
    • 每个环节均实现打桩数据,即可直接根据已有的数据文件进行本系统模块功能的测试,这样可解决上一环节的依赖。
    • 每个系统均实现单元测试代码,集成测试或系统测试时均可非常方便的实现自动化测试,定位问题故障。
    • 网络通信环节可通过WireShark等抓包工具进行精准分析。

     

    配置管理

    1. 文件管理

    场景描述

      当前项目组中的项目资料SVN既包含项目管理文档、个人工作文档、第三方资料库等。其中个人文档中的工作成果可能包含比较大的第三方类库、资源文件,第三方资料库可能包含一个开发板的系统镜像等,如果将所有数据都归入项目管理使用的SVN库,必然造成版本库文件过大,而且那些私有的大文件对绝大部分人来说是完全不关心的。因此,我认为对于大文件应该单独保存,SVN中只需包含相应大文件的资源链接,用户根据需要可自行下载。这样既保证了数据的完整性,也保证了项目库的简洁性。

    解决方法

    • 文件管理应分为大文件管理及小文件管理两部分。因为大文件混杂在SVN、Git等受控库时,初次下载代码时均会下载大量大文件,严重影响下载速率及本地磁盘占用空间。

    • 大文件管理是指安装文件、光盘镜像、大于10M的文档资料等,应通过共享文件、HTTP、FTP下载等方式管理。

    • 小文件管理是指受控的代码、文档、资料、可交付成果等,应通过SVN、Git等方式进行管理。

  • 相关阅读:
    Kafka设计解析(二)- Kafka High Availability (上)
    Kafka设计解析(三)- Kafka High Availability (下)
    Kafka深度解析
    Cloudera Manager(CDH5)内部结构、功能包括配置文件、目录位置等
    Failed to start /etc/rc.d/rc.local Compatibility
    Offset Management For Apache Kafka With Apache Spark Streaming
    maven-assembly-plugin打包可执行的jar包
    How Cigna Tuned Its Spark Streaming App for Real-time Processing with Apache Kafka
    SystemTap Beginners Guide
    数据可视化的开源方案: Superset vs Redash vs Metabase (二)
  • 原文地址:https://www.cnblogs.com/clxye/p/10520950.html
Copyright © 2011-2022 走看看