gpt4 book ai didi

javascript - 如何在 NodeJS 中编写同步块(synchronized block)

转载 作者:行者123 更新时间:2023-11-30 14:56:46 27 4
gpt4 key购买 nike

我的问题是我正在尝试开发一个 NodeJs REST 服务,人们可以使用它在我的网站上注册自己。我的注册流程是这样的:

1.检查是否有用户使用相同的邮箱退出

  1. 如果用户存在,发送一个响应告诉用户已经存在

  2. 如果用户不存在,则使用输入的详细信息创建一个用户对象。

4.现在将其插入数据库。

  1. 发送用户已注册的响应。

现在假设我有两个用户“A”和“B”,他们输入了相同的电子邮件 ID,现在假设用户 A 和 B 都达到了我的代码将检查用户是否退出的点,他们都会得到那个用户不存在,他们的流程将转向创建对象并在数据库上创建对象。现在在这种情况下,如果像 Java 中那样有一个同步块(synchronized block),我们可以防止这两种情况同时创建对象,但是在 NodeJS 中我怎样才能做到这一点呢?以及如何避免这种比赛回合的情况??

NodeJs 是单线程的并且有一个公共(public)堆栈会阻止这种情况发生吗?或者在 NodeJs 中是否还有其他方法可以做到这一点?我是 NodeJs 的新手,如果我提到了错误的地方,我很抱歉。

最佳答案

So strictly speaking, node.js runs on one thread, but your program workflow, wich include I/O (database, filesystem), client and everything, runs on many thread.

来源:Can node.js code result in race conditions?

我能做些什么来预防?

您可以使用事务在数据库级别防止这种情况。或者你也可以在应用层阻止。

数据库层

您可以使用(并且应该使用)事务(假设是 SQL)来确保数据的一致性和完整性。

应用层

此外,使用 hashmap 跟踪内存中输入的电子邮件的注册状态:

var PENDING_EMAILS = {}

app.post("/register", function(req, res) {

var email = req.body.email

if(PENDING_EMAILS[email]) {
return res.send("Email is busy")
}

PENDING_EMAILS[email] = true // check this email as busy
// register operation
// check in DB etc...

delete PENDING_EMAILS[email] // also, release hashmap key when register finishes or when there is an error

})

这种方法可以防止您的问题。

关于javascript - 如何在 NodeJS 中编写同步块(synchronized block),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47130960/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com