KBEngine增加ThinkingData打点

news2025/1/8 16:05:43

Windows下的安装ThinkingData

首先根据他的文档,安装sdk和Logbus,他的原理是sdk写入到log文件,然后通过Logbus2来传送到TD(ThinkingData)服务器。

通过pip获取 Python SDK

pip install ThinkingDataSdk
pip install --upgrade ThinkingDataSdk

安装Logbus
这里省略了
我们来到logbug目录,修改conf下的daemon.json
这里的配置文件可以是这样的

{
    "datasource": [
      {
        "type":"file",
        "file_patterns": ["../assets/logbus/*.*"], 
        "app_id": "你的数数id", 
        "unit_remove": "day", 
        "offset_remove": 7,
        "remove_dirs": true,
        "http_compress": "gzip" 
      }
    ],
    "cpu_limit": 2, 
  
    "push_url": "https://后台的push地址.thinkingdata.cn"
}

这里的file_patterns,.表示logbus.exe的目录,我的log放在外面,所以是…,我把服务端的打点目录配置在了服务端脚本目录的logbus下。

在这里插入图片描述

这个文件就是服务端程序生成的打点文件了。

KBEngine配置

根据TD的官方文档,需要

current_directory = os.path.dirname(os.path.abspath(__file__))
LOG_DIRECTORY = current_directory +"/../../logbus"

from tgasdk.sdk import TGAnalytics, LoggingConsumer
te = TGAnalytics(LoggingConsumer(LOG_DIRECTORY))

这里运行后提示很多库找不到,这里我总结了下,有下面一些包
在这里插入图片描述

只要把python的包拷贝到kbe\res\scripts\common\Lib下就可以了。
(这些包在我们通过pip安装Logbus2的时候会有安装成功的路径,一般是位于:C:\Users\Administrator\AppData\Local里,其他的包也在这里)

然后我贴一个kbe的脚本

from tgasdk.sdk import TGAnalytics, LoggingConsumer
import os
import datetime
import time
import GameConfigs
import KBEngine
from KBEDebug import *

TIME_WRITE_FILE = 10    #10秒写一次文件

current_directory = os.path.dirname(os.path.abspath(__file__))
LOG_DIRECTORY = current_directory +"/../../logbus"
#DEBUG_MSG("dbg.ThinkingData :: init path :%s" % (LOG_DIRECTORY))

#下一次发送时间
nextsend = int(time.time())+ TIME_WRITE_FILE
#当前有几个发送
sendcount = 0

te = TGAnalytics(LoggingConsumer(LOG_DIRECTORY))


#distinct_id = "S1"
#account_id = "TE1"

properties = {
    #"#time":datetime.datetime.now(),
    # 设置这条event发生的时间,如果不设置的话,则默认是当前时间
    #"#ip":"192.168.1.1",
    # 设置用户的IP,tda会自动根据该IP解析省份、城市
    #"#uuid":uuid.uuid1(),#选填,如果上面enable_uuid开关打开,不需要填
    "Product_Name":"商124",
    "Price":324,
    "OrderId":"1234"
}


#打点事件
def AnalyseEvent(userid,eventName,prop):
    global sendcount
    # 上传事件,包含账号ID与访客ID
    try:
        prop["#time"] = datetime.datetime.now()
        prop["server"] = GameConfigs.SERVER_ID
        #te.track(account_id,eventName,prop)
        # 您也可以只上传访客ID
        # te.track(distinct_id = distinct_id, event_name = "Payment", properties = properties)
        # 或者只上传账号ID
        te.track(account_id = userid, event_name = eventName, properties = prop)
        
        sendcount = sendcount + 1
        DEBUG_MSG("dbg.ThinkingData :AnalyseEvent  %s" % (eventName))
    except Exception as e:
        #异常处理
        DEBUG_MSG("Error.ThinkingData :: %s" % (e))

def Flush():
    global sendcount,nextsend
    nowtime = int(time.time())
    if sendcount > 0 and nowtime > nextsend:
        te.flush();
        sendcount = 0
        nextsend = int(time.time()) + TIME_WRITE_FILE
        DEBUG_MSG("dbg.ThinkingData Flush .")


#AnalyseEvent("S1","test1",properties)


调用AnalyseEvent就开始打点,调用Flush立即写入log文件。这样如果启动了logbus程序,他就自动上报给TD了。

Centos下

我们下载Linux-amd64版本,然后把刚才windows的json配置文件覆盖,传到服务器。
我们先检测

