# Lua
本指南将会为您介绍如何使用 Lua SDK 接入您的项目。
最新版本为:v2.0.0
更新时间为:2023-12-01
资源下载: 源代码 (opens new window)
注意
当前文档适用于 v2.0.0 及以后的版本,历史版本请参考 Lua SDK 接入指南(V1) (opens new window)
# 一、集成SDK
- 下载源代码 (opens new window),把下载的ThinkingDataSdk.lua文件放入您的工程目录下
- 使用 luarocks 管理工具安装第三方库:
luarocks install uuid
# 安装 luasec 库需要指定 OPENSSL_DIR 路径
luarocks install luasec OPENSSL_DIR=[PATH]
luarocks install lua-cjson
- 安装Logbus
我们推荐使用SDK+LogBus的形式,完成服务端数据的采集上报.您可以参考以下文档完成Logbus的安装:LogBus使用指南
# 二、初始化
以下是SDK初始化的示例代码:
local tdAnalytics = require "ThinkingDataSdk"
local consumer = tdAnalytics.TDLogConsumer("LOG_DIRECTORY", tdAnalytics.LOG_RULE.HOUR, 200, 500)
local sdk = tdAnalytics(consumer)
LOG_DIRECTORY
为写入本地的文件夹地址。您只需将 LogBus 的监听文件夹地址设置为此处的地址,即可使用 LogBus 进行数据的监听上传。
# 三、常用功能
为了保证访客 ID 与账号 ID 能够顺利进行绑定,如果您的游戏中会用到访客 ID 与账号 ID,我们极力建议您同时上传这两个 ID,否则将会出现账号无法匹配的情况,导致用户重复计算,具体的 ID 绑定规则可参考用户识别规则一章。
# 3.1 发送事件
您可以调用track
来上传事件,建议您根据先前梳理的文档来设置事件的属性以及发送信息的条件,以下是发送事件的示例代码:
--设置访客ID"ABCDEFG123456789"
local distinctId = "ABCDEFG123456789"
--设置账号ID"TE_10001"
local accountId = "TE_10001"
--设置事件属性
local properties = {}
--设置事件发生的时间,如果不设置的话,则默认使用为当前时间
properties["#time"] = os.date("%Y-%m-%d %H:%M:%S")
--设置用户的ip地址,TE系统会根据IP地址解析用户的地理位置信息,如果不设置的话,则默认不上报
properties["#ip"] = "192.168.1.1"
properties["Product_Name"] = "card"
properties["Price"] = 30
properties["OrderId"] = "abc_123"
--上传事件,包含用户的访客ID与账号ID,请注意账号ID与访客ID的顺序
sdk:track(accountId, distinctId, "payment", properties)
- 事件的名称是字符串类型,只能以字母开头,可包含数字,字母和下划线 "_",长度最大为 50 个字符。
- Key 为该属性的名称,为字符串类型,规定只能以字母开头,包含数字,字母和下划线 "_",长度最大为 50 个字符,对字母大小写不敏感,TE会统一转化为小写字母
- Value 为该属性的值,支持字符串、数字、布尔、时间、对象、对象组、数组
用户属性的要求与事件属性保持一致
# 3.2 设置用户属性
对于一般的用户属性,您可以调用userSet
来进行设置,使用该接口上传的属性将会覆盖原有的属性值,如果之前不存在该用户属性,则会新建该用户属性,类型与传入属性的类型一致,此处以设置用户名为例:
--设置访客ID"ABCDEFG123456789"
local distinctId = "ABCDEFG123456789"
--设置账号ID"TE_10001"
local accountId = "TE_10001"
local userSetProperties = {}
userSetProperties["user_name"] = "ABC"
--上传用户属性
sdk:userSet(accountId, distinctId, userSetProperties)
userSetProperties = {}
userSetProperties["user_name"] = "abc"
--再次上传用户属性,此时"user_name"的值会被覆盖为"abc"
sdk:userSet(accountId, distinctId, userSetProperties)
# 四、最佳实践
以下示例代码包含以上所有操作,我们推荐按照如下步骤使用:
local tdAnalytics = require "ThinkingDataSdk"
local consumer = tdAnalytics.TDLogConsumer("LOG_DIRECTORY", tdAnalytics.LOG_RULE.HOUR, 200, 500)
local sdk = tdAnalytics(consumer)
--设置访客ID"ABCDEFG123456789"
local distinctId = "ABCDEFG123456789"
--设置账号ID"TE_10001"
local accountId = "TE_10001"
--设置事件属性
local properties = {}
--设置事件发生的时间,如果不设置的话,则默认使用为当前时间
properties["#time"] = os.date("%Y-%m-%d %H:%M:%S")
--设置用户的ip地址,TE系统会根据IP地址解析用户的地理位置信息,如果不设置的话,则默认不上报
properties["#ip"] = "192.168.1.1"
properties["Product_Name"] = "card"
properties["Price"] = 30
properties["OrderId"] = "abc_123"
--上传事件,包含用户的访客ID与账号ID,请注意账号ID与访客ID的顺序
sdk:track(accountId, distinctId, "payment", properties)
local userSetProperties = {}
userSetProperties["user_name"] = "ABC"
--上传用户属性
sdk:userSet(accountId, distinctId, userSetProperties)
userSetProperties = {}
userSetProperties["user_name"] = "abc"
--再次上传用户属性,此时"user_name"的值会被覆盖为"abc"
sdk:userSet(accountId, distinctId, userSetProperties)
--调用flush接口数据会立即写入文件,生产环境注意避免频繁调用flush引发IO或网络开销问题
sdk:flush()