初始化提交
This commit is contained in:
42
doc/nginx/lua/stock.lua
Normal file
42
doc/nginx/lua/stock.lua
Normal file
@@ -0,0 +1,42 @@
|
||||
-- 导入redisOps函数库
|
||||
local redisOps = require('redisOps')
|
||||
local read_redis = redisOps.read_redis
|
||||
-- 导入cjson库
|
||||
local cjson = require('cjson')
|
||||
-- 导入共享词典,本地缓存
|
||||
-- 本地缓存的主要目的为库存检查,当商品的库存<=0时,提前终止秒杀
|
||||
-- 这里从业务上来说,同样需要解决退单等引发的库存增加允许重新秒杀的情况,
|
||||
-- 解决思路:同样可以订阅对应的Redis的channel,本次不做具体实现,Lua订阅Redis的Channel的参考代码写在RedisExtOps.lua中
|
||||
local item_cache = ngx.shared.stock_cache
|
||||
|
||||
-- 封装查询函数
|
||||
function read_data(key, expire)
|
||||
-- 查询本地缓存
|
||||
local val = item_cache:get(key)
|
||||
if not val then
|
||||
ngx.log(ngx.ERR, "本地缓存查询失败,尝试查询Redis, key: ", key)
|
||||
-- 查询redis
|
||||
val = read_redis("127.0.0.1", 6379, key)
|
||||
-- 判断查询结果
|
||||
if not val then
|
||||
ngx.log(ngx.ERR, "redis查询失败,key: ", key)
|
||||
-- redis查询失败,给一个缺省值
|
||||
val = 0
|
||||
end
|
||||
end
|
||||
-- 查询成功,把数据写入本地缓存,expire秒后过期
|
||||
if tonumber(val) <= 0 then
|
||||
item_cache:set(key, val, expire)
|
||||
end
|
||||
-- 返回数据
|
||||
return val
|
||||
end
|
||||
|
||||
-- 获取请求参数中的productId,也可以使用ngx.req.get_uri_args["productId"],req.get_uri_args在productId有多个时,会返回一个table
|
||||
local product_id = ngx.var.arg_productId
|
||||
|
||||
-- 查询库存信息
|
||||
local stock = read_data("miaosha:stock:cache:"..product_id, 3600)
|
||||
|
||||
-- 返回结果
|
||||
ngx.say(cjson.encode(stock))
|
||||
Reference in New Issue
Block a user