399 lines
		
	
	
		
			19 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
		
		
			
		
	
	
			399 lines
		
	
	
		
			19 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
|  | 当前日志: | |||
|  | 时间戳 - 方法名 - 日志等级 - [user_email: xxx] [conversation_id: xxx] 描述信息 | |||
|  | 
 | |||
|  | 
 | |||
|  | 时间戳 - 方法名 - 日志等级 - [user_email: xxx] [conversation_id: xxx] [event: xxx | status: xxx | msg: xxx] 描述信息 | |||
|  | 
 | |||
|  | 2025-05-25 21:23:20 - __main__ - WARNING - [user_email: DXIN@qq.com] [conversation_id: ad945d8] [event: xxx | status: xxx | msg: xxx] 404 Error - Endpoint: /, Method: OPTIONS | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 2025-06-16 17:40:10 - dialogue.ai_service_call - INFO - [user_email: chendinxin@gmail.com] [conversation_id: 123456-1234-1234-1234-123456789] 用户历史消息: 我是一条测试的日志 | |||
|  | 
 | |||
|  | 2025-06-16 17:40:28 - business - WARNING - [user_email: chendinxin@gmail.com] [conversation_id: 123456-1234-1234-1234-123456789] [event: 达人搜素 | msg: 我是假的处理耗时过长,耗时: 64.96秒,匹配达人数: 219 | context: duration:64.96s,results_count:219] | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 背景:我是运维人员,将日志采集到es中,基于查询日志等级为error的日志进行查询告警。 | |||
|  | 当前日志格式:时间戳 - 方法名 - 日志等级 - [用户邮箱:用户邮箱] [会话id:会话id] 错误描述 or 错误堆栈信息 or 其它 | |||
|  | 如:2025-05-26 03:00:45 - __main__ - ERROR - [user_email: mumemen9@gmail.com] [conversation_id: cfe9f405-0919-40ea-9769-c75e3a1854ae] 404 Error - Endpoint: /, Method: GET | |||
|  | 在日志采集filebesa采集的处理器设置进行采集并拆解了各个字段: | |||
|  |   # 针对 influencer_5002.log 的 dissect(基础字段分解) | |||
|  |   - dissect: | |||
|  |       when: | |||
|  |         equals: | |||
|  |           log_type: influencer_5002.log | |||
|  |       tokenizer: '%{timestamp} - %{module} - %{level} - %{raw_tail}' | |||
|  |       field: "message" | |||
|  |       target_prefix: "mylog" | |||
|  |       ignore_missing: true | |||
|  |       overwrite_keys: true | |||
|  | 
 | |||
|  |   # 从 message 中提取 user_email | |||
|  |   - dissect: | |||
|  |       when: | |||
|  |         equals: | |||
|  |           log_type: influencer_5002.log | |||
|  |       tokenizer: '[user_email: %{user_email}] %{tail}' | |||
|  |       field: "mylog.raw_tail" | |||
|  |       target_prefix: "mylog" | |||
|  |       ignore_missing: true | |||
|  |       overwrite_keys: true | |||
|  | 
 | |||
|  |   # 提取 conversation_id | |||
|  |   - dissect: | |||
|  |       when: | |||
|  |         equals: | |||
|  |           log_type: influencer_5002.log | |||
|  |       tokenizer: '[conversation_id: %{conversation_id}] %{tail}' | |||
|  |       field: "mylog.tail" | |||
|  |       target_prefix: "mylog" | |||
|  |       ignore_missing: true | |||
|  |       overwrite_keys: true | |||
|  | 
 | |||
|  | 当前这个方式可以做到日志告警基于日志等级是error进行查询告警,这里定义为"服务系统告警"。 | |||
|  | 现在需要添加需要“业务层面指标”、“技术层面指标”、“安全层面指标的告警”,在当前日志中不能直接体现,这需要更改日志结构或者在日志结构中添加业务字段或说明。 | |||
|  | 以下是未来需要增加的告警: | |||
|  | 业务层面指标: | |||
|  | 环节            监控事件            告警规则 | |||
|  | 达人检索        检索召回数量少       召回数量≤5 | |||
|  |                 召回响应时间长      响应时间≥20s | |||
|  | 任务创建        任务创建失败        用户走完流程,但任务未创建成功                | |||
|  | 邮件发送        任务未启动          任务创建后10min,状态仍为待启动 | |||
|  |                 邮件发送速率低      邮件发送速度小于2min/封 | |||
|  |                 任务中止            当日实发数<应发数,但超过2min未发送新邮件 | |||
|  |                 任务发不满          任务状态已完成,但实发数<应发数 | |||
|  |                 邮件回复率为0       任务完成后24h,回复率为0 | |||
|  |                 退信率              整体退信率>5% | |||
|  | 
 | |||
