【数据仓库】Clickhouse + Dataway 实现

1. 数据时序

数据时序图
  • 通过CK接管MySQL业务库数据。
  • 使用XXL-JOB作为调度工具,通过SHELL脚本做ETL操作,在CK中建立数仓模型,最终结果表反写到MySQL报表库中。
  • 报表平台通过Dataway创建接口,给前端提供数据。

2. 使用教程

2.1. CK入门

官方文档非常详细:https://clickhouse.com/docs/zh

2.1.1. 接管业务库

  1. 使用MySQL引擎创建xuanfb_user_sales库
CREATE DATABASE IF NOT EXISTS xuanfb_user_sales
ENGINE = MySQL('127.0.0.1:3306', 'xuanfb_user_sales', 'test_rw', '123456');

2.验证结果

select * from  xuanfb_user_sales.ztc_clue;
通过CK查询MySQL数据库

2.1.2.建库建表

1.创建testdb库

CREATE DATABASE IF NOT EXISTS testdb

2.创建dwd_customer表

CREATE TABLE testdb.dwd_customer
(
    `clue_id` String,
    `NicheUUID` String,
    `project_id` String,
    `name` String,
    `mobile` Nullable(String),
    `referrer_account_id` Nullable(String),
    `referrer_name` Nullable(String),
    `counselor_user_id` Nullable(String),
    `counselor_name` Nullable(String),
    `create_time` DateTime
)
ENGINE = ReplacingMergeTree(create_time)
ORDER BY (clue_id,NicheUUID)
SETTINGS index_granularity = 8192;
创建库表

2.1.3.手工ETL

1.初始化数据

insert into testdb.dwd_customer (clue_id,NicheUUID,project_id,name,mobile,referrer_account_id,referrer_name,counselor_user_id,counselor_name,create_time)
select zc.clue_id,NicheUUID,zc.project_id,zc.name,mobile,zc.referrer_account_id,zc.referrer_name,zc.counselor_user_id,zc.counselor_name,zc.create_time 
from xuanfb_user_sales.ztc_clue zc left join xuanfb_user_sales.m_niche mn on zc.clue_id = mn.LeadUUID ;
查看数据

2.1.4.调度工具

统一使用xxl-job进行调度。官方参考文档:https://www.xuxueli.com/xxl-job/

  1. 新建调度任务


    新建任务

2.编辑调度脚本


打开脚本编辑器

添加Shell脚本

2.2. Dataway入门

官方参考文档:https://www.hasor.net/

2.2.1. 后台管理

地址:http://localhost:8080/report-center/interface-ui/#/

Dataway后台管理

2.2.2.编写UDF函数

/**
 * @description: 数据权限-测试
 * @author: Dreamson.Ma
 * @create: 2022-08-22 21:30
 **/
@Slf4j
@Component
@DimUdf("dpUdf")
public class DpUdf implements Udf {

    @Resource
    private UserTokenService userTokenService;

    @Override
    public Object call(Hints hints, Object... objects) {
        log.info("当前用户信息:{}", userTokenService.getUser());
        return "2";
    }
}

2.2.3.编写DataSQL

hint FRAGMENT_SQL_QUERY_BY_PAGE = true
hint FRAGMENT_SQL_QUERY_BY_PAGE_NUMBER_OFFSET = 1

var dataFun = @@sql(ownerType) <%
    select 
    owner_name as ownerName,
    card_id as cardId,
    (case gender 
    when 0 then '一手业主' 
    when 1 then '二手业主' 
    when 2 then '一手/二手业主' 
    end) as gender
    from owner_profile where owner_type = #{ownerType}
    and card_id is not null 
%>
var queryPage = dataFun(dpUdf());
run queryPage.setPageInfo({
    "pageSize"    : 5, // 页大小
    "currentPage" : 1  // 第3页
});

return {
    "pageInfo": queryPage.pageInfo(),
    "pageData": queryPage.data()
}

2.2.4.测试、冒烟、发布

Dataway测试、冒烟、发布
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,839评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,543评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,116评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,371评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,384评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,111评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,416评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,053评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,558评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,007评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,117评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,756评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,324评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,315评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,539评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,578评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,877评论 2 345

推荐阅读更多精彩内容