mongodb findOneAndUpdate()方法实现字段自增出现数据重复

1. 运行环境

1). 当前使用的 Laravel 版本?

5.6 5.8 lumen6.0 都出现过

2). 当前使用的 php/php-fpm 版本?

PHP 版本:7.3

php-fpm 版本:7.3

3). 当前系统

CentOS7

4). 业务环境

开发环境

5). 相关软件版本

Mongodb4.2

2. 问题描述?

使用mongodb的findOneAndUpdate()方法添加自增字段,有时候会出现数据重复的情况。
具体代码:

class Seq extends Eloquent
{
    protected $connection = 'mongodb';
    protected $table = 'seq';
    protected $dateFormat = 'U';
    protected $guarded = [];

    public static function next( $_id ) {
        $seq = self::raw(function($collection) use ($_id) {
            return $collection->findOneAndUpdate(
                ['_id' => $_id],
                ['$inc' => array('v' => 1)],
                ['new' => true, 'upsert' => true]
            );
        });
        return $seq['v'] ? $seq['v'] : self::next($_id);
    }        
}

3. 您期望得到的结果?

每调用一次值+1,多次调用不会出现重复值

4. 您实际得到的结果?

项目里没有相关的报错信息,大部分情况是正常的,偶尔会出现,多个项目修改同一个值的情况出现的几率稍高一些,同一个项目也会出现,而且重复出现的两条记录间隔比较大(最多间隔了1天)。

目前的配置选项,调用next()方法返回的实际上是当前的记录值,我不确定将选项里的’new’改成’returnNewDocument’是否会生效,因为目前项目较多,不方便全部修改,暂未尝试这个方法。

--Max--
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!