|  | 技术层面指标: | |||
|  | 1. 各接口请求成功率(尤其是在对话的时候,是否有顺利出AI回复) | |||
|  | 2. 并发用户数&任务数 | |||
|  | 3. InsightIQ调用量 | |||
|  | 
 | |||
|  | 安全层面指标 | |||
|  | 1. 异常登录监测 | |||
|  | 2. 一定时间段内检索频次 | |||
|  | 
 | |||
|  | 怎么改造这个日志可以完成通过查询es可以做到监控告警,或则有别的方式时间吗? | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | ## 1、请求端点404错误
 | |||
|  | ``` | |||
|  | 2025-05-26 03:00:45 - __main__ - ERROR - [user_email: mumemen9@gmail.com] [conversation_id: cfe9f405-0919-40ea-9769-c75e3a1854ae] 404 Error - Endpoint: /, Method: GET | |||
|  | ``` | |||
|  | ``` | |||
|  | 2025-05-25 21:23:20 - __main__ - ERROR - [user_email: ] [conversation_id: ad945d82-5d7d-4874-bb9b-fbf7532ba4f9] 404 Error - Endpoint: /, Method: OPTIONS | |||
|  | ``` | |||
|  | 
 | |||
|  | ## 2、请求语法错误
 | |||
|  | ``` | |||
|  | 2025-05-26 02:27:44 - werkzeug - ERROR - [user_email: mumemen9@gmail.com] [conversation_id: cfe9f405-0919-40ea-9769-c75e3a1854ae] 172.236.228.229 - - [26/May/2025 02:27:44] code 400, message Bad request syntax ('\x16\x03\x01\x01') | |||
|  | ``` | |||
|  | 
 | |||
|  | ## 3、请求版本错误
 | |||
|  | ``` | |||
|  | 2025-05-26 01:09:58 - werkzeug - ERROR - [user_email: yubeichuan@gmail.com] [conversation_id: 26a4c827-f83b-4af9-aa21-4f1e87b59c10] 3.143.33.63 - - [26/May/2025 01:09:58] code 400, message Bad request version ('À\x14À') | |||
|  | ``` | |||
|  | 
 | |||
|  | ## 4、请求语法错误
 | |||
|  | ``` | |||
|  | 2025-05-25 21:24:10 - werkzeug - ERROR - [user_email: ] [conversation_id: ad945d82-5d7d-4874-bb9b-fbf7532ba4f9] 51.81.155.131 - - [25/May/2025 21:24:10] code 400, message Bad request syntax ('\x0e\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00bbbb0100000001') | |||
|  | ``` | |||
|  | 
 | |||
|  | ## 5、无效的http请求类型
 | |||
|  | ``` | |||
|  | 2025-05-25 21:23:45 - werkzeug - ERROR - [user_email: ] [conversation_id: ad945d82-5d7d-4874-bb9b-fbf7532ba4f9] 51.81.155.131 - - [25/May/2025 21:23:45] code 400, message Bad HTTP/0.9 request type ('AMQP\x00\x00') | |||
|  | ``` | |||
|  | 
 | |||
|  | ## 6、api请求失败
 | |||
