drugs3550 2019-05-24 05:12
浏览 768

在CommitTransaction期间发生WriteConflict

2019-05-13T19:01:30.473+0700 I COMMAND  [conn10179] command admin.$cmd appName: "XXX" command: commitTransaction { commitTransaction: 1, lsid: { id: UUID("4d66cc5b-70ff-4f08-9eae-d281b87b59c4") }, txnNumber: 61576, autocommit: false, $db: "admin" } numYields:0 ok:0 errMsg:"WriteConflict" errName:WriteConflict errCode:112 reslen:153 locks:{ Global: {acquireCount: { r: 1, w: 1 } }, Database: { acquireCount: { w: 2 } }, Collection: { acquireCount: { w: 2 } } } protocol:op_msg 0ms

During load test, I found "WriteConflict" error on commit transaction. Pseudocode is given roughly below:

  • create session
  • start transaction
  • insert
  • POST data via rest API
  • if success, commit transaction, otherwise abort

Language: golang

Mongo driver: go.mongodb.org/mongo-driver v1.0.0

I would like to know that

  1. Why WriteConflict does occur during commit transaction. I do only insert one document(new) per transaction. IMOP document cannot be locked. Why WriteConflict?

  2. How to fix it?

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 安卓adb backup备份应用数据失败
    • ¥15 eclipse运行项目时遇到的问题
    • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
    • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
    • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
    • ¥50 成都蓉城足球俱乐部小程序抢票
    • ¥15 yolov7训练自己的数据集
    • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
    • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
    • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)