使用Oracle Stream Analytics 21步搭建大数据实时流分析平台
概要:
Oracle Stream Analytics(OSA)是企业级大数据流实时分析计算平台。它可以通过使用复杂的关联模式,扩充和机器学习算法来自动处理和分析大规模实时信息。流式传输的大数据可以源自IoT传感器,Web管道,日志文件,销售点设备,ATM机,社交媒体,事务数据库,NoSQL数据库或任何其他数据源。
OSA为业务用户提供了动态创建和实施即时洞察解决方案。它允许用户通过实时图表,地图,可视化视图来实时浏览实时数据,并以图形方式构建流传输管道,而无需进行任何手工编码。 OSA使用与Oracle连续查询引擎集成的Apache Kafka和Apache Spark Streaming在可伸缩且高度可用的集群大数据环境中执行。
OSA广泛应用于以下场景,以解决现代企业中的关键实时用例:
- 金融服务:实时反欺诈,实时风控,实时营销。
- 交通运输:公共交通,车辆调度,集装箱追踪。
- 运营商:精准营销,网络管理,“万物互联”。
- 零售:个性化推荐,动态定价,货架管理。
- 制造业:智能库存,品质管控,预测性维护。
- 公共安全:平安城市。
本文我们将介绍如何使用Oracle Stream Analytics实现实时数据采集,实时数据处理,实时数据可视化以及实时数据同步到大数据平台的整个过程。
Oracle DB→Oracle GoldenGate→Kafka→OSA REST→HBase
具体场景及工具如下:
测试环境说明如下:
整体步骤大致如下:
- 源端数据同步及KAFKA准备
- OSA安装及HBASE配置
- OSA配置
详细步骤如下:
源端数据同步及KAFKA准备
1.在源端数据库Enable GoldenGate并创建测试表
2.配置源端Golden Gate实时数据捕获
3.部署并配置GoldenGate for BigData
- OGG for BigData无需安装,只需解压即可使用
- 编辑配置文件:kafka.props,custom_kafka_producer.properties
4. 拉起extract, pump, replicat进程
Oracle stream analytics安装及Hbase配置
5. OSA安装
OSA下载链接如下:
Oracle Stream Analytics Downloads
目前最新版本为19.1,按照官方安装文档进行安装。
6.HBase的安装及测试表创建
安装并创建同步测试表:
Oracle Stream Analytics配置
下面将详细介绍OSA配置过程:
7.登录OSA
osaadmin为OSA预制用户
8.进入OSA界面,选择【Catalog】选项
9.选择创建新连接选项,点击【Create New Item】
10.创捷连接选项,输入连接名称,连接类型选择【kafka】
并在kafka bootstrap里输入broker地址,测试连接成功
11.创建新的流数据,点击创建【Create Stream】
类型选择【kafka】选择之前创建的连接,输入Topic名称,选择数据格式【JSON】。
topic名称为OGG for bigdata配置文件里指定的Topic
12.预先定义好JSON数据格式的文件如下:
下面定义可以从kafka消费信息中获取,使用bin/kafka-console-consumer.sh
13.OSA支持的数据格式有【CSV】,【JSON】,【AVRO】
这次使用的为上述预定义好的JSON格式
14.创建Custom Jar,选择创建【Custom Jar】
输入名称,选择类型为【Custom Jar】,在Jar URL上指定预先创建好的java程序
需要使用Custom Jar获取流数据并且进行Base64加密处理,Hbase上使用Rest进行操作时,仅支持Base64加密过的数据的增删改查。
注意: Custom Jar所使用的Java程序可以只做针对Event的Base64加密处理
REST可以在OSA上添加REST类型的Stage执行写入到Hbase
OSA目前版本尚未支持流数据base64加密输出
本文使用Java示例程序执行Base64加密及REST操作写入到Hbase
15.创建Pipeline,选择创建【Pipeline】
指定名称,选择上述已创建好的Stream,并且保存。
16.添加已创建的Custom Stage到Pipeline上
右击Pipeline上的Stream标识,选择【Custom Stage from Custom Jar】
17. 指定【Custom Stage】名称,点击保存
18.在Custom Stage的配置选项,我们选择之前已经上传的Custom Jar对象
19.在【Input Mapping】选项,需要把Stream内容和Custom Stage进行关联
并且点击【Publish】发布
注意:如果不选择Publish则无法把OSA输出进行写入操作到Hbase
JOB_ID=after_JOB_ID、JOB_TITILE=after_JOB_TITLE、MIN_SALARY= after_ MIN_SALARY 、MAX_SALARY= after_ MAX_SALARY
20.【Publish】的Pipeline将被锁定,如需更改配置点击【Unpublish】进行更改
Publish的Pipeline如下:
在下方可以看到实时流数据的监听
21.至此为止,OSA端的配置已完成。最后一步为测试与演示。
测试与演示
1.源端数据库插入一条数据并提交
2.OGG源端捕获确认(Extract和Pump)
3.OGG目标端Kafka投递确认
4.Kafka端消费信息确认
5.Kafka端显示以下纪录已经消费,OP_TYPE代表操作类型,
OP_TYPE=I ,I表示这是一条INSERT插入操作。
6.查看OSA Stream监听状态
点击【kafka-stream】图标,可以看到该条记录已经被Kafka Stream正确的监听
7.查看OSA输出结果
点击【restapi】图标,可以看到OSA输出结果
8.使用HBase写入确认
从HBase的HR_JOBS表中,可以看到源端插入的数据已经写入到该表中
写在最后
Oracle Stream Analytics 还具有以下产品特性:
1.提供友好的图形交互页面,集成可视化并可以通过Java语言进行扩展
2. 提供丰富的内建流模式库并可通过Java进行扩展
3. 与位置和地理空间功能集成
4. 预测分析与机器学习集成
5. 可对接Druid Superset
Oracle Stream Analytics支持Continuous Query Language (CQL) ,构建于分布式分内存计算网格框架之上,使得查询处理的性能可得到线性增长。学习成本低,使得业务人员和开发人员可以更大限度的关注业务而非应用技术架构。是您快速构建企业级大数据流实时分析计算平台不二之选。
使用Oracle Stream Analytics 21步搭建大数据实时流分析平台的更多相关文章
- 基于Hadoop生态SparkStreaming的大数据实时流处理平台的搭建
随着公司业务发展,对大数据的获取和实时处理的要求就会越来越高,日志处理.用户行为分析.场景业务分析等等,传统的写日志方式根本满足不了业务的实时处理需求,所以本人准备开始着手改造原系统中的数据处理方式, ...
- Impala简介PB级大数据实时查询分析引擎
1.Impala简介 • Cloudera公司推出,提供对HDFS.Hbase数据的高性能.低延迟的交互式SQL查询功能. • 基于Hive使用内存计算,兼顾数据仓库.具有实时.批处理.多并发等优点 ...
- 腾讯云EMR大数据实时OLAP分析案例解析
OLAP(On-Line Analytical Processing),是数据仓库系统的主要应用形式,帮助分析人员多角度分析数据,挖掘数据价值.本文基于QQ音乐海量大数据实时分析场景,通过QQ音乐与腾 ...
- 大数据时代日志分析平台ELK的搭建
A,首先说说ELK是啥, ELK是ElasticSearch . Logstash 和 Kiabana 三个开源工具组成.Logstash是数据源,ElasticSearch是分析数据的,Kiaba ...
- 大数据应用之Windows平台Hbase客户端Eclipse开发环境搭建
大数据应用之Windows平台Hbase客户端Eclipse开发环境搭建 大数据应用之Windows平台Hbase客户端Eclipse环境搭建-Java版 作者:张子良 版权所有,转载请注明出处 引子 ...
- 一台虚拟机,基于docker搭建大数据HDP集群
前言 好多人问我,这种基于大数据平台的xxxx的毕业设计要怎么做.这个可以参考之前写得关于我大数据毕业设计的文章.这篇文章是将对之前的毕设进行优化. 个人觉得可以分为两个部分.第一个部分就是基础的平台 ...
- 12.Linux软件安装 (一步一步学习大数据系列之 Linux)
1.如何上传安装包到服务器 有三种方式: 1.1使用图形化工具,如: filezilla 如何使用FileZilla上传和下载文件 1.2使用 sftp 工具: 在 windows下使用CRT 软件 ...
- 搭建大数据hadoop完全分布式环境遇到的坑
搭建大数据hadoop完全分布式环境,遇到很多问题,这里记录一部分,以备以后查看. 1.在安装配置完hadoop以后,需要格式化namenode,输入指令:hadoop namenode -forma ...
- 我搭建大数据Hadoop完全分布式环境遇到的坑---hadoop: command not found
搭建大数据hadoop环境,遇到很多问题,这里记录一部分,以备以后查看. [遇到问题].在安装配置完hadoop以后,需要格式化namenode,输入指令:hadoop namenode -forma ...
随机推荐
- Webstorm 配置 Less编译
配置less编译
- AndroidStudio手动安装插件
由于网络原因,android studio 的插件市场经常不能打开或者不能下载,这种情况我们可以手动下载插件的压缩包,再手动安装. 第一步,打开https://plugins.jetbrains.co ...
- 驳“C语言已经死了”
http://blog.csdn.net/xushiweizh/article/details/1476422
- JMeter分布式负载测试(吞吐量控制器)
在本节中,我们将学习如何使用吞吐量控制器在JMeter中创建分布式负载测试计划. 出于测试目的,我们将在我们网站 www.yiibai.com 的URL下的某些网页上创建分布式负载.这些网页包括: 主 ...
- 解决Win10电脑右下角的“激活windows转到电脑设置”的水印的方法
Win10正式版的用户反馈新系统在使用一段时候后,自己电脑桌面右下角就突然出现了“激活windows10转到设置以激活windows”的水印字样.这是怎么回事呢?下面,我就向大家分享win10电脑右下 ...
- 解决Jsp与Java后台之间url传值中文乱码问题
JSP页面中,由JavaScript拼接url时,对于中文名称变量应该加上encodeURIComponent方法,对中文进行十六进制编码. 例如: url = /com/xxx/B.jsp?chin ...
- 公子奇带你一步一步了解Java8中行为参数化
说明:因为本公子一直从事监狱软件开发,所以本系列博客的引入也以此为背景.问题做了简化,只是为了来讲解技术点. 一.问题提出 今日在好好的撸着代码,超哥(民警)找来了,让把监狱30岁以上的民警找给他. ...
- vue 源码 学习days8-比较两个对象的方法
// 在面试中可能会遇到, 思想重要 // 比较两个对象是否是相等的 两个对象 // 1. js 中对象是无法使用 == 来比较的, 比是地址 // 2. 我们一般会定义如果对象的各个属性值都相等 那 ...
- EF 学习系列二 数据库表的创建和表关系配置(Fluent API、Data Annotations、约定)
上一篇写了<Entity Farmework领域建模方式 3种编程方式>,现在就Code First 继续学习 1.数据库表的创建 新建一个MVC的项目,在引用右击管理NuGet程序包,点 ...
- 机器学习实战笔记(一)- 使用SciKit-Learn做回归分析
一.简介 这次学习的书籍主要是Hands-on Machine Learning with Scikit-Learn and TensorFlow(豆瓣:https://book.douban.com ...