$ ./logbus env

-bash: ./logbus: Permission denied
chmod -R 777
$ ./logbus env
6:34PM INF app_id [3fexxx] ok

给了权限,运行后提示app_id ok应该ok了,然后我们再运行start。

$ ./logbus start
6:38PM INF Current Version: 2.1.0.8
6:38PM INF app_id [114xx28f11] ok
6:38PM INF [localhost:21666] start daemon success, pid[1391]

成功了,下来就剩下调试了。

记得把logbus需要的库也传到对应的kbe服务端Lib目录下。
然后就可以上传服务端打点代码测试了。

我遇到了找不到zlib,于是重新安装了

yum install zlib-devel

然后把引擎重新make就可以了。

参考

https://docs.thinkingdata.cn/python_sdk_installation

https://docs.thinkingdata.cn/logbus2_installation.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/890264.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

力扣75——多维动态规划

总结leetcode75中的多维动态规划算法题解题思路。 上一篇:力扣75——一维动态规划 力扣75——多维动态规划 1 不同路径2 最长公共子序列3 买卖股票的最佳时机含手续费4 编辑距离1 - 4 解题总结 1 不同路径 题目: 一个机器人位于一个 m x n 网格的左上角…

史上最全!80个数字化工厂常见术语合集,看完秒懂~

这几天,有几个朋友私信我,问了我不少问题,其中有一个让我讲一讲“数字化工厂”方面的知识,了解我的人想必都清楚,我这个人一般都是有求必应的。 所以今天来聊一聊“数字化工厂”的常见术语,帮助大家快速搞…

【Linux】模拟实现linux的shell

#include <stdio.h> #include <unistd.h> #include <string.h> #include <stdlib.h> #include <sys/wait.h> #include <sys/types.h> #define NUM 1024 #define SIZE 32 #define SEP " " int main() {//保存输入后的字符串char …

你需要需求管理解决方案的三个原因

我们最近研究了一份 Forrester Research 的报告&#xff0c;得出如下结论&#xff1a;高度监管的行业可以从敏捷需求管理方法中受益。在本文中&#xff0c;我们将深入探讨所有行业的客户如何从一个协作平台中受益&#xff0c;该平台如何帮助他们在复杂的开发周期中管理需求。 …

【傅里叶级数与傅里叶变换】数学推导——3、[Part4:傅里叶级数的复数形式] + [Part5:从傅里叶级数推导傅里叶变换] + 总结

文章内容来自DR_CAN关于傅里叶变换的视频&#xff0c;本篇文章提供了一些基础知识点&#xff0c;比如三角函数常用的导数、三角函数换算公式等。 文章全部链接&#xff1a; 基础知识点 Part1&#xff1a;三角函数系的正交性 Part2&#xff1a;T2π的周期函数的傅里叶级数展开 P…

工作流引擎之Flowable教程(整合SpringBoot)

简介 Flowable是什么&#xff0c;下面是官方文档介绍&#xff1a; Flowable是一个使用Java编写的轻量级业务流程引擎。Flowable流程引擎可用于部署BPMN 2.0流程定义&#xff08;用于定义流程的行业XML标准&#xff09;&#xff0c; 创建这些流程定义的流程实例&#xff0c;进行…

C++新经典04--位运算

背景 许多网络游戏为了刺激玩家每天上线&#xff0c;都在游戏中设有“每日任务”——每天让玩家做一些任务&#xff0c;如杀怪、采集来赚取积分、金钱、经验等。每日任务根据游戏不同&#xff0c;数量也不同&#xff0c;每日任务比较少的网络游戏中&#xff0c;可能每日任务只…

多语言多模态(融合图像和文本)大模型-mPLUG-Owl论文解读

近期复现了mPLUG-Owl&#xff0c;效果提升了好几个点&#xff0c;特来精读一番&#xff1a;感谢大佬们的工作&#xff1a; 论文名称&#xff1a;mPLUG-Owl: Modularization Empowers Large Language Models with Multimodality 论文地址&#xff1a;https://arxiv.org/pdf/23…

使用GUI Guider工具开发嵌入式GUI应用(5)-使用timer对象显示动画

使用GUI Guider工具开发嵌入式GUI应用&#xff08;5&#xff09;-使用timer对象显示动画 文章目录 使用GUI Guider工具开发嵌入式GUI应用&#xff08;5&#xff09;-使用timer对象显示动画引言LVGL中的timer对象基于timer对象实现仪表走针小结 引言 设计GUI的显示元素动起来&a…

