Files
Web_BLS_OldRcu_Heartbeat_Se…/bls-oldrcu-heartbeat-backend/logs/kafka-sample-1773221699449.json
XuJiacheng e45d14b720 feat: 实现心跳消息处理模块
- 新增 HeartbeatBuffer 类,用于收集和去重 Kafka 心跳消息,并定期将数据刷新到数据库。
- 新增 HeartbeatDbManager 类,负责与 PostgreSQL 数据库的交互,支持批量 upsert 操作。
- 新增配置文件 config.js,支持从环境变量加载配置。
- 新增 Kafka 消费者模块,支持从 Kafka 中消费心跳消息。
- 新增 Redis 集成模块,支持将日志和心跳信息推送到 Redis。
- 新增心跳消息解析器,负责解析 Kafka 消息并提取心跳字段。
- 新增日志记录工具,支持不同级别的日志输出。
- 新增指标收集器,跟踪 Kafka 消息处理和数据库操作的指标。
- 新增单元测试,覆盖 HeartbeatBuffer 和 HeartbeatDbManager 的主要功能。
- 新增数据库表结构 SQL 文件,定义 room_status_moment_g5 表的结构。
- 配置 Vite 构建工具,支持 Node.js 环境的构建。
2026-03-12 14:11:02 +08:00

783 lines
27 KiB
JSON

