Files
Web_BLS_OldRcu_Heartbeat_Se…/bls-oldrcu-heartbeat-backend/logs/kafka-sample-1773220400582.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:13:31.814Z",
"reason": "sample-size-reached",
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"brokers": [
"kafka.blv-oa.com:9092"
],
"sampleSizeRequested": 50,
"sampleSizeCollected": 50,
"summary": {
"totalMessages": 50,
"validTopLevelShape": 0,
"invalidTopLevelShape": 50,
"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:13:20.020827",
"ts_ms": 1773220400014,
"device_id": "253007116252",
"hotel_id": "2045",
"room_id": "8809"
},
"firstRawExample": "{\"current_time\":\"2026-03-11 17:13:20.020827\",\"ts_ms\":1773220400014,\"device_id\":\"253007116252\",\"hotel_id\":\"2045\",\"room_id\":\"8809\"}"
},
"samples": [
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614858,
"key": "2045",
"value": "{\"current_time\":\"2026-03-11 17:13:20.020827\",\"ts_ms\":1773220400014,\"device_id\":\"253007116252\",\"hotel_id\":\"2045\",\"room_id\":\"8809\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.020827",
"ts_ms": 1773220400014,
"device_id": "253007116252",
"hotel_id": "2045",
"room_id": "8809"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614859,
"key": "1633",
"value": "{\"current_time\":\"2026-03-11 17:13:20.032704\",\"ts_ms\":1773220400029,\"device_id\":\"097006075237\",\"hotel_id\":\"1633\",\"room_id\":\"8306\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.032704",
"ts_ms": 1773220400029,
"device_id": "097006075237",
"hotel_id": "1633",
"room_id": "8306"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614860,
"key": "1071",
"value": "{\"current_time\":\"2026-03-11 17:13:20.043656\",\"ts_ms\":1773220400029,\"device_id\":\"047004000150\",\"hotel_id\":\"1071\",\"room_id\":\"1001\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.043656",
"ts_ms": 1773220400029,
"device_id": "047004000150",
"hotel_id": "1071",
"room_id": "1001"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614861,
"key": "1051",
"value": "{\"current_time\":\"2026-03-11 17:13:20.045454\",\"ts_ms\":1773220400029,\"device_id\":\"027004001015\",\"hotel_id\":\"1051\",\"room_id\":\"307\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.045454",
"ts_ms": 1773220400029,
"device_id": "027004001015",
"hotel_id": "1051",
"room_id": "307"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614862,
"key": "1963",
"value": "{\"current_time\":\"2026-03-11 17:13:20.052092\",\"ts_ms\":1773220400045,\"device_id\":\"171007094206\",\"hotel_id\":\"1963\",\"room_id\":\"1412\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.052092",
"ts_ms": 1773220400045,
"device_id": "171007094206",
"hotel_id": "1963",
"room_id": "1412"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614863,
"key": "1050",
"value": "{\"current_time\":\"2026-03-11 17:13:20.055553\",\"ts_ms\":1773220400045,\"device_id\":\"026004001138\",\"hotel_id\":\"1050\",\"room_id\":\"8518\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.055553",
"ts_ms": 1773220400045,
"device_id": "026004001138",
"hotel_id": "1050",
"room_id": "8518"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614864,
"key": "1006",
"value": "{\"current_time\":\"2026-03-11 17:13:20.065121\",\"ts_ms\":1773220400061,\"device_id\":\"238003002030\",\"hotel_id\":\"1006\",\"room_id\":\"211\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.065121",
"ts_ms": 1773220400061,
"device_id": "238003002030",
"hotel_id": "1006",
"room_id": "211"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614865,
"key": "1071",
"value": "{\"current_time\":\"2026-03-11 17:13:20.065480\",\"ts_ms\":1773220400061,\"device_id\":\"047004000225\",\"hotel_id\":\"1071\",\"room_id\":\"1807\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.065480",
"ts_ms": 1773220400061,
"device_id": "047004000225",
"hotel_id": "1071",
"room_id": "1807"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614866,
"key": "1556",
"value": "{\"current_time\":\"2026-03-11 17:13:20.068946\",\"ts_ms\":1773220400061,\"device_id\":\"020006020048\",\"hotel_id\":\"1556\",\"room_id\":\"8558\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.068946",
"ts_ms": 1773220400061,
"device_id": "020006020048",
"hotel_id": "1556",
"room_id": "8558"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614867,
"key": "1071",
"value": "{\"current_time\":\"2026-03-11 17:13:20.071875\",\"ts_ms\":1773220400061,\"device_id\":\"047004000207\",\"hotel_id\":\"1071\",\"room_id\":\"1609\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.071875",
"ts_ms": 1773220400061,
"device_id": "047004000207",
"hotel_id": "1071",
"room_id": "1609"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614868,
"key": "2013",
"value": "{\"current_time\":\"2026-03-11 17:13:20.090010\",\"ts_ms\":1773220400076,\"device_id\":\"221007127071\",\"hotel_id\":\"2013\",\"room_id\":\"8313\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.090010",
"ts_ms": 1773220400076,
"device_id": "221007127071",
"hotel_id": "2013",
"room_id": "8313"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614869,
"key": "1071",
"value": "{\"current_time\":\"2026-03-11 17:13:20.093838\",\"ts_ms\":1773220400092,\"device_id\":\"047004000135\",\"hotel_id\":\"1071\",\"room_id\":\"807\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.093838",
"ts_ms": 1773220400092,
"device_id": "047004000135",
"hotel_id": "1071",
"room_id": "807"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614870,
"key": "1968",
"value": "{\"current_time\":\"2026-03-11 17:13:20.101157\",\"ts_ms\":1773220400092,\"device_id\":\"176007129249\",\"hotel_id\":\"1968\",\"room_id\":\"1510\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.101157",
"ts_ms": 1773220400092,
"device_id": "176007129249",
"hotel_id": "1968",
"room_id": "1510"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614871,
"key": "1963",
"value": "{\"current_time\":\"2026-03-11 17:13:20.109846\",\"ts_ms\":1773220400107,\"device_id\":\"171007094236\",\"hotel_id\":\"1963\",\"room_id\":\"1312\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.109846",
"ts_ms": 1773220400107,
"device_id": "171007094236",
"hotel_id": "1963",
"room_id": "1312"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614872,
"key": "1691",
"value": "{\"current_time\":\"2026-03-11 17:13:20.115469\",\"ts_ms\":1773220400107,\"device_id\":\"155006043043\",\"hotel_id\":\"1691\",\"room_id\":\"8608\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.115469",
"ts_ms": 1773220400107,
"device_id": "155006043043",
"hotel_id": "1691",
"room_id": "8608"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614873,
"key": "1472",
"value": "{\"current_time\":\"2026-03-11 17:13:20.126913\",\"ts_ms\":1773220400123,\"device_id\":\"192005035071\",\"hotel_id\":\"1472\",\"room_id\":\"8088\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.126913",
"ts_ms": 1773220400123,
"device_id": "192005035071",
"hotel_id": "1472",
"room_id": "8088"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614874,
"key": "1006",
"value": "{\"current_time\":\"2026-03-11 17:13:20.130498\",\"ts_ms\":1773220400123,\"device_id\":\"238003002087\",\"hotel_id\":\"1006\",\"room_id\":\"317\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.130498",
"ts_ms": 1773220400123,
"device_id": "238003002087",
"hotel_id": "1006",
"room_id": "317"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614875,
"key": "1085",
"value": "{\"current_time\":\"2026-03-11 17:13:20.135797\",\"ts_ms\":1773220400123,\"device_id\":\"061004046043\",\"hotel_id\":\"1085\",\"room_id\":\"大会议室\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.135797",
"ts_ms": 1773220400123,
"device_id": "061004046043",
"hotel_id": "1085",
"room_id": "大会议室"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614876,
"key": "1383",
"value": "{\"current_time\":\"2026-03-11 17:13:20.143637\",\"ts_ms\":1773220400139,\"device_id\":\"103005024106\",\"hotel_id\":\"1383\",\"room_id\":\"8421\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.143637",
"ts_ms": 1773220400139,
"device_id": "103005024106",
"hotel_id": "1383",
"room_id": "8421"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614877,
"key": "1093",
"value": "{\"current_time\":\"2026-03-11 17:13:20.150421\",\"ts_ms\":1773220400139,\"device_id\":\"069004002078\",\"hotel_id\":\"1093\",\"room_id\":\"A608\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.150421",
"ts_ms": 1773220400139,
"device_id": "069004002078",
"hotel_id": "1093",
"room_id": "A608"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614878,
"key": "1968",
"value": "{\"current_time\":\"2026-03-11 17:13:20.157364\",\"ts_ms\":1773220400154,\"device_id\":\"176007129222\",\"hotel_id\":\"1968\",\"room_id\":\"1325卧室\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.157364",
"ts_ms": 1773220400154,
"device_id": "176007129222",
"hotel_id": "1968",
"room_id": "1325卧室"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614879,
"key": "1914",
"value": "{\"current_time\":\"2026-03-11 17:13:20.166046\",\"ts_ms\":1773220400154,\"device_id\":\"122007120099\",\"hotel_id\":\"1914\",\"room_id\":\"1301\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.166046",
"ts_ms": 1773220400154,
"device_id": "122007120099",
"hotel_id": "1914",
"room_id": "1301"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614880,
"key": "1114",
"value": "{\"current_time\":\"2026-03-11 17:13:20.168558\",\"ts_ms\":1773220400154,\"device_id\":\"090004001036\",\"hotel_id\":\"1114\",\"room_id\":\"1216\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.168558",
"ts_ms": 1773220400154,
"device_id": "090004001036",
"hotel_id": "1114",
"room_id": "1216"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614881,
"key": "1451",
"value": "{\"current_time\":\"2026-03-11 17:13:20.169440\",\"ts_ms\":1773220400154,\"device_id\":\"171005011104\",\"hotel_id\":\"1451\",\"room_id\":\"2102\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.169440",
"ts_ms": 1773220400154,
"device_id": "171005011104",
"hotel_id": "1451",
"room_id": "2102"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614882,
"key": "1006",
"value": "{\"current_time\":\"2026-03-11 17:13:20.170567\",\"ts_ms\":1773220400170,\"device_id\":\"238003002057\",\"hotel_id\":\"1006\",\"room_id\":\"251\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.170567",
"ts_ms": 1773220400170,
"device_id": "238003002057",
"hotel_id": "1006",
"room_id": "251"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614883,
"key": "2182",
"value": "{\"current_time\":\"2026-03-11 17:13:20.171407\",\"ts_ms\":1773220400170,\"device_id\":\"134008108220\",\"hotel_id\":\"2182\",\"room_id\":\"8219\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.171407",
"ts_ms": 1773220400170,
"device_id": "134008108220",
"hotel_id": "2182",
"room_id": "8219"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614884,
"key": "1633",
"value": "{\"current_time\":\"2026-03-11 17:13:20.172246\",\"ts_ms\":1773220400170,\"device_id\":\"097006077183\",\"hotel_id\":\"1633\",\"room_id\":\"8301\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.172246",
"ts_ms": 1773220400170,
"device_id": "097006077183",
"hotel_id": "1633",
"room_id": "8301"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614885,
"key": "1115",
"value": "{\"current_time\":\"2026-03-11 17:13:20.174435\",\"ts_ms\":1773220400170,\"device_id\":\"091004010149\",\"hotel_id\":\"1115\",\"room_id\":\"1005\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.174435",
"ts_ms": 1773220400170,
"device_id": "091004010149",
"hotel_id": "1115",
"room_id": "1005"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614886,
"key": "1115",
"value": "{\"current_time\":\"2026-03-11 17:13:20.179187\",\"ts_ms\":1773220400170,\"device_id\":\"091004010069\",\"hotel_id\":\"1115\",\"room_id\":\"805\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.179187",
"ts_ms": 1773220400170,
"device_id": "091004010069",
"hotel_id": "1115",
"room_id": "805"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614887,
"key": "2013",
"value": "{\"current_time\":\"2026-03-11 17:13:20.183860\",\"ts_ms\":1773220400170,\"device_id\":\"221007129196\",\"hotel_id\":\"2013\",\"room_id\":\"8517\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.183860",
"ts_ms": 1773220400170,
"device_id": "221007129196",
"hotel_id": "2013",
"room_id": "8517"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614888,
"key": "1321",
"value": "{\"current_time\":\"2026-03-11 17:13:20.193038\",\"ts_ms\":1773220400186,\"device_id\":\"041005024178\",\"hotel_id\":\"1321\",\"room_id\":\"8505\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.193038",
"ts_ms": 1773220400186,
"device_id": "041005024178",
"hotel_id": "1321",
"room_id": "8505"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614889,
"key": "1580",
"value": "{\"current_time\":\"2026-03-11 17:13:20.204493\",\"ts_ms\":1773220400201,\"device_id\":\"044006041207\",\"hotel_id\":\"1580\",\"room_id\":\"1002\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.204493",
"ts_ms": 1773220400201,
"device_id": "044006041207",
"hotel_id": "1580",
"room_id": "1002"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614890,
"key": "1084",
"value": "{\"current_time\":\"2026-03-11 17:13:20.205702\",\"ts_ms\":1773220400201,\"device_id\":\"060004002038\",\"hotel_id\":\"1084\",\"room_id\":\"002038\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.205702",
"ts_ms": 1773220400201,
"device_id": "060004002038",
"hotel_id": "1084",
"room_id": "002038"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614891,
"key": "1293",
"value": "{\"current_time\":\"2026-03-11 17:13:20.212442\",\"ts_ms\":1773220400201,\"device_id\":\"013005010024\",\"hotel_id\":\"1293\",\"room_id\":\"4号102\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.212442",
"ts_ms": 1773220400201,
"device_id": "013005010024",
"hotel_id": "1293",
"room_id": "4号102"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614892,
"key": "1051",
"value": "{\"current_time\":\"2026-03-11 17:13:20.214435\",\"ts_ms\":1773220400201,\"device_id\":\"027004001019\",\"hotel_id\":\"1051\",\"room_id\":\"311\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.214435",
"ts_ms": 1773220400201,
"device_id": "027004001019",
"hotel_id": "1051",
"room_id": "311"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614893,
"key": "1873",
"value": "{\"current_time\":\"2026-03-11 17:13:20.216167\",\"ts_ms\":1773220400201,\"device_id\":\"081007084117\",\"hotel_id\":\"1873\",\"room_id\":\"312\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.216167",
"ts_ms": 1773220400201,
"device_id": "081007084117",
"hotel_id": "1873",
"room_id": "312"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614894,
"key": "1963",
"value": "{\"current_time\":\"2026-03-11 17:13:20.224196\",\"ts_ms\":1773220400217,\"device_id\":\"171007094183\",\"hotel_id\":\"1963\",\"room_id\":\"1011\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.224196",
"ts_ms": 1773220400217,
"device_id": "171007094183",
"hotel_id": "1963",
"room_id": "1011"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614895,
"key": "1093",
"value": "{\"current_time\":\"2026-03-11 17:13:20.226782\",\"ts_ms\":1773220400217,\"device_id\":\"069004002091\",\"hotel_id\":\"1093\",\"room_id\":\"A509\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.226782",
"ts_ms": 1773220400217,
"device_id": "069004002091",
"hotel_id": "1093",
"room_id": "A509"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614896,
"key": "1914",
"value": "{\"current_time\":\"2026-03-11 17:13:20.233152\",\"ts_ms\":1773220400217,\"device_id\":\"122007101232\",\"hotel_id\":\"1914\",\"room_id\":\"501\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.233152",
"ts_ms": 1773220400217,
"device_id": "122007101232",
"hotel_id": "1914",
"room_id": "501"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614897,
"key": "1114",
"value": "{\"current_time\":\"2026-03-11 17:13:20.233839\",\"ts_ms\":1773220400233,\"device_id\":\"090004001058\",\"hotel_id\":\"1114\",\"room_id\":\"1118\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.233839",
"ts_ms": 1773220400233,
"device_id": "090004001058",
"hotel_id": "1114",
"room_id": "1118"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614898,
"key": "1050",
"value": "{\"current_time\":\"2026-03-11 17:13:20.234116\",\"ts_ms\":1773220400233,\"device_id\":\"026004001131\",\"hotel_id\":\"1050\",\"room_id\":\"8516\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.234116",
"ts_ms": 1773220400233,
"device_id": "026004001131",
"hotel_id": "1050",
"room_id": "8516"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614899,
"key": "1383",
"value": "{\"current_time\":\"2026-03-11 17:13:20.239039\",\"ts_ms\":1773220400233,\"device_id\":\"103005027051\",\"hotel_id\":\"1383\",\"room_id\":\"8310\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.239039",
"ts_ms": 1773220400233,
"device_id": "103005027051",
"hotel_id": "1383",
"room_id": "8310"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614900,
"key": "1030",
"value": "{\"current_time\":\"2026-03-11 17:13:20.241678\",\"ts_ms\":1773220400233,\"device_id\":\"006004040061\",\"hotel_id\":\"1030\",\"room_id\":\"8603\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.241678",
"ts_ms": 1773220400233,
"device_id": "006004040061",
"hotel_id": "1030",
"room_id": "8603"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614901,
"key": "1968",
"value": "{\"current_time\":\"2026-03-11 17:13:20.243676\",\"ts_ms\":1773220400233,\"device_id\":\"176007129209\",\"hotel_id\":\"1968\",\"room_id\":\"1225卧室\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.243676",
"ts_ms": 1773220400233,
"device_id": "176007129209",
"hotel_id": "1968",
"room_id": "1225卧室"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614902,
"key": "1486",
"value": "{\"current_time\":\"2026-03-11 17:13:20.244398\",\"ts_ms\":1773220400233,\"device_id\":\"206005058113\",\"hotel_id\":\"1486\",\"room_id\":\"8813\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.244398",
"ts_ms": 1773220400233,
"device_id": "206005058113",
"hotel_id": "1486",
"room_id": "8813"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614903,
"key": "1176",
"value": "{\"current_time\":\"2026-03-11 17:13:20.249065\",\"ts_ms\":1773220400248,\"device_id\":\"152004125192\",\"hotel_id\":\"1176\",\"room_id\":\"213\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.249065",
"ts_ms": 1773220400248,
"device_id": "152004125192",
"hotel_id": "1176",
"room_id": "213"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614904,
"key": "1051",
"value": "{\"current_time\":\"2026-03-11 17:13:20.249856\",\"ts_ms\":1773220400248,\"device_id\":\"027004001016\",\"hotel_id\":\"1051\",\"room_id\":\"308\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.249856",
"ts_ms": 1773220400248,
"device_id": "027004001016",
"hotel_id": "1051",
"room_id": "308"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614905,
"key": "1963",
"value": "{\"current_time\":\"2026-03-11 17:13:20.255564\",\"ts_ms\":1773220400248,\"device_id\":\"171007096054\",\"hotel_id\":\"1963\",\"room_id\":\"1406\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.255564",
"ts_ms": 1773220400248,
"device_id": "171007096054",
"hotel_id": "1963",
"room_id": "1406"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614906,
"key": "1472",
"value": "{\"current_time\":\"2026-03-11 17:13:20.257063\",\"ts_ms\":1773220400248,\"device_id\":\"192005035073\",\"hotel_id\":\"1472\",\"room_id\":\"8035\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.257063",
"ts_ms": 1773220400248,
"device_id": "192005035073",
"hotel_id": "1472",
"room_id": "8035"
}
},
{
"topic": "blwlog4Nodejs-oldrcu-heartbeat-topic",
"partition": 0,
"offset": 4614907,
"key": "1412",
"value": "{\"current_time\":\"2026-03-11 17:13:20.260427\",\"ts_ms\":1773220400248,\"device_id\":\"132005028203\",\"hotel_id\":\"1412\",\"room_id\":\"8805\"}",
"jsonParsed": true,
"parsed": {
"current_time": "2026-03-11 17:13:20.260427",
"ts_ms": 1773220400248,
"device_id": "132005028203",
"hotel_id": "1412",
"room_id": "8805"
}
}
]
}