• 数据仓库架构详解


    一、基本概念

    数据仓库Data Warehouse)是一个为数据分析而设计的企业级数据管理系统。数据仓库可集中、整合多个信息源的大量数据,借助数据仓库的分析能力,为企业指定决策,帮助企业改进业务流程、提高产品数量

    一般数仓分为离线数仓(spark)和实时数仓(flink)

    二、核心框架

    在这里插入图片描述
    数据采集

    数据通过DataX或者sqoop可以将业务数据等导入到数据仓库,通过Flume可以将用户行为数据等导入到数据仓库;

    数据分析

    数据通过处理获取有用的数据指标

    • ODS层:原始数据层,用来数据备份
    • DWD层:明细数据层,用来数据清洗
    • DWS层: 汇总数据层,用来数据预聚合
    • ADS层:数据应用层,用来数据统计和计算
    • DIM层:公共维度层,用来数据分类的

    数据可视化

    将处理好的数据指标用在各种模块中

    1. 可视化的报表
    2. 用户画像
    3. 推荐系统
    4. 机器学习

    三、数仓大数据架构详解(流程)

    流程图
    在这里插入图片描述

    数据采集

    1. 业务数据通过Nginx采集到业务服务器(Springboot)然后再写到mysql中,用户行为数据通过Nginx采集到日志服务器(Springboot)写入到日志文件中(注:主要由JavaWeb人员负责)
    2. 日志文件的用户行为数据通过Flume将数据先写入kafka(主要作用为消峰),再通过Flume将kafka的数据写入到hdfs
    3. Mysql的业务行为数据通过DataX(全量的同步)将数据写入到hdfs中,也可以使用Maxwell(增量同步)将数据写入到hdfs中

    离线数仓

    1. 将HDFS中的数据进行建模 进行各种数据分层处理 如: ODS层、DIM层、DWD层、DWS层、ADS层等,(基本上都是Sql语句),所以需要DolphinScheduler进行任务调度管理
    2. 处理之后数据,通过DataX(每日同步)结果数据写入到MySQL中
    3. 然后再通过Superset的可视化工具进行数据的展示

    实时数仓

    1. Flink读取kakfa中的数据,而kafka中主题数据即为ODS层
    2. Flink从kafka中读取的数据进行清洗即为DWD层,再次写回到kafka中
    3. Flink读取kafka中DWD层的数据,进行维数数据的处理,通过Hbase存储处理的数据,由于Flume和kafka会造成数据的重复,那么Flink在消费kafka数据的时候可以进行精准一次去重。如果数据量比较小可以不用Flink,而使用Redis旁路缓存去重,即为DIM层
    4. 维度的数据可以通过Redis或者Hbase进行查询
    5. Flink将上面数据写入到ClickHouse进行预聚合,即为DWS层
    6. 最后对ClickHouse数据进行查询,然后通过Springboot(JavaWeb)数据接口服务将查询数据写入到Sugar,进行实时数据的可视化
  • 相关阅读:
    代码随想录二刷 |链表 | 移除链表元素
    Python图像处理丨带你掌握图像几何变换
    node使用puppeteer生成pdf与截图
    coco_eval.py详解
    leetcode 26. 删除有序数组中的重复项-java版本
    poi-tl:基于Apache POI的轻量级Word模板引擎
    C++进阶:二叉搜索树介绍、模拟实现(递归迭代两版本)及其应用
    测试用例设计方法真的很重要啊
    如何定时发送云湖社交APP消息?玩转云湖机器人
    HTML标签全解
  • 原文地址:https://blog.csdn.net/weixin_44604159/article/details/127834104