Websocket原理和实践

一、概述 1.websocket是什么&#xff1f; WebSocket是一种在单个TCP连接上进行全双工通信的协议。WebSocket使得客户端和服务器之间的数据交换变得更加简单&#xff0c;允许服务端主动向客户端推送数据。在WebSocket API中&#xff0c;浏览器和服务器只需要完成一次握手&…

如何快速优化 CnosDB 数据库性能与延迟:使用 Jaeger 分布式追踪系统

在正式的生产环境中&#xff0c;数据库的性能和延迟对于确保系统的稳定和高效运行至关重要。特别是在与 CnosDB 数据库进行交互时&#xff0c;更深入地了解其表现变得尤为重要。这时Jaeger 分布式追踪系统发挥了巨大的作用。在本篇博客中&#xff0c;我们将深入探讨如何通过使用…

ATA-4000系列高压功率放大器——应用场景介绍

ATA-4000系列是一款理想的可放大交、直流信号的高压功率放大器。最大输出310Vp-p(155Vp)电压&#xff0c;452Wp功率&#xff0c;可以驱动高压功率型负载。电压增益&#xff0c;直流偏置数控精细可调&#xff0c;为客户提供了丰富的测试选择。 图&#xff1a;ATA-4000系列高压功…

ndk开发-交叉编译

为什么要使用交叉编译&#xff1a; 在linux系统一般使用c c编译可执行程序或者so库文件。该程序只能在当前linux系统执行&#xff0c;为了将生成文件可以再android平台运行&#xff0c;必须使用交叉编译。ndk中提供了跟多android平台交叉编译链&#xff0c;所以首先下载ndk工具…

FPGA应用学习笔记-----布图布线

分割可以将运行时间惊人地减少到三个小时更小的布局布线操作&#xff0c;主要的结构不影响另一个&#xff01;和增量设计流程一样 关键路径布图&#xff1a; 对于不同的模块有不同的电路和不同的关键路径&#xff0c; 布图没有主要的分割&#xff0c;布图由两个小的区域组成&a…

KDD 2023 获奖论文公布,港中文、港科大等获最佳论文奖

ACM SIGKDD&#xff08;国际数据挖掘与知识发现大会&#xff0c;KDD&#xff09;是数据挖掘领域历史最悠久、规模最大的国际顶级学术会议&#xff0c;也是首个引入大数据、数据科学、预测分析、众包等概念的会议。 今年&#xff0c;第29届 KDD 大会于上周在美国加州长滩圆满结…

C语言入门教程,C语言学习教程(非常详细)第五章 循环结构与选择结构

C语言if else语句详解 前面我们看到的代码都是顺序执行的&#xff0c;也就是先执行第一条语句&#xff0c;然后是第二条、第三条……一直到最后一条语句&#xff0c;这称为顺序结构。 但是对于很多情况&#xff0c;顺序结构的代码是远远不够的&#xff0c;比如一个程序限制了只…

【Javaswing课设源码】学生信息管理 Mysql课程设计 管理员 教师 学生

文章目录 系统介绍 系统介绍 大学时代弄的一个课设&#xff0c;当时百度[学长敲代码]找的代做&#xff0c;代码思路很清晰&#xff0c;完全按照我的功能需求去做的&#xff0c;主要是价格便宜&#xff0c;真的爱了&#xff0c;现在回头学习也是不错的一个项目。大概内容如下 本…

springboot里 用zxing 生成二维码

引入pom <!--二维码依赖--><dependency><groupId>com.google.zxing</groupId><artifactId>core</artifactId><version>3.3.3</version></dependency><dependency><groupId>com.google.zxing</groupId>…

【分类讨论】CF1674 E

Problem - E - Codeforces 题意&#xff1a; 思路&#xff1a; 样例&#xff1a; 这种分类讨论的题&#xff0c;主要是去看答案的最终来源是哪几种情况&#xff0c;这几种情况得不重不漏 Code&#xff1a; #include <bits/stdc.h>#define int long longusing i64 lon…

尚硅谷css3笔记

目录 一、新增长度单位 二、新增盒子属性 1.border-box 怪异盒模型 2.resize 调整盒子大小 3.box-shadow 盒子阴影 案例&#xff1a;鼠标悬浮盒子上时&#xff0c;盒子有一个过度的阴影效果 三、新增背景属性 1.background-origin 设置背景图的原点 2.background-clip 设置背…