{
"createdAt": "2026-03-11T09:35:06.077Z",
"reason": "sample-size-reached",
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"brokers": [
"kafka.blv-oa.com:9092"
],
"sampleSizeRequested": 50,
"sampleSizeCollected": 50,
"summary": {
"totalMessages": 50,
"validTopLevelShape": 50,
"invalidTopLevelShape": 0,
"jsonParseFailed": 0,
"topLevelKeys": {
"current_time": 50,
"ts_ms": 50,
"device_id": 50,
"hotel_id": 50,
"room_id": 50
},
"firstParsedExample": {
"current_time": "2026-03-11 17:34:58.379134",
"ts_ms": 1773221698375,
"device_id": "029005021240",
"hotel_id": "1309",
"room_id": "6010"
},
"firstRawExample": "{\"current_time\":\"2026-03-11 17:34:58.379134\",\"ts_ms\":1773221698375,\"device_id\":\"029005021240\",\"hotel_id\":\"1309\",\"room_id\":\"6010\"}"
},
"samples": [
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862076,
"key": "1309",
"value": "{\"current_time\":\"2026-03-11 17:34:58.379134\",\"ts_ms\":1773221698375,\"device_id\":\"029005021240\",\"hotel_id\":\"1309\",\"room_id\":\"6010\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.379134",
"ts_ms": 1773221698375,
"device_id": "029005021240",
"hotel_id": "1309",
"room_id": "6010"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862077,
"key": "1472",
"value": "{\"current_time\":\"2026-03-11 17:34:58.379665\",\"ts_ms\":1773221698375,\"device_id\":\"192005035049\",\"hotel_id\":\"1472\",\"room_id\":\"8080\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.379665",
"ts_ms": 1773221698375,
"device_id": "192005035049",
"hotel_id": "1472",
"room_id": "8080"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862078,
"key": "1321",
"value": "{\"current_time\":\"2026-03-11 17:34:58.383629\",\"ts_ms\":1773221698375,\"device_id\":\"041005024164\",\"hotel_id\":\"1321\",\"room_id\":\"8512\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.383629",
"ts_ms": 1773221698375,
"device_id": "041005024164",
"hotel_id": "1321",
"room_id": "8512"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862079,
"key": "1071",
"value": "{\"current_time\":\"2026-03-11 17:34:58.385401\",\"ts_ms\":1773221698375,\"device_id\":\"047004000226\",\"hotel_id\":\"1071\",\"room_id\":\"1808\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.385401",
"ts_ms": 1773221698375,
"device_id": "047004000226",
"hotel_id": "1071",
"room_id": "1808"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862080,
"key": "2085",
"value": "{\"current_time\":\"2026-03-11 17:34:58.390611\",\"ts_ms\":1773221698375,\"device_id\":\"037008104143\",\"hotel_id\":\"2085\",\"room_id\":\"4809\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.390611",
"ts_ms": 1773221698375,
"device_id": "037008104143",
"hotel_id": "2085",
"room_id": "4809"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862081,
"key": "1343",
"value": "{\"current_time\":\"2026-03-11 17:34:58.392215\",\"ts_ms\":1773221698391,\"device_id\":\"063005014205\",\"hotel_id\":\"1343\",\"room_id\":\"1716\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.392215",
"ts_ms": 1773221698391,
"device_id": "063005014205",
"hotel_id": "1343",
"room_id": "1716"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862082,
"key": "1691",
"value": "{\"current_time\":\"2026-03-11 17:34:58.394536\",\"ts_ms\":1773221698391,\"device_id\":\"155006043096\",\"hotel_id\":\"1691\",\"room_id\":\"1118\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.394536",
"ts_ms": 1773221698391,
"device_id": "155006043096",
"hotel_id": "1691",
"room_id": "1118"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862083,
"key": "1594",
"value": "{\"current_time\":\"2026-03-11 17:34:58.395426\",\"ts_ms\":1773221698391,\"device_id\":\"058006059034\",\"hotel_id\":\"1594\",\"room_id\":\"8801\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.395426",
"ts_ms": 1773221698391,
"device_id": "058006059034",
"hotel_id": "1594",
"room_id": "8801"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862084,
"key": "1161",
"value": "{\"current_time\":\"2026-03-11 17:34:58.396666\",\"ts_ms\":1773221698391,\"device_id\":\"137004041043\",\"hotel_id\":\"1161\",\"room_id\":\"0709\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.396666",
"ts_ms": 1773221698391,
"device_id": "137004041043",
"hotel_id": "1161",
"room_id": "0709"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862085,
"key": "1071",
"value": "{\"current_time\":\"2026-03-11 17:34:58.398854\",\"ts_ms\":1773221698391,\"device_id\":\"047004000181\",\"hotel_id\":\"1071\",\"room_id\":\"1302\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.398854",
"ts_ms": 1773221698391,
"device_id": "047004000181",
"hotel_id": "1071",
"room_id": "1302"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862086,
"key": "1309",
"value": "{\"current_time\":\"2026-03-11 17:34:58.406257\",\"ts_ms\":1773221698391,\"device_id\":\"029005021248\",\"hotel_id\":\"1309\",\"room_id\":\"6008\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.406257",
"ts_ms": 1773221698391,
"device_id": "029005021248",
"hotel_id": "1309",
"room_id": "6008"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862087,
"key": "1161",
"value": "{\"current_time\":\"2026-03-11 17:34:58.406533\",\"ts_ms\":1773221698391,\"device_id\":\"137004040215\",\"hotel_id\":\"1161\",\"room_id\":\"0911\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.406533",
"ts_ms": 1773221698391,
"device_id": "137004040215",
"hotel_id": "1161",
"room_id": "0911"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862088,
"key": "1580",
"value": "{\"current_time\":\"2026-03-11 17:34:58.411742\",\"ts_ms\":1773221698407,\"device_id\":\"044006041234\",\"hotel_id\":\"1580\",\"room_id\":\"8811\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.411742",
"ts_ms": 1773221698407,
"device_id": "044006041234",
"hotel_id": "1580",
"room_id": "8811"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862089,
"key": "1691",
"value": "{\"current_time\":\"2026-03-11 17:34:58.411634\",\"ts_ms\":1773221698407,\"device_id\":\"155006043049\",\"hotel_id\":\"1691\",\"room_id\":\"8911\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.411634",
"ts_ms": 1773221698407,
"device_id": "155006043049",
"hotel_id": "1691",
"room_id": "8911"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862090,
"key": "1811",
"value": "{\"current_time\":\"2026-03-11 17:34:58.419220\",\"ts_ms\":1773221698407,\"device_id\":\"019007083215\",\"hotel_id\":\"1811\",\"room_id\":\"422\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.419220",
"ts_ms": 1773221698407,
"device_id": "019007083215",
"hotel_id": "1811",
"room_id": "422"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862091,
"key": "1580",
"value": "{\"current_time\":\"2026-03-11 17:34:58.421111\",\"ts_ms\":1773221698407,\"device_id\":\"044006064118\",\"hotel_id\":\"1580\",\"room_id\":\"8710\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.421111",
"ts_ms": 1773221698407,
"device_id": "044006064118",
"hotel_id": "1580",
"room_id": "8710"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862092,
"key": "1309",
"value": "{\"current_time\":\"2026-03-11 17:34:58.426307\",\"ts_ms\":1773221698422,\"device_id\":\"029005121202\",\"hotel_id\":\"1309\",\"room_id\":\"7027\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.426307",
"ts_ms": 1773221698422,
"device_id": "029005121202",
"hotel_id": "1309",
"room_id": "7027"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862093,
"key": "1093",
"value": "{\"current_time\":\"2026-03-11 17:34:58.431494\",\"ts_ms\":1773221698422,\"device_id\":\"069004002090\",\"hotel_id\":\"1093\",\"room_id\":\"A508\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.431494",
"ts_ms": 1773221698422,
"device_id": "069004002090",
"hotel_id": "1093",
"room_id": "A508"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862094,
"key": "2090",
"value": "{\"current_time\":\"2026-03-11 17:34:58.434431\",\"ts_ms\":1773221698422,\"device_id\":\"042008091005\",\"hotel_id\":\"2090\",\"room_id\":\"1127\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.434431",
"ts_ms": 1773221698422,
"device_id": "042008091005",
"hotel_id": "2090",
"room_id": "1127"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862095,
"key": "1093",
"value": "{\"current_time\":\"2026-03-11 17:34:58.435272\",\"ts_ms\":1773221698422,\"device_id\":\"069004002087\",\"hotel_id\":\"1093\",\"room_id\":\"A503\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.435272",
"ts_ms": 1773221698422,
"device_id": "069004002087",
"hotel_id": "1093",
"room_id": "A503"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862096,
"key": "1050",
"value": "{\"current_time\":\"2026-03-11 17:34:58.437252\",\"ts_ms\":1773221698422,\"device_id\":\"026004001105\",\"hotel_id\":\"1050\",\"room_id\":\"8405\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.437252",
"ts_ms": 1773221698422,
"device_id": "026004001105",
"hotel_id": "1050",
"room_id": "8405"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862097,
"key": "1059",
"value": "{\"current_time\":\"2026-03-11 17:34:58.444641\",\"ts_ms\":1773221698438,\"device_id\":\"035004001241\",\"hotel_id\":\"1059\",\"room_id\":\"6632\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.444641",
"ts_ms": 1773221698438,
"device_id": "035004001241",
"hotel_id": "1059",
"room_id": "6632"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862098,
"key": "1196",
"value": "{\"current_time\":\"2026-03-11 17:34:58.446280\",\"ts_ms\":1773221698438,\"device_id\":\"172004060100\",\"hotel_id\":\"1196\",\"room_id\":\"408\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.446280",
"ts_ms": 1773221698438,
"device_id": "172004060100",
"hotel_id": "1196",
"room_id": "408"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862099,
"key": "1807",
"value": "{\"current_time\":\"2026-03-11 17:34:58.451557\",\"ts_ms\":1773221698438,\"device_id\":\"015007081169\",\"hotel_id\":\"1807\",\"room_id\":\"8300\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.451557",
"ts_ms": 1773221698438,
"device_id": "015007081169",
"hotel_id": "1807",
"room_id": "8300"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862100,
"key": "1687",
"value": "{\"current_time\":\"2026-03-11 17:34:58.451944\",\"ts_ms\":1773221698438,\"device_id\":\"151006045201\",\"hotel_id\":\"1687\",\"room_id\":\"729\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.451944",
"ts_ms": 1773221698438,
"device_id": "151006045201",
"hotel_id": "1687",
"room_id": "729"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862101,
"key": "1084",
"value": "{\"current_time\":\"2026-03-11 17:34:58.453944\",\"ts_ms\":1773221698438,\"device_id\":\"060004002030\",\"hotel_id\":\"1084\",\"room_id\":\"415\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.453944",
"ts_ms": 1773221698438,
"device_id": "060004002030",
"hotel_id": "1084",
"room_id": "415"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862102,
"key": "2004",
"value": "{\"current_time\":\"2026-03-11 17:34:58.455031\",\"ts_ms\":1773221698454,\"device_id\":\"212007102070\",\"hotel_id\":\"2004\",\"room_id\":\"8550\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.455031",
"ts_ms": 1773221698454,
"device_id": "212007102070",
"hotel_id": "2004",
"room_id": "8550"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862103,
"key": "1196",
"value": "{\"current_time\":\"2026-03-11 17:34:58.457543\",\"ts_ms\":1773221698454,\"device_id\":\"172004060063\",\"hotel_id\":\"1196\",\"room_id\":\"316\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.457543",
"ts_ms": 1773221698454,
"device_id": "172004060063",
"hotel_id": "1196",
"room_id": "316"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862104,
"key": "1691",
"value": "{\"current_time\":\"2026-03-11 17:34:58.458445\",\"ts_ms\":1773221698454,\"device_id\":\"155006072044\",\"hotel_id\":\"1691\",\"room_id\":\"8709\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.458445",
"ts_ms": 1773221698454,
"device_id": "155006072044",
"hotel_id": "1691",
"room_id": "8709"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862105,
"key": "1486",
"value": "{\"current_time\":\"2026-03-11 17:34:58.461698\",\"ts_ms\":1773221698454,\"device_id\":\"206005058077\",\"hotel_id\":\"1486\",\"room_id\":\"8901\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.461698",
"ts_ms": 1773221698454,
"device_id": "206005058077",
"hotel_id": "1486",
"room_id": "8901"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862106,
"key": "1594",
"value": "{\"current_time\":\"2026-03-11 17:34:58.465447\",\"ts_ms\":1773221698454,\"device_id\":\"058006057124\",\"hotel_id\":\"1594\",\"room_id\":\"8501\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.465447",
"ts_ms": 1773221698454,
"device_id": "058006057124",
"hotel_id": "1594",
"room_id": "8501"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862107,
"key": "1968",
"value": "{\"current_time\":\"2026-03-11 17:34:58.466935\",\"ts_ms\":1773221698454,\"device_id\":\"176007137152\",\"hotel_id\":\"1968\",\"room_id\":\"1603\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.466935",
"ts_ms": 1773221698454,
"device_id": "176007137152",
"hotel_id": "1968",
"room_id": "1603"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862108,
"key": "1472",
"value": "{\"current_time\":\"2026-03-11 17:34:58.470359\",\"ts_ms\":1773221698469,\"device_id\":\"192005060058\",\"hotel_id\":\"1472\",\"room_id\":\"8122\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.470359",
"ts_ms": 1773221698469,
"device_id": "192005060058",
"hotel_id": "1472",
"room_id": "8122"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862109,
"key": "2099",
"value": "{\"current_time\":\"2026-03-11 17:34:58.471775\",\"ts_ms\":1773221698469,\"device_id\":\"051008128172\",\"hotel_id\":\"2099\",\"room_id\":\"8515\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.471775",
"ts_ms": 1773221698469,
"device_id": "051008128172",
"hotel_id": "2099",
"room_id": "8515"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862110,
"key": "1580",
"value": "{\"current_time\":\"2026-03-11 17:34:58.483285\",\"ts_ms\":1773221698469,\"device_id\":\"044006062247\",\"hotel_id\":\"1580\",\"room_id\":\"1121\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.483285",
"ts_ms": 1773221698469,
"device_id": "044006062247",
"hotel_id": "1580",
"room_id": "1121"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862111,
"key": "1811",
"value": "{\"current_time\":\"2026-03-11 17:34:58.486597\",\"ts_ms\":1773221698485,\"device_id\":\"019007083227\",\"hotel_id\":\"1811\",\"room_id\":\"305\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.486597",
"ts_ms": 1773221698485,
"device_id": "019007083227",
"hotel_id": "1811",
"room_id": "305"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862112,
"key": "1207",
"value": "{\"current_time\":\"2026-03-11 17:34:58.488430\",\"ts_ms\":1773221698485,\"device_id\":\"183004001029\",\"hotel_id\":\"1207\",\"room_id\":\"320\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.488430",
"ts_ms": 1773221698485,
"device_id": "183004001029",
"hotel_id": "1207",
"room_id": "320"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862113,
"key": "2067",
"value": "{\"current_time\":\"2026-03-11 17:34:58.500476\",\"ts_ms\":1773221698485,\"device_id\":\"019008117135\",\"hotel_id\":\"2067\",\"room_id\":\"910\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.500476",
"ts_ms": 1773221698485,
"device_id": "019008117135",
"hotel_id": "2067",
"room_id": "910"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862114,
"key": "1196",
"value": "{\"current_time\":\"2026-03-11 17:34:58.511847\",\"ts_ms\":1773221698500,\"device_id\":\"172004060152\",\"hotel_id\":\"1196\",\"room_id\":\"519\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.511847",
"ts_ms": 1773221698500,
"device_id": "172004060152",
"hotel_id": "1196",
"room_id": "519"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862115,
"key": "1006",
"value": "{\"current_time\":\"2026-03-11 17:34:58.521066\",\"ts_ms\":1773221698516,\"device_id\":\"238003002021\",\"hotel_id\":\"1006\",\"room_id\":\"201\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.521066",
"ts_ms": 1773221698516,
"device_id": "238003002021",
"hotel_id": "1006",
"room_id": "201"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862116,
"key": "2067",
"value": "{\"current_time\":\"2026-03-11 17:34:58.526344\",\"ts_ms\":1773221698516,\"device_id\":\"019008118200\",\"hotel_id\":\"2067\",\"room_id\":\"909\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.526344",
"ts_ms": 1773221698516,
"device_id": "019008118200",
"hotel_id": "2067",
"room_id": "909"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862117,
"key": "1050",
"value": "{\"current_time\":\"2026-03-11 17:34:58.531075\",\"ts_ms\":1773221698516,\"device_id\":\"026004001115\",\"hotel_id\":\"1050\",\"room_id\":\"8415\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.531075",
"ts_ms": 1773221698516,
"device_id": "026004001115",
"hotel_id": "1050",
"room_id": "8415"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862118,
"key": "2032",
"value": "{\"current_time\":\"2026-03-11 17:34:58.537400\",\"ts_ms\":1773221698532,\"device_id\":\"240007114205\",\"hotel_id\":\"2032\",\"room_id\":\"8010\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.537400",
"ts_ms": 1773221698532,
"device_id": "240007114205",
"hotel_id": "2032",
"room_id": "8010"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862119,
"key": "2090",
"value": "{\"current_time\":\"2026-03-11 17:34:58.541467\",\"ts_ms\":1773221698532,\"device_id\":\"042008127043\",\"hotel_id\":\"2090\",\"room_id\":\"1105\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.541467",
"ts_ms": 1773221698532,
"device_id": "042008127043",
"hotel_id": "2090",
"room_id": "1105"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862120,
"key": "2070",
"value": "{\"current_time\":\"2026-03-11 17:34:58.552572\",\"ts_ms\":1773221698547,\"device_id\":\"022008117143\",\"hotel_id\":\"2070\",\"room_id\":\"8852\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.552572",
"ts_ms": 1773221698547,
"device_id": "022008117143",
"hotel_id": "2070",
"room_id": "8852"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862121,
"key": "1050",
"value": "{\"current_time\":\"2026-03-11 17:34:58.554786\",\"ts_ms\":1773221698547,\"device_id\":\"026004001146\",\"hotel_id\":\"1050\",\"room_id\":\"8606\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.554786",
"ts_ms": 1773221698547,
"device_id": "026004001146",
"hotel_id": "1050",
"room_id": "8606"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862122,
"key": "1580",
"value": "{\"current_time\":\"2026-03-11 17:34:58.556860\",\"ts_ms\":1773221698547,\"device_id\":\"044006041109\",\"hotel_id\":\"1580\",\"room_id\":\"1102\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.556860",
"ts_ms": 1773221698547,
"device_id": "044006041109",
"hotel_id": "1580",
"room_id": "1102"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862123,
"key": "1556",
"value": "{\"current_time\":\"2026-03-11 17:34:58.557342\",\"ts_ms\":1773221698547,\"device_id\":\"020006020051\",\"hotel_id\":\"1556\",\"room_id\":\"8666\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.557342",
"ts_ms": 1773221698547,
"device_id": "020006020051",
"hotel_id": "1556",
"room_id": "8666"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862124,
"key": "1051",
"value": "{\"current_time\":\"2026-03-11 17:34:58.558490\",\"ts_ms\":1773221698547,\"device_id\":\"027004001018\",\"hotel_id\":\"1051\",\"room_id\":\"310\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.558490",
"ts_ms": 1773221698547,
"device_id": "027004001018",
"hotel_id": "1051",
"room_id": "310"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4862125,
"key": "1161",
"value": "{\"current_time\":\"2026-03-11 17:34:58.562369\",\"ts_ms\":1773221698547,\"device_id\":\"137004040109\",\"hotel_id\":\"1161\",\"room_id\":\"1127\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:34:58.562369",
"ts_ms": 1773221698547,
"device_id": "137004040109",
"hotel_id": "1161",
"room_id": "1127"
}
}
]
}