|  | ``` | |||
|  | 2025-05-25 20:35:38 - __main__ - ERROR - [user_email: jennie.christina.ai@gmail.com] [conversation_id: ad945d82-5d7d-4874-bb9b-fbf7532ba4f9] 详细错误信息: Traceback (most recent call last): | |||
|  |   File "/data/webapps/influencer_search_agent/utils/base_gateway.py", line 69, in _request | |||
|  |     response.raise_for_status() | |||
|  |   File "/root/miniconda3/envs/search/lib/python3.12/site-packages/requests/models.py", line 1024, in raise_for_status | |||
|  |     raise HTTPError(http_error_msg, response=self) | |||
|  | requests.exceptions.HTTPError: 429 Client Error:  for url: https://api.insightiq.ai/v1/social/creators/dictionary/topics/?work_platform_id=14d9ddf5-51c6-415e-bde6-f8ed36ad7054&identifier=DIY+office&limit=6 | |||
|  | 
 | |||
|  | During handling of the above exception, another exception occurred: | |||
|  | 
 | |||
|  | Traceback (most recent call last): | |||
|  |   File "/data/webapps/influencer_search_agent/dialogue/influencer_5002.py", line 291, in search_single_card | |||
|  |     topic_list = insightiq_gateway.get_topic_list(query_text, channels) | |||
|  |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | |||
|  |   File "/data/webapps/influencer_search_agent/gateway/insightiq_gateway.py", line 246, in get_topic_list | |||
|  |     response = self._request('GET', f'social/creators/dictionary/topics/', params={'work_platform_id': work_platform_id, 'identifier': query_text, 'limit': 6}) | |||
|  |                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | |||
|  |   File "/data/webapps/influencer_search_agent/utils/base_gateway.py", line 86, in _request | |||
|  |     raise Exception(f"API请求失败: {str(e)}") | |||
|  | Exception: API请求失败: 429 Client Error:  for url: https://api.insightiq.ai/v1/social/creators/dictionary/topics/?work_platform_id=14d9ddf5-51c6-415e-bde6-f8ed36ad7054&identifier=DIY+office&limit=6 | |||
|  | ``` | |||
|  | ``` | |||
|  | 2025-05-25 20:35:38 - __main__ - ERROR - [user_email: jennie.christina.ai@gmail.com] [conversation_id: ad945d82-5d7d-4874-bb9b-fbf7532ba4f9] 处理卡片 4 时出错: API请求失败: 429 Client Error:  for url: https://api.insightiq.ai/v1/social/creators/dictionary/topics/?work_platform_id=14d9ddf5-51c6-415e-bde6-f8ed36ad7054&identifier=DIY+office&limit=6 | |||
|  | ``` | |||
|  | ``` | |||
|  | 2025-05-25 20:35:38 - utils.base_gateway - ERROR - [user_email: jennie.christina.ai@gmail.com] [conversation_id: ad945d82-5d7d-4874-bb9b-fbf7532ba4f9] API请求异常: 429 Client Error:  for url: https://api.insightiq.ai/v1/social/creators/dictionary/topics/?work_platform_id=14d9ddf5-51c6-415e-bde6-f8ed36ad7054&identifier=DIY+office&limit=6 | |||
|  | ``` | |||
|  | 
 | |||
|  | ## 7、参数错误
 | |||
|  | ``` | |||
|  | 2025-05-25 20:35:38 - utils.base_gateway - ERROR - [user_email: jennie.christina.ai@gmail.com] [conversation_id: ad945d82-5d7d-4874-bb9b-fbf7532ba4f9] Error param, https://api.insightiq.ai/v1/, social/creators/dictionary/topics/ | |||
|  | ``` | |||
|  | 
 | |||
|  | ## 8、聊天处理错误
 | |||
|  | ``` | |||
|  | 2025-05-25 19:45:06 - dialogue.ai_service_call - ERROR - [user_email: jennie.christina.ai@gmail.com] [conversation_id: fef57c39-3e6c-4bbf-8805-c91d0636b1c0] process chat error: the JSON object must be str, bytes or bytearray, not NoneType | |||
|  | Traceback (most recent call last): | |||
|  |   File "/data/webapps/influencer_search_agent/dialogue/ai_service_call.py", line 859, in update_influencer_card_form | |||
|  |     last_history_message_list = json.loads(last_history_message_list_str) | |||
|  |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | |||
|  |   File "/root/miniconda3/envs/search/lib/python3.12/json/__init__.py", line 339, in loads | |||
|  |     raise TypeError(f'the JSON object must be str, bytes or bytearray, ' | |||
|  | TypeError: the JSON object must be str, bytes or bytearray, not NoneType | |||
|  | ``` | |||
|  | 
 | |||
