【开题报告】海洋多源数据质量控制应用服务的WebServer设计与实现

开 题 报 告 内 容

论文选题的意义、主要研究内容和文献资料调研情况

一、选题意义

在当今世界研究自然环境的大背景下,计算机技术与各学科、各领域的综合应用逐渐增多。作为地球上最广阔的水体,同时也是地球上决定气候发展的主要的因素之一,海洋方面的研究具有很高的科学价值。海洋环境监测数据质量对于海洋环境“数字化”、海洋科学的研究和海洋经济的发展,都具有十分重要的意义。首先,海洋环境监测数据作为海洋环境“数字化”的重要基础,其可视化程度以及查找和分析的便捷程度,都影响着海洋环境“数字化”工作的进行;其次,海洋监测数据质量控制影响着海洋环境管理决策的科学性,海洋环境监测部门必须高度重视数据质量控制。

为了提高海洋多源数据的可视化程度,以及数据处理和分析的效率,借助计算机领域的WebServer技术,针对合作课题组设计开发的一套海洋多源数据质量控制程序,设计并提供在线的质量控制数据分析和可视化展示在线服务,使其具有随时随地在浏览器上进行海洋数据查看与质控操作的功能,具有轻量化、便捷易用的优点。

基于上述背景,本选题为海洋多源数据质量控制应用服务的WebServer设计与实现。

二、主要内容

本程序研究与设计的目的是,针对海洋多源数据,通过WebServer形式实现在线质量控制分析和展示,主要实现以下业务和功能:

按照前后端业务划分,前端主要负责输入的导入/导出、廓线展示、参数修改、交互操作等业务,后端服务器则源源不断地接收和处理来自前端的请求并返回相应的页面和数据,在本业务中主要包括批量数据的暂存与数据质控操作。

整个程序的主要结构如下图所示:

     

三、设计思路

本课题计划通过充分的需求分析、合理的技术路线设计、详尽实施方案设计及实现来完成课题研究内容。

  1. 需求分析

根据对海洋多源数据质量控制分析应用服务未来用户的调研及需求沟通分析,在线应用服务需要实现以下需求:导入\导出需求、采样点展示需求、廓线参数展示需求、廓线图像展示需求、质控参数展示需求、交互需求、质控需求等。初步需求分析文档附后。

  1. 技术路线

Web开发分为前端和后端两部分,前端开发拟采用Vue.js技术框架,后端开发拟采用Spring或Springboot技术框架。在本地进行前后端开发工作后,后续可通过Docker构造容器并部署应用,容器化的封装增强系统的可移植性,便于迁移部署。此外,后续的工作中,还可以考虑通过echarts等插件工具进行可视化展示。

研究内容框图:

    图注:前后端技术及容器技术等共同构建应用服务程序;应用服务程序为各项需求提供技术支持;通过应用服务程序,针对各项需求进行各项相关操作。

    

技术栈部分:

图注:应用服务程序的技术方面主要涉及前端、后端和容器部署三方面。

设计思路为,通过前端和后端设计技术,先进行本地的应用程序的构建和实现,后续再通过容器化部署进行封装和移植,并辅以可视化展示、安全维护等,进行海洋多源数据质量控制应用服务的webserver设计与实现。

场景流程:

四、文献资料调研

根据参阅的文献,海洋多源数据质量控制程序可通过C/S(Client/Server或客户/服务器模式)或B/SBrowser/Server浏览器/服务器模式)模式来设计实现。程序分为前端和后端,前端为客户实现操作与展示的功能,后端为管理员实现数据存储和数据质控的功能。本程序选择B/S模式,便于架构建立在广域网上,便于各地的研究人员进行数据的查看和管理,此外B/S模式的系统运行速度较快、便于维护、建立在浏览器上、 有更加丰富和生动的表现方式与用户交流. 并且开发与使用难度减低,节约开发成本

初步需求分析:

导入\导出需求:数据导入和数据导出作为程序的输入端和输出端,支持导入/导出数据格式:txt,netCDF。导入文件大小要求:单文件大小不超5MB, 多文件需排队上传,支持断点续传,整体数据量不超500MB,批量暂存于后端服务器。导出要求:支持txt,netCDF格式导出,导出的数据包含原始的导入数据,修改后的数据,以及质控标记位。

