42 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
-- 导入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)) |