|  | ## 9、登录过期错误
 | |||
|  | ``` | |||
|  | 2025-05-23 20:11:22 - memory.memory_slots - ERROR - [user_email: ] [conversation_id: 5d1614dd-9e92-4db6-97b6-83d38c94b1e3] 从远程数据库加载数据失败,状态码: 401,响应: {"code":401,"msg":"Your login status has expired, please log in again!","data":null} | |||
|  | ``` | |||
|  | 
 | |||
|  | 
 | |||
|  | ## 在es里的摘要:
 | |||
|  | ``` | |||
|  | { | |||
|  |   "@timestamp": [ | |||
|  |     "2025-05-25T19:00:50.099Z" | |||
|  |   ], | |||
|  |   "agent.ephemeral_id": [ | |||
|  |     "0b9f9018-ed5f-4fd0-8ad2-554873ca870b" | |||
|  |   ], | |||
|  |   "agent.ephemeral_id.keyword": [ | |||
|  |     "0b9f9018-ed5f-4fd0-8ad2-554873ca870b" | |||
|  |   ], | |||
|  |   "agent.id": [ | |||
|  |     "d0764891-a93b-426f-9282-31c476153eb3" | |||
|  |   ], | |||
|  |   "agent.id.keyword": [ | |||
|  |     "d0764891-a93b-426f-9282-31c476153eb3" | |||
|  |   ], | |||
|  |   "agent.name": [ | |||
|  |     "VM-0-3-centos" | |||
|  |   ], | |||
|  |   "agent.name.keyword": [ | |||
|  |     "VM-0-3-centos" | |||
|  |   ], | |||
|  |   "agent.type": [ | |||
|  |     "filebeat" | |||
|  |   ], | |||
|  |   "agent.type.keyword": [ | |||
|  |     "filebeat" | |||
|  |   ], | |||
|  |   "agent.version": [ | |||
|  |     "8.17.0" | |||
|  |   ], | |||
|  |   "agent.version.keyword": [ | |||
|  |     "8.17.0" | |||
|  |   ], | |||
|  |   "application": [ | |||
|  |     "influencer_search_app.lessie.ai" | |||
|  |   ], | |||
|  |   "application.keyword": [ | |||
|  |     "influencer_search_app.lessie.ai" | |||
|  |   ], | |||
|  |   "ecs.version": [ | |||
|  |     "8.0.0" | |||
|  |   ], | |||
|  |   "ecs.version.keyword": [ | |||
|  |     "8.0.0" | |||
|  |   ], | |||
|  |   "environment": [ | |||
|  |     "app_lessie_ai" | |||
|  |   ], | |||
|  |   "environment.keyword": [ | |||
|  |     "app_lessie_ai" | |||
|  |   ], | |||
|  |   "host.name": [ | |||
|  |     "VM-0-3-centos" | |||
|  |   ], | |||
|  |   "input.type": [ | |||
|  |     "log" | |||
|  |   ], | |||
|  |   "input.type.keyword": [ | |||
|  |     "log" | |||
|  |   ], | |||
|  |   "log.file.path": [ | |||
|  |     "/data/webapps/influencer_search_agent/log/influencer_5002_20250523_193646.log" | |||
|  |   ], | |||
|  |   "log.file.path.keyword": [ | |||
|  |     "/data/webapps/influencer_search_agent/log/influencer_5002_20250523_193646.log" | |||
|  |   ], | |||
|  |   "log.offset": [ | |||
|  |     60913844 | |||
|  |   ], | |||
|  |   "log_type": [ | |||
|  |     "influencer_5002.log" | |||
|  |   ], | |||
|  |   "log_type.keyword": [ | |||
|  |     "influencer_5002.log" | |||
|  |   ], | |||
|  |   "message": [ | |||
|  |     "2025-05-26 03:00:45 - __main__ - ERROR - [user_email: mumemen9@gmail.com] [conversation_id: cfe9f405-0919-40ea-9769-c75e3a1854ae] 404 Error - Endpoint: /, Method: GET" | |||
|  |   ], | |||
|  |   "message.keyword": [ | |||
|  |     "2025-05-26 03:00:45 - __main__ - ERROR - [user_email: mumemen9@gmail.com] [conversation_id: cfe9f405-0919-40ea-9769-c75e3a1854ae] 404 Error - Endpoint: /, Method: GET" | |||
|  |   ], | |||
|  |   "mylog.level": [ | |||
|  |     "ERROR" | |||
|  |   ], | |||
|  |   "mylog.level.keyword": [ | |||
|  |     "ERROR" | |||
|  |   ], | |||
|  |   "mylog.message": [ | |||
|  |     "[user_email: mumemen9@gmail.com] [conversation_id: cfe9f405-0919-40ea-9769-c75e3a1854ae] 404 Error - Endpoint: /, Method: GET" | |||
|  |   ], | |||
|  |   "mylog.message.keyword": [ | |||
|  |     "[user_email: mumemen9@gmail.com] [conversation_id: cfe9f405-0919-40ea-9769-c75e3a1854ae] 404 Error - Endpoint: /, Method: GET" | |||
|  |   ], | |||
|  |   "mylog.module": [ | |||
|  |     "__main__" | |||
|  |   ], | |||
|  |   "mylog.module.keyword": [ | |||
|  |     "__main__" | |||
|  |   ], | |||
|  |   "mylog.timestamp": [ | |||
|  |     "2025-05-26 03:00:45" | |||
|  |   ], | |||
|  |   "mylog.timestamp.keyword": [ | |||
|  |     "2025-05-26 03:00:45" | |||
|  |   ], | |||
|  |   "_id": "AZcI0XdDvDmC7+Hb10iq", | |||
|  |   "_index": ".ds-out-148-flymoonlog-app_lessie_ai-influencer_search_app.lessie.ai-2025.05-2025.05.21-000002", | |||
|  |   "_score": null | |||
|  | } | |||
|  | ``` | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 2025-05-27 00:19:10 - __main__ - INFO - [user_email: pengdachen1995@gmail.com] [conversation_id: 9ea1bef1-3121-484b-a239-5f413139d88c] 穿插排序后的结果数量: 0 | |||
|  | 2025-05-27 00:19:10 - __main__ - INFO - [user_email: pengdachen1995@gmail.com] [conversation_id: 9ea1bef1-3121-484b-a239-5f413139d88c] 所有卡片搜索完成,总耗时: 8.42秒,找到总共 53 个结果 | |||
|  | 2025-05-27 00:19:10 - __main__ - INFO - 卡片 3 (成分党护肤达人) 搜索完成,总耗时: 8.22秒,找到 10 个结果     | |||
|  | 2025-05-27 00:19:10 - __main__ - INFO - 卡片 3 排序后的matched_ids_with_scores: [{'id': '6760880459083318277', 'score': 0.6418526}, {'id': '7200799333906154538', 'score': 0.6364443}, {'id': '13703370', 'score': 0.6362148}, {'id': '6756056737843987461', 'score': 0.6320581}, {'id': '6931172889514247174', 'score': 0.6319245}, {'id': '6586372536946245637', 'score': 0.6314599}, {'id': '6709610644901430278', 'score': 0.63083375}, {'id': '6526536534412235791', 'score': 0.6307928}, {'id': '7061495040306627631', 'score': 0.63024676}, {'id': '7029324212326630405', 'score': 0.6293421}]   | |||
|  | 2025-05-27 00:19:25 - dialogue.agent - INFO - [conversation_id: 9ea1bef1-3121-484b-a239-5f413139d88c] 开始异步执行extract_slots和update_last_history_form | |||
|  | 2025-05-27 00:19:25 - dialogue.ai_service_call - INFO - [user_email: pengdachen1995@gmail.com] [conversation_id: 9ea1bef1-3121-484b-a239-5f413139d88c] extract_slots language_prompt: [{'role': 'system', 'content': 'Hello, I need you to act as a language detection and translation assistant. Please follow these steps:\n\n1. First, analyze the provided user_message to detect its language.\n\nuser_message: 寻找适合推广卸妆水产品的美妆达人,要求粉丝量≥5000;\n\n2. Return two-character code of the language in lowercase, must not return anything else.\n\n For example:\n - If user_message is in Chinese, return "zh"\n - If user_message is in French, return "fr"\n - If user_message is in English, return "en"\n - If user_message is in Korean, return "ko"\n - If user_message is in Portuguese, return "pt"\n - If user_message is in Spanish, return "es"\n - If user_message is in German, return "de"\n - If user_message is in Italian, return "it"\n - If user_message is in Japanese, return "ja"\n\n Remember, your response should only contain the lowercase two-character code of the language, nothing else.\n'}]    | |||
|  | 2025-05-27 09:22:29 - utils.base_gateway - ERROR - [user_email: token_d98cf010...] HTTP错误: 500 - 401 Client Error: for url: http://129.204.158.54:8070/prod-api/jenniefy/account/info/     | |||
|  | 2025-05-26 21:56:43 - utils.base_gateway - ERROR - [user_email: jennie.christina.ai@gmail.com] [conversation_id: 4c97fc29-5d95-422e-9b9f-e206789119bd] Error param, https://api.insightiq.ai/v1/, social/creators/dictionary/topics/    | |||
|  |  这样的日志格式,filebeat的处理器能拆分各个字段吗?好像info和error的日志日志结构不统一?可以按需匹配处理器吗? | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  |  { | |||
|  |   "@timestamp": [ | |||
|  |     "2025-05-27T03:22:39.814Z" | |||
|  |   ], | |||
|  |   "message": [ | |||
|  |     "2025-05-27 11:15:21 - utils.base_gateway - ERROR - [user_email: token_6fc20e11...] HTTP错误: 500 - 401 Client Error:  for url: http://129.204.158.54:8070/prod-api/jenniefy/account/info/" | |||
|  |   ], | |||
|  |   "message.keyword": [ | |||
|  |     "2025-05-27 11:15:21 - utils.base_gateway - ERROR - [user_email: token_6fc20e11...] HTTP错误: 500 - 401 Client Error:  for url: http://129.204.158.54:8070/prod-api/jenniefy/account/info/" | |||
|  |   ], | |||
|  |   "mylog.level": [ | |||
|  |     "ERROR" | |||
|  |   ], | |||
|  |   "mylog.level.keyword": [ | |||
|  |     "ERROR" | |||
|  |   ], | |||
|  |   "mylog.module": [ | |||
|  |     "utils.base_gateway" | |||
|  |   ], | |||
|  |   "mylog.module.keyword": [ | |||
|  |     "utils.base_gateway" | |||
|  |   ], | |||
|  |   "mylog.raw_tail": [ | |||
|  |     "[user_email: token_6fc20e11...] HTTP错误: 500 - 401 Client Error:  for url: http://129.204.158.54:8070/prod-api/jenniefy/account/info/" | |||
|  |   ], | |||
|  |   "mylog.raw_tail.keyword": [ | |||
|  |     "[user_email: token_6fc20e11...] HTTP错误: 500 - 401 Client Error:  for url: http://129.204.158.54:8070/prod-api/jenniefy/account/info/" | |||
|  |   ], | |||
|  |   "mylog.tail": [ | |||
|  |     "HTTP错误: 500 - 401 Client Error:  for url: http://129.204.158.54:8070/prod-api/jenniefy/account/info/" | |||
|  |   ], | |||
|  |   "mylog.tail.keyword": [ | |||
|  |     "HTTP错误: 500 - 401 Client Error:  for url: http://129.204.158.54:8070/prod-api/jenniefy/account/info/" | |||
|  |   ], | |||
|  |   "mylog.timestamp": [ | |||
|  |     "2025-05-27 11:15:21" | |||
|  |   ], | |||
|  |   "mylog.timestamp.keyword": [ | |||
|  |     "2025-05-27 11:15:21" | |||
|  |   ], | |||
|  |   "mylog.user_email": [ | |||
|  |     "token_6fc20e11..." | |||
|  |   ], | |||
|  |   "mylog.user_email.keyword": [ | |||
|  |     "token_6fc20e11..." | |||
|  |   ], | |||
|  |   "_id": "AZcPw3dDvDmC7zSTrFPW", | |||
|  |   "_index": ".ds-out-148-flymoonlog-app_lessie_ai-influencer_search_app.lessie.ai-2025.05-2025.05.21-000002", | |||
|  |   "_score": null | |||
|  | } | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 查询到的最新日志详情: | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | { | |||
|  | "_id": "AZcQbHdDvDmC71v4SVPH",  | |||
|  | "timestamp": "2",  | |||
|  | "module": "无",  | |||
|  | "level": "ERROR",  | |||
|  | "user_email": "无",  | |||
|  | "conversation_id": "无",  | |||
|  | "tail": "2025-05-27 12:48:54 - utils.base_gateway - ERROR - [user_email: token_6fc20e11...] HTTP错误: 500 - 401 Client Error:  for url: http://129.204.158.54:8070/prod-api/jenniefy/account/info/..."} | |||
|  | 
 | |||
