|
数据集成指的是把分散在各个系统中的各种类型的数据统一汇聚起来,而数据集成系统就是提供数据集成能力的平台。如何做好一个数据集成系统呢?本文作者对此进行了分析,一起来看一下吧。; E7 r$ y' I$ X( L
: Z' A+ ]3 l- v) G) D: T. P
) T! K# o2 W9 R9 ~
4 q: p. ^2 v0 K0 H& D一个风雨交加的晚上,领导把我拉到会议室说:老影啊,公司接到一个项目,需要在 3 个月里完成一个大数据平台的开发,用于项目的交付,这个任务交给你了,加油搞!此刻的我:搞?搞事情啊!由此我开始了数据平台的 " 闯关之路 ",遇到的第一个 boss 就是数据集成系统……$ O9 V9 x$ X+ d7 P& N: l
01 什么是数据集成?
: ]% d: Y0 ~" P( h1 X百科里的解释是:把不同来源、格式、特点性质的数据在逻辑上或物理上有机地集中,从而为企业提供全面的数据共享;通俗讲就是把分散在各个系统中的各种类型的数据统一汇聚起来,主要体现在一个 " 集 " 字。而数据集成系统就是提供数据集成能力的平台,是一站式解决异构数据存储互通,消除数据孤岛的同步平台,为大数据各系统和业务方提供数据集成的高效通道 。
; e0 M+ _, d6 L# Z: O拿现实中的实例类比来说,数据集成就好比把各种粮食通过不同的管道灌输到一个大粮仓中,这些管道就是数据集成系统,我们可以支持接入各式各样的粮食,小麦、玉米、大豆等等,同时支持在这些管道中加一些滤网,比如在大豆的管道中加上 5mm 的滤网,此时从大豆管道过来的粮食只有 5mm 以下的大豆,这就相当于数据集成系统中的数据过滤功能;这个粮仓相当于集成目的,我们把数据集成进来之后存储在这里,供其他各方消费。
: u: X# U1 v7 N& a- m$ l" u 02 教育为什么要做数据集成?
) |2 Q! X- i2 }( T- \ 1. 数据大爆炸
1 G# S8 F0 l) A& V( i$ ~0 }现在是一个信息大爆炸时代,互联网的高速发展、迅速普及,让信息无处不在、无孔不入,每天在我们所生活在的这个世界出现了大量的信息,教育场景下也不例外,随着各种信息化系统的涌入,信息以空前的速度增长,教育从业者体验着信息时代便捷的同时,也给他们带来了问题和 " 副作用 ",从浩如烟海的信息海洋中迅速而准确地获取他们最需要的信息,变得非常困难。' Y: Y) v7 c& B- g
2. 数据来源多样化" u$ m5 U- E2 x' X$ E$ S" R
随着《教育信息化 2.0 行动计划》的提出,教学过程中的信息化系统越来越多,比如作业系统、考试系统、选课系统、智慧课堂等等,每个系统都会产生大量的数据,存储在各自的数据库中,如果系统的服务商不同,可能数据的格式也不一样,致使教育场景下的数据越来越多,越来越难以管理。+ @9 l( G4 c B$ @& J$ {/ p: A; p
3. 数据集不同结构: _- F* t! E8 h0 A% N' O
教育场景下的数据集可能是结构化的、半结构化的,甚至非结构化的;比如:考试系统中的数据是结构化的,评价系统中的数据是半结构化的,课堂实录中的数据是非结构化的;不同结构的数据需要整合成统一的结构才能够进行统计和分析。) h' n# c! I0 V% E. u* S' W
4. 数据冗余
9 V8 z/ A) D5 ^* G数据中有很多冗余、错误、敏感数据,如果不进行数据清洗,会影响数据分析的效率和结果;在这种情况下需要我们配置统一的标准,对数据进行简单的处理,以便于后续进行统计分析。9 g) Y+ N. J' q' p2 Q4 f1 i. [
03 数据集成系统对教育的价值是什么?
* R1 Y8 t3 I) b% B* W$ J; S, {大数据技术能够将隐藏于海量数据中的信息和知识挖掘出来,按照科学的教育评价准则,对教学数据进行科学的统计分析,提供有价值的教学质量测评与分析数据,实现对教育活动,教育过程和教育结果的价值评判,为提高教育质量,教育决策以及学校改进日常教学方法提供科学的依据,实现教育管理的智能化,提升教育管理与服务水平。, ?2 W. F3 Z+ i* w' m
数据集成系统作为底层基础支撑性服务,是大数据系统的核心组成部分。通过提供数据集成能力,将教育各部门和来自互联网的结构化和非结构化的数据进行统一的汇聚接入,存储到大数据存储组件,并支持数据的预处理,为大数据系统提供原始数据支撑。; H" ?6 j' ^6 `6 l
04 数据集成系统怎么做?# e& z' [5 U7 c3 ^; G* t7 F5 q0 }
1. 建设原则
/ V& q& \7 ?3 _9 D数据采集系统针对实际项目中复杂的、异构的数据环境,实现对多种数据源的集成,支持的关系数据库有 Oracle、MySQL、Sqlserver 等,支持的文件类型有 txt 文件、csv 文件、excel 文件等,支持的接口类型有 webservice 接口、http 接口、socket 接口等。
T; E( L: Z% `, W- R. W对于不同的大数据存储需求,实现对多种大数据存储组件的支持,支持的大数据存储组件包括 HDFS、HBase、Hive、Solr、Elasticserach 等。
; {1 d1 _- y# _针对数据的预处理需求,实现对数据的清洗、转换、标准化等预处理的支持,并且支持清洗规则、转换规则的用户自定义,以及清洗、转换、导入流程的用户自定义。
6 _9 w C- w) G! B) [: s, g在数据采集系统中,各类功能点模块化、组件化,便于步骤独立,保证系统内部模块自治,同时便于多种步骤、方法的组合应用。 Z9 ?6 ~! L, _7 x, [8 R. i) a
简化用户操作,通过图形化的配置方式,简单,灵活,使得用户无需过分关心数据库的各种内部细节,而专注于功能。
, D9 O# }2 b8 p# n. t- k$ c$ b 2. 数据集成信息框架$ g: v+ t. }, F7 t2 P9 p! g4 x
* L. O+ R8 {1 I2 d3 B. Z5 @% c# K1 k a& O" u
/ U) l+ @) k* z6 _/ @2 `
数据集成信息流
& t' ^# |3 A" y& X2 p+ x 3. 功能结构
! \1 m* P) v( @6 e* ^: Z R为了快速实现数据集成系统,满足后续项目交付,经过和研发大佬的多次沟通,优先实现为业务提供数据集成的能力的数据源管理和集成任务管理。明确了第一版需求,只要包含数据源管理和集成任务管理就可以支持项目交付,因此功能结构设计如下:6 b/ R$ B, P* o* b
; o6 w$ f0 A% ~$ w, t: h4 Z) A; @( F
2 `" Q( Q7 c4 a4 h5 \ W3 T9 Q# d
数据集成系统功能结构图
. S! E P r; u 4. 建设内容) s# w& B' g9 u' l; o
1)数据源管理7 D7 g0 j/ S2 A8 c! ~
数据源模块主要管理平台支持的数据组件的基础信息,包含各种数据组件的新增,配置和管理,如关系型数据库的数据库 IP,端口,访问信息等。这里大家可以理解为一个中间层,先通过数据抽取组件将各系统数据抽取到这里,以备后续集成任务管理模块的调用。
* X7 O8 o5 Q% @在这里可以对数据源进行增删改查,前提是需要和数据来源方沟通好,需要提供数据库 IP 相关信息,下方是页面示例:' j/ B; I3 b$ g5 i
+ o% ~& `7 k0 X$ u, s( C/ T! C5 X) g0 z; Y
8 V. |8 F. e m4 R% }; g- w( q
数据源管理列表: b6 [9 [7 G9 k8 D" Z
2)集成任务管理
; o5 X. L7 k$ q6 C. O: a当用户创建好数据源之后,需要有一个模块支持用户创建集成任务,相当于上文中讲到的,上游的所有粮食都准备好了,需要我们提供搭建管道的地方,让用户把所有的管道搭起来,然后把各种粮食都汇聚到一起。此时集成任务管理模块诞生了,这个模块下主要对数据集成的任务进行统一的管理,支持用户对数据集成任务进行增删改查。+ n9 t7 g- n7 h% X# |5 b
①操作列表功能
1 b0 r) q1 ^9 n) H4 a/ v0 ?上线:集成任务完成创建状态默认为未上线,此时用户可将集成任务上线,上线为就绪状态;
, m: C, J+ Z! H: r; e运行:上线状态下的任务支持运行,运行自动调用任务执行组件,开始数据集成;
0 q( Z; P9 _8 B4 }8 v下线:已上线的任务支持下线; C# y" W& V+ O$ E' H0 R
删除:未上线和已下线的任务支持删除;# S+ b: G2 W3 H% U) K
编辑:未上线和已下线的任务支持编辑。
% C* d }# u3 F, J/ |( V$ E
2 N0 B6 z' X& u- r6 W2 M) S; _2 D" z l9 R& k. E
8 Q6 E' t9 j. K T# ?$ `
数据集成任务列表
z- H5 k$ k" b+ V* p' C②任务运行
% f4 a# d, }$ u) z) ^3 X+ n" B集成任务创建好之后,如果需要周期性的拉取数据,这时候需要支持进行例行周期配置,支持用户配置定时任务;) j, ?( Q+ o7 U
同时支持用户进行失败策略、任务执行优先级等相关参数的配置。
5 l0 y, u$ e) [6 O& _! j( i7 f9 q' `3)新增集成任务6 g9 Q0 H4 z' [% a8 f# N
为了方便用户填写,支持用户选择不同的数据源类型,数据接口类型不同,需要配置的参数信息也不同;但是总体来说数据集成主要分为三步:
7 H4 }1 \- v5 |* `2 {数据接入:回答数据从哪来的问题;
% F n [% Z$ B! J5 h ?6 c数据处理:回答对数据要做什么的问题;) g, O* v; d. P& N/ g
数据输出:回答数据要到哪去的问题。4 f6 G1 t0 n; ? W, w0 ?+ u
下方以将第三方数据库数据集成到 hive 中为例举例说明。选择数据库之后,页面进入数据集成任务配置页,三个步骤依次如下:' e* ~6 q9 M0 O* {
①数据接入
6 e: v, ~7 F/ e+ D6 V: X主要配置数据源相关信息,需要用户填写数据源表相关信息:
0 p3 U. h. @6 Y+ i% F. L2 Q数据源:数据集群相关信息;4 _# c* N! @( _% `& k
数据库:源数据存储数据库;. H( n4 m+ Q8 F0 _+ I0 ]' K- ? D
是否分表:如果分表存储需要从多个表抽取数据;8 x7 k. q# _& T5 M1 E. g' V+ Z
表名:源数据所在表名;
) Q/ l3 t4 Z$ v$ A/ r数据归属产品 / 系统:这部分数据在目录管理系统维护,这里直接引用;
8 d' w# M/ |$ i8 ], G" j数据预览:支持用户对所选表进行预览,查看数据格式。$ A$ d. R4 w3 k5 p9 C
; L* T. J8 [ k* h* {! R6 u: C) z0 w) j* e. E& g# q; k) @0 Y
?0 k$ d$ W/ |, w: d: [数据接入
: c. s7 l$ A7 a# m- x( q& ]* g2 R②数据处理- y, h4 N6 ], h0 u
到在数据集成过程中会对数据进行预处理,考虑到后续的扩展性,这里直接将各种处理步骤提炼为公共组件,支持用户自定义选择,第一期可支持:字段映射过滤、账号匹配、数据脱敏、数据转换;为了节省操作,数据处理默认以字段映射过滤开始,自动选择一项,用户可直接点击下一步。
+ _: ^( Z/ r. f9 B
) V) O3 C, X7 N" }
- q; S# H4 i. [% c; D( R8 e1 v9 Q9 `. V
数据处理. {' c* T7 a% X
③数据输出. E' R$ j$ | M/ j; {5 x1 z1 s9 q
此时的数据经过预处理,已经完成了清洗、转换的操作,接下来就需要将处理完的数据存下来,以备后续使用。9 L- |% K( A( X6 ]+ p& b
( ^5 |5 c, z2 }6 z0 ^8 M5 a' n4 `' |2 n. l6 u5 d) Y$ G
. x3 _/ @+ h8 B0 K
数据输出
( J0 O/ U9 o% K' ]& s 05 数据集成结束后做什么?6 c/ f8 P' E m2 ^5 x$ [7 I
下面以学生画像的思路和大家简单聊聊。通过从各个系统中采集过来的数据,包含但不限于:学生上网数据、网页浏览时长、作业完成数据、作业完成时长、课堂互动数据等等,帮助学校管理者针对学生群体进行标签化分析。帮助教育管理者从学习,网络行为,生活等多维度分析学生群体的习惯和特点,为学校实现个性化培养教育提供数据支撑。
6 n0 d# @1 Q+ n) T0 x学生画像整体分为个人画像和群体画像:
`4 p& b4 j* E% f0 [. x1)群体画像1 ]. o3 T- `& |3 d" o( D
通过对学生行为数据和结果数据的分析,为每个学生贴上具有行为或思想的特征标签,并按照群体分类,教育管理者可以查看每个分类的人群特征,并从学校、年级、男女比例等各方面进行群体标签的分析,帮助学校定位不同标签人群的特征和规律,实现精细化管理,同时通过对不同行为数据进行阈值设置,及时发现出现问题的学生,以便进行及时纠偏。
7 C* k) V; Y& Y2)个人画像7 z/ l6 O. V! y W/ f
通过采集学生各场景数据,如学习行为、学习结果、消费信息、饮食信息、运动信息等,综合分析学生的学习状态,全面刻画学生画像,帮助教育管理者全方位了解一个学生,通过多维度分析学生的学习习惯和学习动机,逐步实现喊了 2000 多年的口号 " 因材施教 "。
$ C# j* L% R( w1 b* w1 k& C$ q- Q$ _2 G作者:一丁," 数据人创作者联盟 " 成员。
/ c. Q5 B5 A3 j5 j; Q* i本文由 @一个数据人的自留地 原创发布于人人都是产品经理,未经许可,禁止转载。
0 e; u: V! D- P) s6 D题图来自 Unsplash,基于 CC0 协议。 |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
|