java实战项目技术架构设计
技术架构设计
一、用例收集
一、记录查询
1.用户根据运单号,站点,sop环节查询站点内指定sop环节操作记录,以及对应的视频记录;
2.用户根据运单号,站点查询指定站点内sop环节操作记录,以及对应的视频记录;
3.用户根据运单号,sop环节查询所有站点内指定sop环节操作记录,以及对应的视频记录;
4.用户根据运单号查询所有站点内sop环节操作记录,以及对应的视频记录;
二、交叉带视频查询
1.用户查看包裹在供件台上包后在交叉带运行的视频
二、模型抽象
sop环节由对应要素完成,操作记录由要素触发完成,摄像头拍摄对应时间节点所覆盖的要素完成的事件
三、表结构设计
建表语句
CREATE TABLE sop (
id bigint(20)NOT NULL AUTO_INCREMENT COMMENT '主键id', sop_type varchar(64)NOT NULL COMMENT 'sop类型',
sop_name varchar(64)NOT NULL COMMENT 'sop名称',
creator varchar(64)NOT NULL COMMENT '创建者',
gmt_create datetime NOT NULL COMMENT '创建时间',
gmt_modify datetime NOT NULL COMMENT '修改时间',
PRIMARY KEY (id)
) ENGINE = InnoDB COMMENT 'sop环节';
CREATE TABLE sop_flow (
id bigint(20)NOT NULL COMMENT '主键id',
flow_name varchar(64) COMMENT '流程名称',
site_code varchar(64)NOT NULL COMMENT '站点code',
site_name varchar(64)NOT NULL COMMENT '站点名称',
sop_nodes varchar(4096)NOT NULL COMMENT 'sop节点集合', tenant_code varchar(64)NOT NULL COMMENT '租户code',
creator varchar(64)NOT NULL COMMENT '创建者',
gmt_create datetime NOT NULL COMMENT '创建时间',
gmt_modify datetime NULL COMMENT '修改时间'
) ENGINE = InnoDB COMMENT 'sop流程';
CREATE TABLE sop_node (
id bigint(20)NOT NULL AUTO_INCREMENT COMMENT '主键id', site_code varchar(64)NOT NULL COMMENT '站点编号',
site_name varchar(64)NOT NULL COMMENT '站点名称',
sop_id bigint(20)NOT NULL COMMENT 'sop节点id',
flow_id bigint(20)NOT NULL COMMENT '流程id',
sop_type varchar(64) COMMENT 'sop环节类型',
element_id varchar(64)NOT NULL COMMENT '元素id',
business_code varchar(64)NOT NULL COMMENT '业务编码', parent_node bigint(20) COMMENT '父节点id',
prev_node bigint(20) COMMENT '前置节点',
gmt_create datetime NOT NULL COMMENT '创建时间',
gmt_modify datetime NULL COMMENT '修改时间',
creator varchar(64) COMMENT '创建人',
PRIMARY KEY (id)
) ENGINE = InnoDB COMMENT 'sop环节节点';
CREATE TABLE waybill_sop_operate_event (
id bigint(20)NOT NULL auto_increment COMMENT '主键id',
tenant_code varchar(64)NOT NULL COMMENT '租户编码',
site_code varchar(64)NOT NULL COMMENT '站点编码',
site_name varchar(64)NOT NULL COMMENT '站点名称',
waybill_no varchar(64)NOT NULL COMMENT '运单号',
package_no varchar(64) COMMENT '包号',
site_element_id bigint(20)NOT NULL COMMENT '要素id',
external_element_code varchar(64)NOT NULL COMMENT '外部要素编号',
element_type varchar(64)NOT NULL COMMENT '业务要素类型',
sop_type varchar(32)NOT NULL COMMENT 'sop环节类型',
op_time datetime NOT NULL COMMENT '操作时间',
operator varchar(64) COMMENT '操作人',
operator_id bigint(20) COMMENT '操作人员id',
remark varchar(64) COMMENT '备注',
gmt_create datetime NOT NULL COMMENT '创建时间',
gmt_modify datetime NOT NULL COMMENT '修改时间',
PRIMARY KEY (site_code,waybill_no,sop_type)
) DISTRIBUTE BY HASH(site_code,waybill_no) COMMENT '运单sop环节事件表';
CREATE TABLE site_element (
id bigint(20)NOT NULL COMMENT '主键id',
site_code varchar(32)NOT NULL COMMENT '站点code',
site_name varchar(64)NOT NULL COMMENT '站点名称',
tenant_code varchar(64)NOT NULL COMMENT '租户code',
element_name varchar(64)NOT NULL COMMENT '要素名称',
external_element_code varchar(64)NOT NULL COMMENT '业务编号(如外部的设备id)',
element_type varchar(32)NOT NULL COMMENT '要素类型',
parent bigint(20) COMMENT '父节点',
creator varchar(32) COMMENT '创建者',
gmt_create datetime NOT NULL COMMENT '创建时间',
gmt_modify datetime NOT NULL COMMENT '修改时间'
) ENGINE = InnoDB COMMENT '场内要素表';
CREATE TABLE element_camera_relation (
id bigint(20)NOT NULL AUTO_INCREMENT COMMENT '主键id',
site_code varchar(64)NOT NULL COMMENT '站点编码',
site_element_id bigint(20)NOT NULL COMMENT '对应要素id',
external_element_code varchar(64)NOT NULL COMMENT '业务编码', camera_id varchar(64)NOT NULL COMMENT '摄像头id',
container_id varchar(64)NOT NULL COMMENT '容器id',
gmt_create datetime NOT NULL COMMENT '创建时间',
gmt_modify datetime NOT NULL COMMENT '修改时间',
PRIMARY KEY (id)
) ENGINE = InnoDB COMMENT '要素与摄像头关联表';
四、交互图
架构图
未来规划
五、时序图
轩辕镜对接流程
1、创建容器以及绑定ipc
2、订单打点流程,以及视频查询流程
技术选型
选用ADB存储数据,实时计算使用blink,外部消息中间件ons
缓存计划使用Redis
性能、实效性
1.记录秒级查询
2.巴枪数据延迟半小时左右
五、数据来源
数据的来源主要可分为三个来源:
1.机的事件(机主要有三合一、五面扫,交叉带,摆臂)
2.巴枪事件(外部依赖)
由于巴枪和机是有两个团队维护提供的能力也不同,环节又是一个必要的查询条件,所以需要根据巴枪和机的事件分别去反向推导某一操作属于哪个环节,梳理如下。
六、消息结构及内容
巴枪扫描MQ(待确认)
topic:
机事件MQ
三合一&摆臂交叉带
具体消息格式参考星图https://https://www.360docs.net/doc/d110476036.html,/#/iot/doc?_k=u1xgyp topic:
设备id和网点关联关系,机这边会有专门一张表维护,计划元旦出表,331之前对接完江浙沪皖地区厂家(数据不全),使用sls中数据
对接
ons消息字段
七、接口设计
1.视屏回溯
2.物与设备关联
3.小车配置
八、问题
时间同步方案
1.时间戳如何校正,统一的时间服务器。视频如何截取视频,前后推多少时间。
时间同步一个方案
1)天眼盒子可以自己增加一个时间服务同步功能
2)机这边边缘网关可以做时间同步,但是需要厂商配合推广 3)巴枪本身是个android操作系统,可以做时间同步,但是需要开发
2.巴枪的数据吐出他们说要统一的规划@昔年(haoyuan.why)
3.存储问题
1)巴枪绑定工位通过工位来寻找摄像头
2)巴枪带定位功能,通过范围查找寻找摄像头(依赖于lemmo)
3)或通过巴枪下一站来来判断
其他
轩辕镜产品矩阵
接入天眼需要在天眼后台配置一个账号做鉴权使用
JavaWeb应用开发项目设计方案
《Java Web应用开发》项目设计参考方案(学时:84)项目一网上商城项目开发环境的搭建(学时:8) 一、教学目标 最终目标:学会Java Web 开发环境搭建,了解如何在集成开发环境中开发JSP、Servlet程序,能在Web服务器上进行运行测试。 促成目标: 1. 了解JSP、Servlet技术; 2. 了解Java Web 开发模式; 3. 了解Java Web服务器运行条件,掌握如何安装、配置Jdk、Tommcat和集成开。 二、工作任务 1.任务1 Java Web 环境搭建 2. 任务2 简单JSP、Servlet测试 三、活动设计 1.活动思路 首先介绍动态网页技术及相关开发模式,并将相关技术进行比较,从而引出本门课的重点。接着指出建立Web服务器的条件,引出如何搭建Java Web运行环境;最后学习集成开发环境的安装与设置,并学习如何写JSP程序、Servlet 程序,并掌握如何在客户端进行运行测试。 2.活动组织 3.活动评价 评价内容:根据学生具体任务完成情况、课后作业等情况进行评价。 评价标准: 实践部分评价:能基本完成相关软件的安装、环境配置为及格;独立完成相关软件的安装、环境配置,基本能进行代码编写及测试为良好;独立完成相关软件的安装、环境配置,并能进行正确的代码编写及测试为优秀。
模块一 Java Web 环境搭建(学时:4) 一、教学目标 最终目标:掌握浏览静态网页和动态网页的技能,掌握分析网页所采用的技术的技能,能独立完成JSP运行环境的安装及配置 促成目标: 1.了解静态网页中的静态的概念; 2.了解动态网页中的动态的概念; 3. 了解JSP、Servlet技术; 4. 了解Java Web 开发模式; 5.学会JDK、Tomcat的下载、安装及配置。 二、工作任务 1. JDK、Tomcat的安装及配置; 2.浏览各种类型的网页,分析出网页采用的技术; 三、活动设计 1.活动内容 通过浏览多种类型的网页、导出静态网站与动态网站的概念,继而引出对各种网页开发技术的分析,引入JSP动态网页开发技术、开发模式及运行环境;浏览电子商务网站,导出网上商城的项目;分析JSP的基本概念,导出Web服务器的概念,引出JSP常用的Web服务品Tomcat。构建JSP运行环境,为下一步开发工作做好准备。 子任务一:JDK安装与配置 子任务二:Tomcat的安装与配置,服务器运行测试。 2.活动组织
java项目开发实例图书信息管理系统开发及源码
j a v a项目开发实例图书信息管理系统开发及源 码 集团文件发布号:(9816-UATWW-MWUB-WUNN-INNUL-DQQTY-
图书信息管理系统 一、系统功能概述: 根据图书信息管理系统的特点,可以将本系统分为2大功能模块,分别为:基础数据维护、系统数据维护。本系统各个部分及其包括的具体功能模块如下图所示: 二、数据库设计: 图书信息表: 图书类别表: 用户信息表:
读者信息表: 三、系统源代码: ewInstance(); conn = (dbUrl, dbUser, dbPwd); "数据库连接成功!"); } else return; } catch (Exception ee) { (); } } xecuteQuery(sql); } catch (SQLException e) { ();
return null; } finally { } } xecuteUpdate(sql); } catch (SQLException e) { quals("[Microsoft][SQLServer 2000 Driver for JDBC][SQLServer]DELETE 语句与 COLUMN REFERENCE 约束 'FK_TB_BORRO_REFERENCE_TB_BOOKI' 冲突。该冲突发生于数据库 'db_library',表 'tb_borrow', column 'bookISBN'。")) return -1; } finally { } } etLayout(borderLayout); setIconifiable(true); dd(panel); final JLabel label_2 = new JLabel(); ("图书编号:"); (label_2); ISBN = new JTextField("请输入13位书号",13); (new MyDocument(13)); dd(panel_1, ; final FlowLayout flowLayout = new FlowLayout();
javaweb开发要学习的所有技术和框架总结:
学习javaweb开发要学习的技术和框架总结: 前言:当初想学习javaweb开发的时候,希望能够全方面地学习(这样找工作时就胸有成足了)。但是对这个根本不理解,又不认识从事这方面的熟人,所以学习起来无从下手。经过了一年的‘死’学习,从网上,从书本,从视频里面深入了解了java。想从事java的朋友,只要把这些技术全学会了,哪就业肯定没有问题了。 前端技术: HTML, CSS, JA V ASCRIPT, JQUERY, AJAX HTML “超文本”就是指页面内可以包含图片、链接,甚至音乐、程序等非文字元素。 超文本标记语言的结构包括“头”部分(外语:Head)、和“主体”部分(外语:Body),其中“头”部提供关于网页的信息,“主体”部分提供网页的具体内容。 CSS 级联样式表是一种用来表现HTML(标准通用标记语言的一个应用)或XML(标准通用标记语言的一个子集)等文件样式的计算机语言。 JavaScript JavaScript一种直译式脚本语言,是一种动态类型、弱类型、基于原型的语言,内置支持类型。它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在HTML(标准通用标记语言下的一个应用)网页上使用,用来给HTML网页增加动态功能。 jQuery jQuery是一个兼容多浏览器的javascript库,核心理念是write less,do more(写得更少,做得更多)。jQuery在2006年1月由美国人John Resig在纽约的barcamp发布,吸引了来自世界各地的众多JavaScript高手加入,由Dave Methvin率领团队进行开发。如今,jQuery已经成为最流行的javascript库,在世界前10000个访问最多的网站中,有超过55%在使用jQuery。
Java Web项目开发总结
1、In Action (1)根据添加信息(insert)来考虑表中的字段,进行建表。使用PD画出ER图。要注意字段的数据类型的确定以及建表要满足三范式,减少数据冗余; (2)表建好后,根据表中各个字段来建pojo中的属性。要注意属性的数据类型和字段的数据类型要一致; (3)根据pojo中的属性确定bean的属性,直接拷贝即可,用于页面展示。在bean中,统一使用String类型变量接收前台页面传递的参数;每个HTML表单对应一个bean。HTML 表单中的字段和bean中的属性一一对应。 (4)自顶向下,依次定出action、manager、dao。先写出轮廓,跑通整个流程,再写具体实现,一点点累加,便于调试错误; (5)根据数据实体和具体业务逻辑,使用StarUML画类图,进行OOA和OOD,灵活运用设计模式。 (6)API命名: CRUD:add,get,update,delete,[list] 严格区分单复数形式,单数表示对象,复数表示对象集合。 对象、属性最好单个单词。 (7)前后台都要校验。 (8)按照资源方式组织数据接口,对前端开发帮助很大。即通过REST来实现资源的增、删、改、查。 (9)软件开发,思路最重要!代码开发多了,思路就有了。 a、一个版本一个版本递增的开发;每个版本增加一点内容; b、总结开发思路;第一步怎么做,下一步怎么做? c、用文档记录开发的思路,即第一个版本开发实现了什么功能以及开发步骤,下一个版本实现了什么功能等等?
d、程序员进行程序开发时,不要仅仅停留在代码,要深入到底层的运行机制,才可以对程序的运行机制有更准备的把握; (10)网页模板 request到template.jsp文件(此文件假设包括三个部分,即title、banner、body) web客户——> title banner———————>include:banner.jsp body————————>include:showcart.jsp (11)一步一步的定位。根据结果进行分析。 (12)分页控件 假分页: 基本思想是将所有的数据从数据库中取出,只显示有用的部分。靠的是程序的算法,实际上就是在ResultSet上进行操作。 真分页:(数据库中的一种实现) 任何数据库都会提供分页的函数操作:Oracle、MySQL(limit,即limit 开始的记录, 要查询的行数)、SQL Server(top) 基本思想是在数据库中编写特定的SQL语句。程序中只读取有用的部分,没用的部分不会加载到内存中。 (13) 2、TIPS
实验五java项目开发实例
实验五Java项目开发实例 实验目的: 掌握运用RAD开发Java应用程序 目标要求: 1.掌握运用Visual Editor创建窗口应用程序 2.掌握通过JDBC连接数据库 内容简介: 本章将介绍MyLibrary的 GUI应用程序。 实验说明: 第一节创建GUI应用程序 1.添加JDBC环境变量 在菜单栏点击“文件 -> 新建 -> 项目”,选择“Java项目”,点击“下一步”。 输入项目名称“MyLibraryGUI”,点击“下一步”。 在Java设置中选择“库”栏,点击“添加变量”。在“新建变量类路径条目”对话框
中点击“配置变量” 在“类途径变量”对话框中点击“新建”按钮,会弹出“新建变量条目”对话框。在“名称”栏中输入“CLOUDSCAPE_DRIVER_JAR”,然后点击“文件”按钮,找到D:/Program Files/IBM/Rational/SDP/runtimes/base_v6/cloudscape/lib/,如下图: 点击“确定”。再次点击“确定”。在弹出对话框点击“是”。 在“新建变量类路径条目”窗口中选择 ,点击“确定”。
这样就在MyLibraryGUI项目里添加了Cloudscape 的JDBC驱动。点击“完成”按钮。 2.新建可视类(Visual Class) 在菜单栏选择“文件 -> 新建 -> 其它 -> Java -> 可视类”,点击“下一步”。 在“Java类”窗口,“包”文本框输入,“名称”文本框输入“MyLibraryDesktopApp”,“样式”选择“Swing -> 框架”(选择后“超类”变成),点击“接口”右侧的“添加”,输入ActionListener,点击“确定”。勾选“pulibc static void main(String[] args)”,点击“完成”
java-WEB模块物流项目一
BOS物流管理系统第一天搭建环境 内容安排: 1、运行项目,分析功能结构 Struts2 通配符映射,将所有页面放在WEB-INF下 2、项目改造为maven结构 项目使用STS 3、jQuery EasyUI 框架 常用各个布局插件、Ztree菜单技术 学习目标:maven 、svn 、eclipse 工具、掌握前端开发框架EasyUI 1.BOS项目概述 1.1.项目背景 什么是BOS? (Business Operation System) ,各个软件最核心业务系统 用友软件公司为宅急送公司开发ERP系统---- 核心系统 BOS一期工程C/S结构,二期工程B/S 结构 传统项目分类:OA 自动化办公系统、CRM 客户关系管理系统、ERP 综合管理平台
1.2.项目开发任务 项目完整开发流程: 需求分析(需求分析文档)----- 系统设计(页面原型设计jquery easyui 、数据库设计PowerDesigner )------ 编码----- 测试----- 集成部署和运维 BOS系统非常庞大,十几天学习哪些功能
涉及三大核心业务模块:基础设置模块、取派模块、中转模块 基础设置模块:管理物流信息基础元素信息(快递员、配送区域、配送时间、排班…)取派模块:客户要进行快递,系统进行业务受理、系统分单到快递员、快递员取件、打包、计费 中转模块:管理货物在配送路程中间数据 路由模块:管理车辆和线路 财务模块:计费 PDA模块:管理快递员无线电通信 报表模块:生成统计数据 用户权限管理:通用权限管理系统Apache Shiro
1.3.项目开发平台和技术 新建一个Maven工程mavenbos 1.4.导入原型页面 配置说明pom.xml 导入参照下发pom.xml 文档!
多层技术架构JAVA
多层技术架构 本系统构建于J2EE平台,采用分层提供服务支持的设计思想,将系统划分为数据库层、中间件层、EMALL基础服务层、业务表现层和系统接口层。系统对每一层定义明确的功能接口,同时在层次内实现组件化的接口实现。层次化、模块组件化的实现,使系统具备了最大程度的灵活度,从而能对业务需求的变化作出快速的反应,使系统具有很好的扩展性。 首先我们来看一个系统技术架构图: 上图可以清晰的了解到整个系统的层次划分,系统从最底部的数据库层开始,一层一层的向上提供接口服务,最终实现用户按业务要求的可见操作界面和其他系统接口。各层次专著于自身功能的接口实现,整个层次保持相对的稳定。系统通过不改变接口,各个层次、各个组件进行优化的策略,能在不影响整个业务的前提下,不断的完善和改进。 一、数据库层 对于平台中的所有应用,都存在着各种各样的配置信息、业务数据、系统运行状态等信息。数据库层对这些数据信息本身进行归档,提供快速查询的底层接口,并保证数据的完整性、可靠性。 在数据库方面,我们采用Oracle或者是MySQL。这两种数据库分别有不同的适用环境。 1、Oracle ◆适合大型的电子商务应用。 ◆能使用所有的网客通平台功能。如访问量排行榜、降价排行榜、销售排行榜、访问量统计等等,就以往的经验来看,这些功能每天要处理的数据都会超过一千万。这种数据量如果使用传统的统计方法,统计一次的时间就可能会以天来计算了。如果使用Oracle,再配合我们专门对Oracle进行优化的高效率的统计程序,那么只需十数秒便可完成。 ◆此外,如果只用一台数据库无法应付日益增长的服务器访问量,可以使用Oracle RAC(真正应用集群),通过增加数据库服务器进行集群。 2、MySQL ◆适合中小型的电子商务应用。 ◆无法使用网客通平台一些高级应用,如排行榜、统计分析、MIS系统对接等。这是由于MySQL设计上强调访问速度,牺牲了一些数据库的高级功能,虽然用程序也可以实现这些功能,但是在性能上无法满足需求。 ◆不支持数据库集群。
JAVA编程实例大全及详解答案(50例)
JA V A编程实例大全及详解答案(50例) 【程序1】 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? //这是一个菲波拉契数列问题 public class lianxi01 { public static void main(String[] args) { System.out.println("第1个月的兔子对数: 1"); System.out.println("第2个月的兔子对数: 1"); int f1 = 1, f2 = 1, f, M=24; for(int i=3; i<=M; i++) { f = f2; f2 = f1 + f2; f1 = f; System.out.println("第" + i +"个月的兔子对数: "+f2); } } } 【程序2】 题目:判断101-200之间有多少个素数,并输出所有素数。 程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数。 public class lianxi02 { public static void main(String[] args) { int count = 0; for(int i=101; i<200; i+=2) { boolean b = false; for(int j=2; j<=Math.sqrt(i); j++) { if(i % j == 0) { b = false; break; } else { b = true; } } if(b == true) {count ++;System.out.println(i );} } System.out.println( "素数个数是: " + count);
黑马程序员javaweb教程:案例--注册功能
案例--注册功能 1功能说明 没有人不知道什么叫注册功能吧! 我们这里的注册功能很简单,给用户提供一个页面,在页面中给出一个注册表单,用户输入自己的注册信息(用户名和密码)。然后提交表单,把请求发送到Servlet,Servlet会把用户的注册信息保存到XML文件中。完毕! 我们也不打算让Servlet做太多的事情,所以真正保存信息的工作还是交给DAO来做吧!所以在Servlet中只是获取DAO对象,然后调用DAO的方法来完成保存信息! DAO – Data Access Object(数据的存取工作,由这个对象来完成!) ●User :这是我们注册功能的唯一数据类! 不能用业务数据做主键(唯一标识!) username:用户名是唯一的! password email:唯一的! 2项目分析 用户通过注册页面的表单向Servlet发送请求,Servlet获取DAO对象,然后调用DAO 对象的方法save()方法完成向XML文档中保存注册信息。 ●reigst.jsp:包含注册表单的页面,提交表单会把请求交给RegistServlet来处理; ●RegistServlet:注册Servlet,包含doPost()方法。获取DAO对象,然后调用DAO对 象的save()方法传递User对象(注册信息领域对象)过去,由DAO完成保存注册信 息; ●RegistDao:只有一个save(User)方法,会使用DOM4J完成把User保存到XML文件 中; ●RegistDaoImpl:为了更好的处理耦合的问题,我们把RegistDao定义为接口,而 RegistDaoImpl为其实现类; ●User:领域对象,用来封装注册信息。最终还需要把它转换成XML数据持久化! ●user.xml:因为我们现在没学数据库,只能使用XML作为存储数据的工具。 总是从无依赖开始! 3从注册页面开始