|  | 
 | |||
|  | [DEBUG] 飞书API完整响应:{"StatusCode": 0, "StatusMessage": "success", "code": 0, "data": {}, "msg": "success"} | |||
|  | 告警已发送,发现30条错误日志 | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 1、该脚本执行后发送到飞书机器人显示的时间错误,消息显示:触发时间:2025-05-27 01:10:57,实际时间是2025-05-27 09:10:54 | |||
|  | 2、帮我修改发送到飞书的消息的内容: | |||
|  | 
 | |||
|  | 触发时间:python脚本触发时间 | |||
|  | 错误数量:python脚本触发时查询到符合条件的条目数 | |||
|  | 最近一条日志详情 | |||
|  | 时间戳:kibana界面看到的 mylog.timestamp 字段 | |||
|  | 模块:kibana界面看到的 mylog.timestamp 字段 | |||
|  | 日志等级:kibana界面看到的 mylog.level 字段 | |||
|  | 用户邮箱:kibana界面看到的 mylog.user_email 字段 | |||
|  | 会话ID:kibana界面看到的 mylog.conversation_id  字段 | |||
|  | 日志信息:kibana界面看到的 mylog.tail  字段 | |||
|  | @群成员 | |||
|  | 注意: | |||
|  | 1、有些日志条目的“用户邮箱字段”或者“会话ID字段”,有时可能是空的,或者就没有该字段,当这两个字段没有值时显示“无” | |||
|  | 2、日志信息字段其实就是错误堆栈信息,有时候可能会很长,需要截断,显示上限500字 | |||
|  | 3、脚本日志输出需要显示查询的具体信息。 | |||
|  | 4、@群成员:暂时保持@所有人 | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 2025-05-27 00:19:10 - __main__ - INFO - [user_email: pengdachen1995@gmail.com] [conversation_id: 9ea1bef1-3121-484b-a239-5f413139d88c] 穿插排序后的结果数量: 0 | |||
|  | 2025-05-27 00:19:10 - __main__ - INFO - [user_email: pengdachen1995@gmail.com] [conversation_id: 9ea1bef1-3121-484b-a239-5f413139d88c] 穿插排序后的结果数量: 0 | |||
|  | 2025-05-27 00:19:10 - __main__ - INFO - [user_email: pengdachen1995@gmail.com] [conversation_id: 9ea1bef1-3121-484b-a239-5f413139d88c] 穿插排序后的结果数量: 0 | |||
|  | 2025-05-27 00:19:10 - __main__ - INFO - [user_email: pengdachen1995@gmail.com] [conversation_id: 9ea1bef1-3121-484b-a239-5f413139d88c] 穿插排序后的结果数量: 0 | |||
|  | 2025-05-27 00:19:10 - __main__ - INFO - [user_email: pengdachen1995@gmail.com] [conversation_id: 9ea1bef1-3121-484b-a239-5f413139d88c] 穿插排序后的结果数量: 0 | |||
|  | 2025-05-27 00:19:10 - __main__ - INFO - [user_email: pengdachen1995@gmail.com] [conversation_id: 9ea1bef1-3121-484b-a239-5f413139d88c] 穿插排序后的结果数量: 0 | |||
|  | 2025-05-27 00:19:10 - __main__ - INFO - [user_email: pengdachen1995@gmail.com] [conversation_id: 9ea1bef1-3121-484b-a239-5f413139d88c] 穿插排序后的结果数量: 0 |