采样点展示需求:导入数据后,依据采样位点的经纬度显示全球采样图,每个采样位点显示为蓝色,参考Client 服务中世界地图展示。提取的关键业务数据:国家、经纬度信息。

廓线参数展示需求:导入数据后,显示详细的数据统计信息,如观测日期,站点位置、航次、站好、国家、记录系统、仪器类型、数据个数、Access Number等内容。其中,单廓线信息包括:观测日期,站点位置、航次、站好、国家、记录系统、仪器类型、数据个数(指温度/深度数据点数)、Access Number等内容。多条廓线信息包括:观测范围、站点范围、采样点个数、Access Number、仪器类型等内容。

廓线图像展示需求:质控前或质控后均可切换显示廓线图像,廓线图像包括单廓线与多廓线,横坐标温度,纵坐标深度,其中,单廓线数据为一个采样点的温度/深度数据,表现形式为一个曲线,多廓线为多个采样点数据,表现形式为多条曲线。

质控参数展示需求:对采样点质控,需要根据质控参数完成具体的质控过程,质控包括13个check步骤(接入质控程序脚本完成各步处理),可分项选择独立进行质控,展示质控参数并提供用户选择。

交互需求:本任务中交互需求主要包括点击采样点,显示相应参数及廓线展示交互需求。前者需求较为简单明确,着重描述廓线展示交互需求。经由质控程序质控后,廓线需要标注出合格点与不合格点,以不同颜色区分,以散点形式呈现,点击每个采样点上的数据后,该采样点数据可以连接成线表示。对于多廓线交互,默认显示100个采样点数据,多采样点数据分页显示。

质控需求:任务的核心即是数据的质控过程,数据质控通过调用质控程序完成,前端需要根据用户选择的质控参数,通过HTTP请求发送到后端,调度质控程序完成具体的质控操作并将修改的文本文件返回前端。

参考文献:

[1] 许自舟, 宋德瑞, 赵辉, 等. 海洋环境检测数据质量计算机控制方法研究[J]. 海洋环境科学, 2009,28(03):320-323.

[2]向先全, 路文海, 杨翼, 等. 海洋环境监测数据集质量控制方法研究[J]. 海洋开发与管理, 2015,32(01):88-91.

[3]冯翔宇. 面向云计算的海洋环境监测系统访问控制方法研究[J]. 舰船科学技术, 2016(8x):136-138.

[4]黄海燕, 路文海, 付瑞全, 等. 基于质控数据库的海洋环境监测生物名质量控制方法研究[J].应用海洋学学报, 2014, 33(3):434-439.

整体思路

一、引言

随着海洋数据获取技术的不断发展,海洋数据量日益庞大,涉及的来源也日益增多。这些数据对于海洋科学研究、环境监测、渔业管理等领域具有重要意义。然而,由于不同来源的数据质量参差不齐,如何对这些数据进行有效质量控制成为一个重要问题。因此,本文旨在设计和实现一个基于Java的海洋多源数据质量控制应用服务的Web Server,以提高海洋数据的质量控制能力。

二、系统需求分析

本系统需要满足以下需求:

  1. 数据接收:能够从不同的数据源接收海洋数据。
  2. 数据预处理:对接收到的数据进行清洗、格式转换等预处理操作,以确保数据的一致性和完整性。
  3. 数据质量评估:利用一定的算法和模型对数据进行质量评估,识别和纠正错误数据。
  4. 数据可视化:将处理后的数据以图表等形式呈现给用户,以便用户直观地了解数据的质量状况。
  5. 用户管理:能够对不同用户进行权限管理,确保数据的安全性和保密性。
  6. 日志管理:能够对系统的操作过程进行记录和监控,以便追踪和排查问题。
  7. 可扩展性:系统应具备良好的扩展性,能够适应未来数据源的增加和数据处理需求的变化。

三、系统设计

本系统采用Java Web技术进行开发,利用Spring Boot框架实现。系统主要包括以下几个模块:

  1. 数据接收模块:采用Socket通信或HTTP请求等方式从不同的数据源接收数据。
  2. 数据预处理模块:对接收到的数据进行清洗、格式转换等操作,以确保数据的一致性和完整性。
  3. 数据质量评估模块:利用一定的算法和模型对数据进行质量评估,识别和纠正错误数据。
  4. 数据可视化模块:采用前端框架如React或Vue等,将处理后的数据以图表等形式呈现给用户。
  5. 用户管理模块:采用Spring Security框架实现用户认证和授权管理,确保数据的安全性和保密性。
  6. 日志管理模块:采用Log4j或Logback等日志框架记录系统的操作过程和监控信息。
  7. 可扩展性设计:采用微服务架构,将各个模块解耦,方便未来扩展和维护。同时,采用Docker容器化技术,使得系统能够轻松地在不同的环境中部署和运行。

