为了账号安全,请及时绑定邮箱和手机立即绑定

nodejs 环境下 redis如何保证异步set数据,数据不会被覆盖?

nodejs 环境下 redis如何保证异步set数据,数据不会被覆盖?

犯罪嫌疑人X 2019-03-04 22:15:16
使用了express作为服务端框架,然后使用redis来存储一些数据。发现一个问题,一直想不明白。比如 A 在 time 2:31:11:00 时发送ajax请求,该请求修改redis里某个数据,B在time 2:31:11:02时发送ajax请求修改redis里的某个数据。于是服务器开始了如下操作2:31:11:00 POST updateData user = A;2:31:11:01 POST updateData user = B;2:31:11:01 服务器拉取redis里的某个集合 (A的请求);2:31:11:02 服务器拉取redis里的某个集合 (B的请求);2:31:11:02 服务器该集合里关于用户A的数据被修改;2:31:11:03 服务器该集合里关于用户B的数据被修改;2:31:11:03 服务器把修改过A的数据集合重新更新到redis上;2:31:11:04 服务器把修改过B的数据集合重新更新到redis上;这样下来,不是redis上的数据变成只有B修改,A没有修改吗?nodejs是执行代码单线程,是不是说如果A.B一前一后请求,先处理完A的,再处理B的?
查看完整描述

2 回答

?
跃然一笑

TA贡献1826条经验 获得超6个赞

又读了一遍,我的理解有问题(当成mongodb了),你的理解没问题,可以大致当成localStorage来理解(能存的东西花样更多)
设计表就是设计key,表应该设计成这样

{    "room:1:seat1:ready":true,    "room:1:seat1:userid":1,    "room:1:seat2:ready":false,    "room:1:seat2:userid":2,
    ...
}

你看这里存储seat1和seat2的准备状态的key是不同的,所以不会冲突


查看完整回答
反对 回复 2019-03-04
  • 2 回答
  • 0 关注
  • 1893 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信