AiApe问答机器人项目后端Bug汇总

后端Bug汇总

邓新宇:

  • 位置: Buaa.AIBot.Repository.Implement.QuestionRepository.UpdateQuestionAsync
  • 级别: 一般情况下, 导致陷入死循环.
  • 描述: 更新问题信息时, 会导致系统陷入死循环.
  • 原因: 这是由于这一部分是拷贝InsertQuestionAsync的实现然后进行修改的, 而后者创建了QuestionData对象后, 需要将其插入数据库, 但前者是不需要, 由于插入的重试机制, 将无限重试, 陷入死循环.
  • 解决情况: 顺利解决. 同时引入了重试的超时机制, 确保类似的问题不会陷入死循环.

  • 位置: Buaa.AIBot.Repository.Implement.QuestionRepository.UpdateQuestionAsync
  • 级别: 特殊情况下, 后端报错.
  • 描述: 当不更新问题的标签时, 将抛出空引用异常.
  • 原因: QuestionRepository通过Buaa.AIBot.Repository.Implement.QuestionRepository.TagMatcher进行标签匹配, TagMatcher在创建时需要通过传入的Tags列表初始化一个HashSet, 而当不更新Tags时, Tags列表为null, 此时将会报错.
  • 解决情况: 顺利解决.

  • 位置: Buaa.AIBot.Repository.Implement.QuestionRepository.UpdateQuestionAsync
  • 级别: 特殊情况下, 发生一致性错误, 导致语义错误.
  • 描述: 当更新问题信息中的最佳回答信息时, 若该回答并不属于该问题时仍能够成功, 此时一个问题的最佳回答并不属于该问题, 语义错误.
  • 原因: 更新时仅检查了回答是否存在, 没有检查该回答所属问题是不是本回答.
  • 解决情况: 顺利解决.

  • 位置: Buaa.AIBot.Repository.Implement.QuestionRepository.UpdateQuestionAsync
  • 级别: 高并发的特殊情况下, 发生数据丢失错误.
  • 描述: 当更新问题信息的标签信息时, 若在更新标签-问题表时, 标签表删除了某个被选中的标签时, 将会导致整个问题被删除.
  • 原因: 上述情况发生时, 应当视为操作失败, 应当撤销之前的更改, 但是由于实现的错误, 导致问题被删除, 这是由于这一部分是拷贝InsertQuestionAsync的实现然后进行修改的, 后者的撤销自然就是删除.
  • 解决情况: 经过分析, 虽然本函数需要更改问题表和标签-问题表两个表, 但是并不像InsertQuestionAsync那样需要先插入问题表以获得问题的qid, 而不得不分两步完成, UpdateQuestionAsync只需要一次数据库数据的提交即可完成. 最后顺利修复.

  • 位置: Buaa.AIBot.Repository.Implement.UserRepository.InsertUserAsync
  • 级别: 代码编写错误的特殊情况下, 错误调用本方法未能报告错误.
  • 描述: 当调用方未初始化UserInfo.Auth时未能报告错误.
  • 原因: 接口设计时, 为每个引用类型设置了null检查, 但是Auth对应的时枚举类, 故遗漏了检查.
  • 解决情况: 添加了对当Auth为AuthLevel.None时的报错, 同时更新了Buaa.AIBot.Repository.IUserRepository.InsertUserAsync中的描述. 顺利解决.

  • 位置: Buaa.AIBot.Repository.Implement.AnswerRepository.InsertAnswerAsync
  • 级别: 特殊情况下, 发生一致性错误, 导致语义错误.
  • 描述: 创建新的回答时, 未检查创建者CreaterId的合法性, 导致CreaterId未对应任何用户时, 仍能够插入成功.
  • 原因: 由于数据模型设计时, 为了实现用户删除后其回答不会被的功能, 未添加对CreaterId的强制约束, 但是语义上, 创建问题时应当保证用户存在.
  • 解决情况: 添加了对当CreaterId为null时的报错, 同时更新了Buaa.AIBot.Repository.IAnswerRepository.InsertAnswerAsync中的描述. 顺利解决.

  • 位置: Buaa.AIBot.Services.QuestionService.ModifyAnswerAsync
  • 级别: 一般情况下, 后端报错.
  • 描述: 调用该方法时, 即使待修改的回答时存在的, 仍旧会报错回答不存在.
  • 原因: 调用Buaa.AIBot.Repository.Implement.AnswerRepository.UpdateAnswerAsync方法时, 少传了AnswerInfo.AnswerId参数.
  • 解决情况: 顺利解决.

  • 位置: Buaa.AIBot.Repository.Implement.QuestionRepository.SelectQuestionsByTagsAsync
  • 级别: 一般情况下, 后端报错.
  • 描述: 无论如何, 总会报错. 导致/api/questions/questionlist总是报错.
  • 原因: EF Core对LINQ中GroupBy和Where支持有限, 导致原代码构建的表达式树无法转换为SQL语句, 从而导致了报错. 改为直接通过RawSql语句进行查询后, 由于开发环境为Windows, 生产/测试环境为Linux, 前者MySQL表名不区分大小写, 而后者区分, 导致过无法正确运行, 目前已解决该问题.
  • 解决情况: 目前可以工作, 但是实现较为低下, 已有一定方案进行优化, 但是尚未进行.

  • 位置:
    • Buaa.AIBot.Repository.Implement.QuestionRepository.SelectAnswersForQuestionByIdAsync
    • Buaa.AIBot.Repository.Implement.QuestionRepository.SelectTagsForQuestionByIdAsync
    • Buaa.AIBot.Repository.Implement.UserRepository.SelectAnswersIdByIdAsync
    • Buaa.AIBot.Repository.Implement.UserRepository.SelectAnswersIdByIdByModifyTimeAsync
    • Buaa.AIBot.Repository.Implement.UserRepository.SelectQuestionsIdByIdAsync
    • Buaa.AIBot.Repository.Implement.UserRepository.SelectQuestionsIdByIdOrderByModifyTimeAsync
  • 级别: 导致功能缺失.
  • 描述: 无论是否创建了问题和回答, 是否为问题添加了相关标签, 都会导致通过用户搜索用户问答的问题和提出的问题, 以及通过问题搜索对应的回答和标签时, 将永远返回空列表. 导致以下接口无法正常工作(永远返回空列表, 或其中某部分为空列表):
    • /api/user/questions
    • /api/user/answers
    • /api/questions/question
  • 原因: 错误地理解了EF Core对于一对多关系的加载策略, 误认为该关系是自动而主动由数据库加载到内存的, 事实上需要特定操作进行加载.
  • 解决情况: 顺利解决.

  • 位置: Buaa.AIBot.Services.NLPService.PostResultAsync
  • 级别:高并发情况下,后端报错.
  • 描述: 当并发量较高时,向NLP微服务发送请求时可能出现意外的连接断开情况,即使本模块与NLP微服务部署在同一服务器。
  • 原因: 未知。
  • 解决情况: 加锁后情况有所改善,但是仍旧无法解决,加锁并Sleep后可以在高并发下正常运行。

