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

使用了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的?

阅读 3.1k
1 个回答

https://youyu4.iteye.com/blog...
又读了一遍,我的理解有问题(当成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是不同的,所以不会冲突

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题