在另一个协程中运行Tarantool Lua函数。

我使用 NoSQL 数据库 Tarantool 并尝试使用 Lua 存储过程在数据库端进行一些复杂的工作。我认为这是一个好主意,因为我可以减少数据库的调用,降低网络数据传输的开销。

我有一张表:

user_counters:id、counter_a、counter_b、score

例如,我有一些计算得分的函数:

function recalc_score(id)
   local stream = box.space.user_counters:select { id }
   local rating = 0
   -- some_rating_calculation using counter_a and counter_b here
   box.space.user_counters:update(id, { { '=', 4, rating } })
end

我还有另一个用于更新 counter_a 和 counter_b 字段的函数:

function update_user_counters(id, counter_a_diff, counter_b_diff)
    local rating_default = 0
    local user_counters_tuple = box.space.user_counters:upsert(
        { id, counter_a_diff, counter_b_diff, rating_default },
        { { '+', 2, counter_a_diff }, { '+', 3, counter_b_diff } }
    )
    -- start another coroutine recalc_score(id) and forget about it
    return user_counters_tuple
 end

我如何调用 recalc_score(id) 函数并返回 user_counters_tuple 而不等待上一个函数执行完毕?

点赞
用户1033289
用户1033289

只需使用 fiber.create(fun, ...) 函数:

local fiber = require('fiber')

-- 启动另一个协程 recalc_score(id) 并忘记它
fiber.create(recalc_score, id)
2016-01-02 17:12:03