四、系统实现

本系统的实现主要包括以下几个步骤:

  1. 环境搭建:安装Java开发工具包JDK和开发平台Eclipse或IntelliJ IDEA,安装Maven或Gradle构建工具,安装Tomcat或Jetty等Servlet容器。
  2. 数据库设计:根据需求分析,设计数据库表结构,包括用户表、日志表、数据源表、数据处理任务表等。使用MySQL或PostgreSQL等关系型数据库存储和管理数据。
  3. 模块开发:根据系统设计,分别开发各个模块的代码。采用Java语言和Spring Boot框架进行开发,利用Maven或Gradle构建项目。
  4. 接口设计:定义RESTful API接口,用于前端页面和后端服务之间的交互。使用Spring Data JPA或MyBatis等ORM框架实现数据的增删改查操作。
  5. 测试与调试:进行单元测试、集成测试和系统测试,确保系统的稳定性和可靠性。同时,利用调试工具如IntelliJ IDEA的调试器或Eclipse的调试器进行代码调试和问题排查。
  6. 部署与运行:将系统部署到服务器上,配置相应的环境变量和启动参数。运行系统并观察运行结果是否符合预期。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/200792.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Unity学习笔记11

一、视频播放功能 1.如何让视频在游戏场景中播放? 在Assets目录下添加一个渲染器纹理,步骤:新建→渲染器纹理 首先在创建一个平面,想让视频在平面上显示。在平面上添加一个组件 Video Player 然后将视频文件拖拽到视频剪辑位置上…

自动化测试 —— requests和selenium模块!

一、requests基于POST请求 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 #1.requests的GET与POST用法的区别: GET请求: (HTTP默认的请求方法就是GET) * 没有请求体 * 数据必须在1K之内! * GET请求数据会暴露在浏览器…

【MyBatis】MyBatis操作数据库