李明昕:

  • 位置:
    Buaa.AIBot.Controllers.UserController.GetInternalInfoAsync
  • 级别:比较严重,导致API无法正常响应。
  • 描述:在请求用户内部信息的时候总是返回404NotFound。
  • 原因:在判断是否存在该用户时逻辑写反了。
  • 解决情况:修复了判断逻辑,现在能正常判断用户是否存在并获取其内部信息。

  • 位置:
    Buaa.AiBot.Controllers.UserController.FreshAsync
  • 级别:比较严重,导致无法更新令牌。
  • 描述:在JWT令牌未过期时请求更新令牌失败。
  • 原因:从请求中获取令牌的位置出现了错误,主要涉及到两个方法
    1. UserService.FreshTokenAsync
    2. UserService.GetExpirationFromToken
      这两个方法都错误地从请求参数中获取JWT令牌,使得令牌获取失败,进而导致无法更新令牌。
  • 解决情况:修复了令牌获取方式,现在令牌可以正确地从请求体中得到。

  • 位置:
    Buaa.AIBot.Controllers.QuestionsController.AddAnswerAsync
  • 级别:一般严重,使得后端在一定情况下会产生错误。
  • 描述:如果一个问题不存在的时候回答该问题会产生错误。
  • 原因:调用Buaa.AIbot.Services.IQuestionService.AddAnswerAsync是未接住其抛出的QuestionNotExistException。
  • 解决情况:成功解决,正确接住了并处理了其抛出的异常。

  • 位置:
    Buaa.AIBot.Controllers.UserController.SignUpAsync
  • 级别:不太严重,主要影响前端人员测试
  • 描述:无法创建管理员用户
  • 原因:在控制层实现signup api时,没有考虑到增加管理员用户的需求。
  • 解决情况:在signup逻辑中增加了添加管理员账户逻辑。

  • 位置:
    Buaa.AIBot.Repository.BaiduCrawlerRepository.onCompleted
  • 级别:不太严重,主要影响的时处理效率。
  • 描述:在使用正则表达式处理爬取的数据时效率较低。
  • 原因:错误地在一个循环中进行了多余的正则替换
  • 解决情况:将正则替换移到循环外,提高了处理效率。

  • 位置:
    SentenceEmbedding/EmbeddingModel
  • 级别:比较严重,可能会导致程序奔溃。
  • 描述:高并发条件下添加问题可能会出发错误。
  • 原因:transfomers 的的编码器似乎不能适应高并发环境。
  • 解决情况:通过对模型加锁,已经在很大程度上改善了该问题。

  • 位置:
    SentenceEmbedding/EmbeddingModel
  • 级别:一般严重,对程序主题运行没有造成太大影响。
  • 描述:在删除问题的情况下,可能会出现删除不干净的情况。
  • 原因:由于一个问题可能在多个标签下,没有处理好导致没有删除干净。
  • 解决情况:通过修改逻辑已经修复了这个bug。
posted @ 2021-05-12 02:49  DQSJ  阅读(137)  评论(0编辑  收藏  举报