突变并发控制:乐观锁与悲观锁在 GraphQL 中的实战
本教程将解决并发修改同一资源时的数据一致性问题,教你如何在 mutation 中实现基于版本号的乐观锁和基于数据库锁的悲观锁。 · 难度:入门 · +10XP
突变并发控制:乐观锁与悲观锁在 GraphQL 中的实战
当多个客户端同时更新同一数据时,简单覆盖会导致数据丢失。本课程将带你实现乐观锁:给每个资源添加 version 字段,在更新时检查版本是否变化。同时,也会演示在需要强一致性时如何使用数据库行锁或分布式锁(Redis Redlock)实现悲观锁。你将学会如何在同一个 mutation 中优雅地处理冲突并返回用户友好的错误信息。
async function updateUser(parent, { id, name, version }, context) {
const user = await db.users.findOne({ _id: id });
if (user.version !== version) {
throw new ConflictError('User was modified by another request');
}
return db.users.findOneAndUpdate(
{ _id: id, version: version },
{ $set: { name }, $inc: { version: 1 } },
{ returnDocument: 'after' }
);
}