• Stars
    star
    108
  • Rank 310,065 (Top 7 %)
  • Language
    Java
  • License
    Apache License 2.0
  • Created over 2 years ago
  • Updated 11 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

logbook 简介

logbook 是一款面向 ToB 业务的服务端埋点方案

logbook架构简图

概念介绍

1. 业务系统

支撑业务正常运转的软件系统体系,统称为业务系统。

2. 业务事件

单个业务系统中发生的事件,叫业务事件。 业务事件可能影响到0个或多个实体。

3. 上报

业务系统把自己感知到的业务事件提交给 logbook 的过程。

4. 准入

logbook 接收业务系统的业务事件,业务事件的格式和内容由业务系统和logbook双方共同约定。 在 logbook 接收事件时、会对约定格式/内容做校验,校验的过程叫做准入。

5. 实体事件

单一实体视角发生的事件,叫实体事件。 实体事件只涉及到单个实体,由业务事件加工后得到。

6. 翻译

logbook 把业务事件翻译成实体事件的过程。

7. 数据使用方

需要使用实体事件作为输入,来支撑自身业务的系统。

8. 分发

logbook 把实体事件处理后发送给对应的数据使用方的过程。


logbook 核心能力

  1. 定义了 业务事件-实体事件 的数据输出和转发规范
  2. 提供了 业务事件准入、翻译,实体事件过滤、分发的基础能力

logbook架构详图

实施标准

1. 业务事件

标准格式:

  • biz_event_type,Integer业务事件类型
  • biz_event_id,Long,业务事件id、是业务事件的唯一标识
  • biz_event_info,Json String,业务事件的上下文信息
  • biz_entity_info_before,Json String,业务事件影响到的实体、在事件发生前的实体信息
  • biz_entity_info_after,Json String,业务事件影响到的实体、在事件发生后的实体信息

2. 实体事件

标准格式:

  • entity_type,Integer,实体类型
  • entity_id String,实体id
  • entity_info_before_event,Json Object,实体在事件发生前的数据快照
  • entity_info_after_event,Json Object,实体在事件发生后的数据快照
  • event_type,Integer,事件类型
  • event_id,String,事件id
  • event_time,String,事件时间
  • event_report_caller,String,事件上报方
  • event_info,Json Object,实体事件相关的上下文信息

3. 准入

对业务事件的准入方案,目前支持 jsonSchema 校验,可扩展。

4. 翻译

将业务事件翻译为实体事件的方案,目前支持 groovy 翻译,可扩展。

5. 过滤

将实体事件分发给具体某个使用方前,可以进行简单的过滤,目前支持 groovy 过滤,可扩展。

6. 消息队列

业务事件翻译为实体事件后,会存入消息队列,目前支持 kafka 消息队列,暂不支持扩展。 实体事件也是通过 kafka 分发给数据使用方,暂不支持扩展。


快速开始

1. 阅读 api 接口