目录 一,准备工作 1.1 创建工程 1.2 准备数据 1.3 数据库连接字符串 1.4 创建持久层接口UserInfoMapper 1.5 单元测试 二,注解的基础操作 2.1 打印日志 2.2 参数传递 2.3 增(Insert) 2.4 删(Delete&#x…

pytest分布式执行(pytest-xdist)

前言 平常我们手工测试用例非常多时,比如有1千条用例,假设每个用例执行需要1分钟。如果一个测试人员执行需要1000分钟才能执行完,当项目非常紧急的时候,我们会用测试人力成本换取时间成本,这个时候多找个小伙伴把任务…

如何使用群晖Synology Office结合内网穿透实现多人远程编辑文件协同办公

使用群晖Synology Office提升生产力:多人同时编辑一个文件 文章目录 使用群晖Synology Office提升生产力:多人同时编辑一个文件本教程解决的问题是:1. 本地环境配置2. 制作本地分享链接3. 制作公网访问链接4. 公网ip地址访问您的分享相册5. 制…

react-route-dom 实现简单的嵌套路由

最终效果 点击 to test1 点击to test2 > to test21 点击to test2 > to test22 代码如下 path: "page",element: <父组件 />,children: [{ path: "test1", element: <Test1 /> },{path: "test2",element: <Test2 />…

【JavaEE初阶】死锁问题

目录 一、死锁的三种典型场景 1、一个线程&#xff0c;一把锁 2、两个线程&#xff0c;两把锁 3、N个线程&#xff0c;M把锁 死锁&#xff0c;是多线程代码中的一类经典问题。我们知道加锁是能解决线程安全问题的&#xff0c;但是如果加锁的方式不当&#xff0c;就可能产生死…

品味丰富美食,羊大师温暖心灵

品味丰富美食&#xff0c;羊大师温暖心灵 冬季来临&#xff0c;寒冷的天气让人们渴望寻找一种温暖和满足感&#xff0c;这时候美食便成了一种心灵享受。冬季与美食的结合&#xff0c;使得人们在寒冷的冬日也能感受到温暖与欢乐。本文小编羊大师将带大家领略冬季与美食的完美结…

PAT-10道题

PAT算法刷题 1002 1002 一&#xff1a;对于每一的1到6都进行枚举&#xff0c;进行递归操作 二&#xff1a;如果位数到了指定的n的时候&#xff0c;递归的条件&#xff0c;进行判断是否可以整除操作 #include<iostream> #include<algorithm> using namespace std; l…

c语言十进制转二进制

以下是一个将十进制数转换为二进制数的C语言代码示例&#xff1a; #include <stdio.h>void decimal_to_binary(int decimal) { int binary[32]; int i 0; while (decimal > 0) { binary[i] decimal % 2; decimal / 2; i; } pr…

zookeeper集群+kafka集群:

kafka3.0之前依赖于zookeeper。 zookeeper开源&#xff0c;分布式的架构。提供协调服务&#xff08;Apache项目&#xff09; 基于观察者模式涉及的分布式服务管理架构。 存储和管理数据。分布式节点上的服务接受观察者的注册。一旦分布式节点上的数据发生变化&#xff0c;由zoo…

工作时想摸鱼?不如背点单词冷静一下

今天给大家分享一款新发现的“摸鱼”神器「ToastFish」。 这个软件相当神奇&#xff0c;它可以让我们在用电脑时安全隐蔽地——背单词&#xff01; 是的&#xff0c;工作累了&#xff0c;打游戏乏了&#xff0c;背两个单词&#xff0c;既能放松&#xff0c;又能提高&#xff0c…

linux 之iptables

1.iptables防火墙基本介绍 Linux系统的防火墙&#xff1a;IP信息包过滤系统&#xff0c;它实际上由两个组件 netfilter和 iptables 组成。 主要工作在网络层&#xff0c;针对IP数据包。体现在对包内的IP地址、端口、协议等信息的处理上。 iptables由软件包iptables提供的命令…

交叉熵损失函数(Cross-Entropy Loss Function)

交叉熵损失函数&#xff08;Cross-Entropy Loss Function&#xff09; 在处理机器学习或深度学习问题时&#xff0c;损失/成本函数用于在训练期间优化模型。目标几乎总是最小化损失函数。损失越低&#xff0c;模型越好。交叉熵损失是最重要的成本函数。它用于优化分类模型。对…

设计好的测试用例,6大注意事项

设计好的测试用例对于发现缺陷、验证功能、提高可靠性、降低风险和提高效率都具有重要的作用&#xff0c;是保证产品质量和稳定性的重要环节。如果测试用例有问题&#xff0c;可能会导致遗漏缺陷、功能验证不充分、测试效率低下以及误报漏报等问题&#xff0c;从而影响项目的质…

Jira Software最新版本(9.11.2)安装

软件获取 Jira Software 历史版本下载地址&#xff1a;Jira Server 下载存档 | Atlassian Atlassian-agent.jar https://github.com/haxqer/confluence/releases/download/v1.3.3/atlassian-agent.jar MySQL 驱动包 MySQL :: Download MySQL Connector/J (Archived Versio…

mybatis项目中添加logback日志

1、pom.xml <dependencies><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId></dependency><!-- MySQL驱动 mybatis底层依赖jdbc驱动实现,本次不需要导入连接池,mybatis自带! --><dependency&g…

uniapp 连接斑马PDA调试

1、先把PDA设置成开发者模式 打开设置--》关于手机 --》单击版本号&#xff0c;5次以上 连线单击5次以上 2、后退--》找到系统 --》高级 3、打开 --》开发都模式 4、找到调试 --》 打开USB调试 5、设置USB偏好设置&#xff0c;插入电脑连接PDA就会在通知栏上显示&#xff0c;默…

排序算法基本原理及实现1

&#x1f4d1;打牌 &#xff1a; da pai ge的个人主页 &#x1f324;️个人专栏 &#xff1a; da pai ge的博客专栏 ☁️宝剑锋从磨砺出&#xff0c;梅花香自苦寒来 &#x1f4d1;插入排序 &#x1f4…

量子力学应用:探索科技前沿的奇幻之旅

量子力学应用:探索科技前沿的奇幻之旅 引言 量子力学,这门探讨微观世界规律的学科,自其诞生以来就充满了神秘与奇幻。随着科学技术的不断进步,量子力学已经从纯理论研究走向了实际应用领域,为我们打开了一个全新的科技世界。在本文中,我们将深入探讨量子力学的应用方面,…