a.连接mysql ,按照广告分类ID读取广告列表,转换为json字符串。
b.连接redis,将广告列表json字符串存入redis 。
定义请求:
请求:
/update_content
参数:
id --指定广告分类的id
返回值:
json
请求地址:http://192.168.xxx.xxx/update_content?id=1
创建/root/lua目录,在该目录下创建update_content.lua: 目的就是连接mysql 查询数据 并存储到redis中。
ngx.header.content_type=“application/json;charset=utf8”
local cjson = require(“cjson”)
local mysql = require(“resty.mysql”)
local uri_args = ngx.req.get_uri_args()
local id = uri_args[“id”]
local db = mysql:new()
db:set_timeout(1000)
local props = {
host = “192.168.xxx.xxx”,
port = 3306,
database = “changgou_content”,
user = “root”,
password = “123456”
}
local res = db:connect(props)
local select_sql = “select url,pic from tb_content where status =‘1’ and category_id=”…id…" order by sort_order"
res = db:query(select_sql)
db:close()
local redis = require(“resty.redis”)
local red = redis:new()
red:set_timeout(2000)
local ip =“192.168.xxx.xxx”
local port = 6379
red:connect(ip,port)
red:set(“content_”…id,cjson.encode(res))
red:close()
ngx.say(“{flag:true}”)
修改/usr/local/openresty/nginx/conf/nginx.conf文件: 添加头信息,和 location信息
server {
listen 80;
server_name localhost;
location /update_content {
content_by_lua_file /root/lua/update_content.lua;
}
}
定义lua缓存命名空间,修改nginx.conf,添加如下代码即可:
lua_shared_dict dis_cache 128m;
请求http://192.168.xxx.xxx/update_content?id=1可以实现缓存的添加
(2)实现思路-从redis中获取数据
实现思路:
定义请求,用户根据广告分类的ID 获取广告的列表。通过lua脚本直接从redis中获取数据即可。
定义请求:
请求:/read_content
参数:id
返回值:json
在/root/lua目录下创建read_content.lua:
–设置响应头类型
ngx.header.content_type=“application/json;charset=utf8”
–获取请求中的参数ID
local uri_args = ngx.req.get_uri_args();
local id = uri_args[“id”];
–引入redis库
local redis = require(“resty.redis”);
–创建redis对象
local red = redis:new()
–设置超时时间
red:set_timeout(2000)
–连接
local ok, err = red:connect(“192.168.211.132”, 6379)
–获取key的值
local rescontent=red:get(“content_”…id)
–输出到返回响应中
ngx.say(rescontent)
–关闭连接
red:close()
在/usr/local/openresty/nginx/conf/nginx.conf中配置如下:
location /read_content {
content_by_lua_file /root/lua/read_content.lua;
}
(3)加入openresty本地缓存
如上的方式没有问题,但是如果请求都到redis,redis压力也很大,所以我们一般采用多级缓存的方式来减少下游系统的服务压力。参考基本思路图的实现。
先查询openresty本地缓存 如果 没有
再查询redis中的数据,如果没有
再查询mysql中的数据,但凡有数据 则返回即可。
修改read_content.lua文件,代码如下:
ngx.header.content_type=“application/json;charset=utf8”
local uri_args = ngx.req.get_uri_args();
local id = uri_args[“id”];
–获取本地缓存
local cache_ngx = ngx.shared.dis_cache;
–根据ID 获取本地缓存数据
local contentCache = cache_ngx:get(‘content_cache_’…id);
if contentCache == “” or contentCache == nil then
local redis = require(“resty.redis”);
local red = redis:new()
red:set_timeout(2000)
red:connect(“192.168.211.132”, 6379)
local rescontent=red:get(“content_”…id);
if ngx.null == rescontent then
local cjson = require(“cjson”);
local mysql = require(“resty.mysql”);
写在最后
由于本文罗列的知识点是根据我自身总结出来的,并且由于本人水平有限,无法全部提及,欢迎大神们能补充~
将来我会对上面的知识点一个一个深入学习,也希望有童鞋跟我一起学习,一起进阶。
提升架构认知不是一蹴而就的,它离不开刻意学习和思考。
**这里,笔者分享一份从架构哲学的层面来剖析的视频及资料分享给大家,**梳理了多年的架构经验,筹备近1个月最新录制的,相信这份视频能给你带来不一样的启发、收获。
最近还在整理并复习一些Android基础知识点,有问题希望大家够指出,谢谢。
希望读到这的您能转发分享和关注一下我,以后还会更新技术干货,谢谢您的支持!
转发+点赞+关注,第一时间获取最新知识点
Android架构师之路很漫长,一起共勉吧!
。**
**这里,笔者分享一份从架构哲学的层面来剖析的视频及资料分享给大家,**梳理了多年的架构经验,筹备近1个月最新录制的,相信这份视频能给你带来不一样的启发、收获。
[外链图片转存中…(img-rV0v6J2n-1720097143981)]
[外链图片转存中…(img-vhYqhesI-1720097143982)]
最近还在整理并复习一些Android基础知识点,有问题希望大家够指出,谢谢。
希望读到这的您能转发分享和关注一下我,以后还会更新技术干货,谢谢您的支持!
转发+点赞+关注,第一时间获取最新知识点
Android架构师之路很漫长,一起共勉吧!