Lua+OpenResty+nginx+redis+canal实现缓存策略,Android应用性能优化

文章详细描述了如何使用Lua脚本在Nginx中通过MySQL查询数据并将结果存储到Redis中,同时介绍了如何配置缓存策略,包括直接从Redis获取数据和多级缓存(本地缓存、Redis和MySQL)的应用。
摘要由CSDN通过智能技术生成

请求地址: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”);

local db = mysql:new();

db:set_timeout(2000)

local props = {

host = “192.168.211.132”,

port = 3306,

database = “xxx_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);

local responsejson = cjson.encode(res);

red:set(“content_”…id,responsejson);

ngx.say(responsejson);

db:close()

else

cache_ngx:set(‘content_cache_’…id, rescontent, 10*60);

ngx.say(rescontent)

end

red:close()

else

ngx.say(contentCache)

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

面试复习路线,梳理知识,提升储备

自己的知识准备得怎么样,这直接决定了你能否顺利通过一面和二面,所以在面试前来一个知识梳理,看需不需要提升自己的知识储备是很有必要的。

关于知识梳理,这里再分享一下我面试这段时间的复习路线:(以下体系的复习资料是我从各路大佬收集整理好的)

  • 架构师筑基必备技能
  • Android高级UI与FrameWork源码
  • 360°全方面性能调优
  • 解读开源框架设计思想
  • NDK模块开发
  • 微信小程序
  • Hybrid 开发与Flutter

知识梳理完之后,就需要进行查漏补缺,所以针对这些知识点,我手头上也准备了不少的电子书和笔记,这些笔记将各个知识点进行了完美的总结:

Android开发七大模块核心知识笔记

《960全网最全Android开发笔记》

《379页Android开发面试宝典》

历时半年,我们整理了这份市面上最全面的安卓面试题解析大全
包含了腾讯、百度、小米、阿里、乐视、美团、58、猎豹、360、新浪、搜狐等一线互联网公司面试被问到的题目。熟悉本文中列出的知识点会大大增加通过前两轮技术面试的几率。

如何使用它?

1.可以通过目录索引直接翻看需要的知识点,查漏补缺。
2.五角星数表示面试问到的频率,代表重要推荐指数

《507页Android开发相关源码解析》

只要是程序员,不管是Java还是Android,如果不去阅读源码,只看API文档,那就只是停留于皮毛,这对我们知识体系的建立和完备以及实战技术的提升都是不利的。

真正最能锻炼能力的便是直接去阅读源码,不仅限于阅读各大系统源码,还包括各种优秀的开源库。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

1.可以通过目录索引直接翻看需要的知识点,查漏补缺。
2.五角星数表示面试问到的频率,代表重要推荐指数

[外链图片转存中…(img-vKDEnk8f-1712785212142)]

《507页Android开发相关源码解析》

只要是程序员,不管是Java还是Android,如果不去阅读源码,只看API文档,那就只是停留于皮毛,这对我们知识体系的建立和完备以及实战技术的提升都是不利的。

真正最能锻炼能力的便是直接去阅读源码,不仅限于阅读各大系统源码,还包括各种优秀的开源库。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 18
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值