From a9e958ce3675c4950ceddd3fd6f939cdf0d2bc5a Mon Sep 17 00:00:00 2001 From: guyue <1721849008@qq.com> Date: 星期五, 25 七月 2025 19:00:20 +0800 Subject: [PATCH] 任务不存在时,更新关键词状态,更新创建订单id逻辑 --- src/main/java/com/linghu/controller/CollectController.java | 68 +++++++++++++++------------------- 1 files changed, 30 insertions(+), 38 deletions(-) diff --git a/src/main/java/com/linghu/controller/CollectController.java b/src/main/java/com/linghu/controller/CollectController.java index 61f9f54..0da27b4 100644 --- a/src/main/java/com/linghu/controller/CollectController.java +++ b/src/main/java/com/linghu/controller/CollectController.java @@ -220,7 +220,7 @@ return Mono.just(ResponseResult.success("任务已被取消")); } // 如果任务状态是"submitted"或"running",继续轮询 - if (!"completed".equalsIgnoreCase(statusResponse.getStatus()) && !"failed".equalsIgnoreCase(statusResponse.getStatus()) && !"cancelled".equalsIgnoreCase(statusResponse.getStatus()) ) { + if (!"completed".equalsIgnoreCase(statusResponse.getStatus()) && !"failed".equalsIgnoreCase(statusResponse.getStatus()) && !"cancelled".equalsIgnoreCase(statusResponse.getStatus()) && !("ERROR".equalsIgnoreCase(statusResponse.getStatus()) && statusResponse.getMessage().contains("Task not found")) ) { return Mono.delay(Duration.ofSeconds(5)) // 延迟 5 秒后再次查询 .flatMap(aLong -> waitForTaskCompletion(taskId, batchQueue, searchTaskRequest, keywordId)); // 递归调用继续等待 } else { @@ -589,7 +589,8 @@ */ private Platform getOrCreatePlatform(String domain,String platformName) { // 1. 先尝试查询已存在的平台 - Platform platform = platformService.getPlatformByDomain(domain,platformName); + + Platform platform = platformService.getPlatformByDomain(domain); if (platform != null) { return platform; } @@ -624,7 +625,7 @@ } catch (DuplicateKeyException e) { // 3. 若捕获到重复键异常,说明并发创建了,重新查询即可(此时数据库中已存在该平台) log.warn("平台domain={}已存在,无需重复创建", domain, e); - return platformService.getPlatformByDomain(domain,platformName); // 重新查询,一定能获取到 + return platformService.getPlatformByDomain(domain); // 重新查询,一定能获取到 } catch (Exception e) { // 处理其他异常(如数据库连接失败等) log.error("创建平台失败,domain={}", domain, e); @@ -650,14 +651,14 @@ System.out.println("未找到关联的关键词,task_id: " + result.getTask_id()); //报错 throw new Exception("未找到关联的关键词,task_id: " + result.getTask_id()); -// return; + } LambdaQueryWrapper<KeywordTask> keywordTaskWrapper2 = new LambdaQueryWrapper<>(); keywordTaskWrapper2.eq(KeywordTask::getKeyword_id, keyword.getKeyword_id()); List<KeywordTask> keywordTasks = keywordTaskService.list(keywordTaskWrapper2); - //如果全部为completed 关键词也为completed ,如果关联关系没有任务id,或者状态为running ,关键词为submitted, - if (keywordTasks.stream().allMatch(task -> "completed".equals(task.getStatus()) || "false".equals(task.getStatus()) || "cancelled".equals(task.getStatus()) ||"canceled".equals(task.getStatus())) ) { + //如果全部为completed 或者错误、取消、任务不存在 关键词也为completed ,如果关联关系没有任务id,或者状态为running ,关键词为submitted, + if (keywordTasks.stream().allMatch(task -> "completed".equals(task.getStatus()) || "false".equals(task.getStatus()) || "cancelled".equals(task.getStatus()) ||"canceled".equals(task.getStatus()) || "nonentity".equals(task.getStatus())) ) { keyword.setStatus("completed"); keywordService.updateById(keyword); @@ -724,11 +725,27 @@ List<Reference> allReferences = new ArrayList<>(); List<Reference> resultList = new ArrayList<>(); - // 4. 新增:统计所有提问词的结果状态 - boolean allEmptyReferences = true; // 所有提问词引用数据为空 - boolean allSystemBusy = true; // 所有提问词系统繁忙 // 遍历结果 for (UserResult userResult : result.getResults()) { + //更新账号状态 + if ( "failed".equals(userResult.getStatus())){ + if (userResult.getError().contains("登录失败")){ + LambdaUpdateWrapper<User> userWrapper = new LambdaUpdateWrapper<>(); + userWrapper.eq(User::getUser_email, userResult.getUser_email()); + userWrapper.set(User::getStatus, "无法登录"); + userService.update(userWrapper); + //更新所有提问词的状态 + questionService.update(new LambdaUpdateWrapper<Question>().eq(Question::getKeyword_id, keyword.getKeyword_id()) + .set(Question::getStatus, "failed") + .set(Question::getError, "账户登录失败")); + + }else if (userResult.getError().contains("信息错误")){ + LambdaUpdateWrapper<User> userWrapper = new LambdaUpdateWrapper<>(); + userWrapper.eq(User::getUser_email, userResult.getUser_email()); + userWrapper.set(User::getStatus, "信息错误"); + userService.update(userWrapper); + } + } for (QuestionResult questionResult : userResult.getQuestions_results()) { try { Question question = questionMap.get(questionResult.getQuestion()); @@ -765,15 +782,13 @@ String finalStatus = determineFinalStatus(allResults); if ("success".equals(finalStatus)){ question.setStatus("success"); + question.setError(""); }else if ("no_results".equals(finalStatus)){ - question.setStatus("failed"); + question.setStatus("success"); question.setError("采集结果无引用数据"); }else if ("busyness".equals(finalStatus)){ question.setStatus("failed"); question.setError("DeepSeek繁忙,请稍后尝试"); - }else if ("failed".equals(finalStatus)){ - question.setStatus("failed"); - question.setError("所有账号登录失败"); } // 更新问题对象 @@ -876,25 +891,7 @@ System.out.println("处理问题结果失败: " + e.getMessage()); } } - //更新账号状态 - if ( "failed".equals(userResult.getStatus())){ - if (userResult.getError().contains("登录失败")){ - LambdaUpdateWrapper<User> userWrapper = new LambdaUpdateWrapper<>(); - userWrapper.eq(User::getUser_email, userResult.getUser_email()); - userWrapper.set(User::getStatus, "无法登录"); - userService.update(userWrapper); - //更新所有提问词的状态 - questionService.update(new LambdaUpdateWrapper<Question>().eq(Question::getKeyword_id, keyword.getKeyword_id()) - .set(Question::getStatus, "failed") - .set(Question::getError, "账户登录失败")); - }else if (userResult.getError().contains("信息错误")){ - LambdaUpdateWrapper<User> userWrapper = new LambdaUpdateWrapper<>(); - userWrapper.eq(User::getUser_email, userResult.getUser_email()); - userWrapper.set(User::getStatus, "信息错误"); - userService.update(userWrapper); - } - } } @@ -921,7 +918,6 @@ int totalCount = results.size(); int emptyResponseCount = 0; int systemBusyCount = 0; - int failedCount = 0; for (QuestionResultList result : results) { // 判断回答是否为空 @@ -933,9 +929,7 @@ if ("success".equals(result.getStatus()) && (result.getResponse().isEmpty()|| result.getResponse().contains("WebDriver连接中断") || result.getResponse().contains("响应超时"))) { systemBusyCount++; } - if ("failed".equals(result.getStatus()) && result.getError().contains("登录失败")){ - failedCount++; - } + } // 全返回系统繁忙 @@ -946,9 +940,7 @@ if (emptyResponseCount == totalCount) { return "no_results"; } - if (failedCount == totalCount) { - return "failed"; - } + // 系统繁忙比例超过阈值(可配置,这里设为70%) // double busyRate = (double) systemBusyCount / totalCount; -- Gitblit v1.7.1