文档位置:```docs/ApiDocs.md``

2. 修改 yml配置

修改 application.yml 配置文件,路径:logbook-server/src/main/resources/application.yml

  • 必须修改的是 spring.datasource 开头的数据库配置
  • 其他配置可以使用默认值,也可以视情况进行调整

3. 修改数据库配置

logbook 内部需要用到 12 张表,其中:

  • 配置侧需要 10 张表,建表语句路径:logbook-server/sql/config.sql
  • 执行侧需要 2 张表,建表语句路径:logbook-server/sql/run.sql

4. 添加 mysql 驱动

  • 可以通过 maven 引入
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>${mysql-connector.version}</version>
        </dependency>

5. 二次开发

logbook 没有提供默认的消息队列实现,需要使用方选型完成后进行二次开发。

  • 二次开发需要完成的逻辑统一收敛在:logbook/logbook-server/src/main/java/com/didiglobal/mq/MQCustomizedUtil.java
  • 代码注释里给出了 kafka-clients 2.8.1 的示例代码,如需使用需要在 pom 文件里添加相应的依赖:
        <dependency>
            <groupId>org.apache.kafka</groupId>
            <artifactId>kafka-clients</artifactId>
            <version>${kafka-client.version}</version>
        </dependency>

6. demo

  • 部署好 kafka 环境
  • 创建好 demo 中用到的 4个 topic:inner_worksheet_events、inner_user_events、destinate_downstream1、destinate_downstream2
  • 修改 docs/logbookDemoSql.sql 中的 "你的kafka地址" 为真实的 kafka 地址
  • 执行修改后的 docs/logbookDemoSql.sql 将 demo 的配置侧数据写入到数据库
  • 执行 docs/ApiDemo.md 中的请求,进行 demo 测试

More Repositories

1

DoKit

一款面向泛前端产品研发全生命周期的效率平台。
Java
19,956
star
2

cube-ui

🔶 A fantastic mobile ui lib implement by Vue
JavaScript
9,110
star
3

chameleon

🦎 一套代码运行多端,一端所见即多端所见
JavaScript
9,024
star
4

VirtualAPK

A powerful and lightweight plugin framework for Android
Java
8,949
star
5

LogicFlow

A flow chart editing framework focusing on business customization. 专注于业务自定义的流程图编辑框架,支持实现脑图、ER图、UML、工作流等各种图编辑场景。
TypeScript
6,812
star
6

KnowStreaming

一站式云原生实时流数据平台,通过0侵入、插件化构建企业级Kafka服务,极大降低操作、存储和管理实时流数据门槛
Java
6,747
star
7

booster

🚀Optimizer for mobile applications
Kotlin
4,752
star
8

nightingale

An enterprise-level cloud-native monitoring system, which can be used as drop-in replacement of Prometheus for alerting and management.
Go
4,510
star
9

mpx

Mpx,一款具有优秀开发体验和深度性能优化的增强型跨端小程序框架
JavaScript
3,531
star
10

mand-mobile

💰 A mobile UI toolkit, based on Vue.js 2, designed for financial scenarios.
Vue
3,429
star
11

sharingan

Sharingan(写轮眼)是一个基于golang的流量录制回放工具,适合项目重构、回归测试等。
Go
2,182
star
12

tinyid

ID Generator id生成器 分布式id生成系统,简单易用、高性能、高可用的id生成系统
Java
2,071
star
13

ChineseNLP

Datasets, SOTA results of every fields of Chinese NLP
HTML
1,767
star
14

DiDiPrism

小桔棱镜,一款专注移动端操作行为的利器! A powerful tool (iOS & Android) that focuses on mobile operation behavior!
Objective-C
1,699
star
15

gendry

a golang library for sql builder
Go
1,500
star
16

DDMQ

DDMQ is a distributed messaging product with low latency, high throughput and high availability.
Java
1,286
star
17

Hummer

一套移动端高性能高可用的动态化跨端开发框架
Objective-C
1,283
star
18

rdebug

Rdebug — Real Debugger
PHP
1,155
star
19

echo

Echo是一款桌面端调试工具,旨在提高客户端的研发调试效率
Objective-C
1,022
star
20

DroidAssist

A lightweight Android Studio gradle plugin based on Javassist for editing bytecode in Android.
Java
881
star
21

AoE

AoE (AI on Edge,终端智能,边缘计算) 是一个终端侧AI集成运行时环境 (IRE),帮助开发者提升效率。
C++
870
star
22

turbo

Turbo is a light-weight flow engine framework, support BPMN2.0. 一款轻量级流程引擎服务框架,可作为底层服务支持各类流程设计、低代码设计、工作流、服务编排等场景
Java
798
star
23

DRouter

Android Router Framework
Java
711
star
24

AgileTC

AgileTC is an agile test case management platform
JavaScript
642
star
25

falcon-log-agent

用于监控系统的日志采集agent,可无缝对接open-falcon
Go
554
star
26

epage

一款基于schema的低代码可视化页面配置工具
Vue
441
star
27

super-jacoco

Java
430
star
28

GateKeeper

A high-performance Golang gateway that supports rapid development and plug-inization
Go
428
star
29

sds

SDS是一个基于Java开发的简单、易用、高性能的服务降级系统,支持限流、熔断和降级等功能,服务端必备!!
Java
406
star
30

KnowSearch

面向Elasticsearch研发与运维人员,围绕集群、索引构建的零侵入、多租户的Elasticsearch GUI管控平台
Java
377
star
31

kemon

An Open-Source Pre and Post Callback-Based Framework for macOS Kernel Monitoring.
C
368
star
32

di18n

一种自动转换、基于配置的前端国际化方案
JavaScript
286
star
33

pile.js

pile.js components build with React.
CSS
267
star
34

ES-Fastloader

Quickly build large-scale ElasticSearch indices by using the fault tolerance and parallelism of Hadoop
Java
259
star
35

KnowAgent

基于日志模板构建,采集任务动态管控、数据质量精确度量,一站式日志采集平台
Java
243
star
36

LogiCommon

Java版 认证、鉴权、管理、任务调度通用功能组件
Java
213
star
37

Tips

JavaScript
187
star
38

maskdetection

C++
179
star
39

xiaoju-survey

「快速」打造「专属」问卷系统, 让调研「更轻松」
Vue
167
star
40

DreamBox

DreamBox是一个为客户端开发者打造的统一视图开发框架,具有性能好、可动态更新的特点
Java
165
star
41

dlflow

DLFlow is a deep learning framework.
Python
156
star
42

hetsann

Source Codes of HetSANN in the AAAI'20 paper: An Attention-based Graph Nerual Network for Heterogeneous Structural Learning.
Python
140
star
43

collection

go collection package for fasting coding
Go
127
star
44

didi.github.io

didi website
HTML
125
star
45

athena

A release version for https://github.com/athena-team/athena
Python
123
star
46

JuShaTa

JuShaTa是一个Java容器,提供模块隔离及模块热加载能力。
Java
114
star
47

levin

A Quick Way to Bulk Loading
C++
104
star
48

heteta

HetETA: Heterogeneous Information Network Embedding for Estimating Time of Arrival
Python
101
star
49

thrift-mock

A lightweight java test library for mocking thrift server
Java
90
star
50

mand-mobile-rn

💰 Mand Mobile for React Native, designed for financial scenarios.
TypeScript
87
star
51

TrafficIndex

TTI ,Smart Transportation Industry Standard
C++
85
star
52

slime-validator

JavaScript library of validation based on Plugin system and make data validation be easy.
JavaScript
85
star
53

vue-tmap

一个基于腾讯地图JavaScript API GL、TypeScript 封装适用于 Vue3 的高性能地图组件库
TypeScript
81
star
54

mtmc-vt

MTMC Vehicle Tracking For AI City challenge 2019
Jupyter Notebook
69
star
55

sgt

didiyun super-agent daemon
Go
57
star
56

FeatureProbe

开源的高效可视化『功能』管理平台,提供灰度发布、AB实验、配置变更全功能。
53
star
57

ALITA

ALITA is a layer-based data analysis tool. The front-end see
Java
50
star
58

react-tmap

一个基于腾讯地图JavaScript API GL、TypeScript 封装适用于 react 的高性能地图组件库
TypeScript
45
star
59

benchmark-thrift

An open source application designed to load test Thrift applications
Java
44
star
60

elastic-trib

elasticsearch cluster command line tool.
Go
39
star
61

mpx-cube-ui

基于"Mpx 小程序框架"的移动端基础组件库
TypeScript
25
star
62

yarc

基于 eBPF 的流量录制工具
C
24
star
63

paladin

Scala
20
star
64

MEEP

End-to-end framework to build automatic agents (chatbots) for task-oriented dialogs
Python
18
star
65

tg-flow

Go
18
star
66

Unify

Dart
15
star
67

ALITA_UI

ALITA is a layer-based data analysis tool. The back-end see
JavaScript
13
star
68

wmt2021_triangular_mt

The baseline model code for WMT 2021 Triangular MT
Python
13
star
69

MeetDot

Python
11
star
70

DAIBench

Shell
10
star
71

WorkTrans

Python
10
star
72

didi-tech-edu

9
star
73

daedalus

JavaScript
6
star
74

tmap-types

腾讯地图 js api 类型声明,主要用于 react-tmap 和 vue-tmap 组件库
4
star
75

Json-adapter

Java
3
star