你好,我是温铭。
今天的内容,我同样会以视频的形式来讲解。不过,在你进行视频学习之前,我想先问你这么几个问题:
- lua-resty-lrucache 内部最重要的数据结构是什么?
- lua-resty-lrucache 有两种 FFI 的实现,我们今天讲的这一种更适合什么场景?
这几个问题,也是今天视频课要解决的核心内容,希望你可以先自己思考一下,并带着问题来学习今天的视频内容。
同时,我会给出相应的文字介绍,方便你在听完视频内容后,及时总结与复习。下面是今天这节课的文字介绍部分。
今日核心
lua-resty-lrucache 是一个使用 LuaJIT FFI 实现的 LRU 缓存库,可以在 worker 内缓存各种类型的数据。功能与之类似的是 shared dict,但 shared dict 只能存储字符串类型的数据。在大多数实际情况下,这两种缓存是配合在一起使用的——lrucache 作为一级缓存,shared dict 作为二级缓存。
lrucache 的实现,并没有涉及到 OpenResty 的 Lua API。所以,即使你以前没有用过OpenResty,也可以通过这个项目来学习如何使用 LuaJIT 的 FFI。
lrucache 仓库中包含了两种实现方案,一种是使用 Lua table 来实现缓存,另外一种则是使用 hash 表来实现。前者更适合命中率高的情况,后者适合命中率低的情况。两个方案没有哪个更好,要看你的线上环境更适合哪一个。
通过今天这个项目,你可以弄清楚要如何使用 FFI,并了解一个完整的 lua-resty 库应该包括哪些必要的内容。当然,我顺道也会介绍下 travis 的使用。
最后,还是想强调一点,在你面对一个陌生的开源项目时,文档和测试案例永远是最好的上手方式。而你后期如果要阅读源码,也不要先去抠细节,而是应该先去看主要的数据结构,围绕重点逐层深入。
课件参考
今天的课件已经上传到了我的GitHub上,你可以自己下载学习。
链接如下:https://github.com/iresty/geektime-slides
如果有不清楚的地方,你可以在留言区提问,另也可以在留言区分享你的学习心得。期待与你的对话,也欢迎你把这篇文章分享给你的同事、朋友,我们一起交流、一起进步。
精选留言
2019-06-30 06:49:27
2019-06-24 10:41:37
2019-06-26 14:59:56
2019-07-15 21:22:05
2019-07-10 15:48:01
openresty环境:1个master进程、X个worker进程
在init_worker阶段中注册了缓存信息如:cache.set("key1","val1")
在content阶段修改了缓存信息:cache.set("key1","val2")
此操作是否仅为更新了当前worker的缓存信息,而无法跨worker更新。
如需完成跨worker更新应如何处理呢?
2019-07-04 11:52:37
我用c语言实现了跨平台的so类库。 用ffi.load 来加载。
那么,在openrestry 中会有几个 so 函数的实例呢?
按照操作系统的知识,共享库在系统中只有一个实例。
如果只有一个,那么我们在不同的worker 中调用so 里的函数中,对于一个so 内的资源是否存在冲突呢?
2019-06-24 18:20:12
2023-08-18 07:22:55
网上也没有找到解决方案,大多数是要修改JAVA的加密方式,请问有没有更好的办法
2020-10-05 22:53:52
2020-06-23 20:12:23
2019-09-23 13:14:06
2019-07-02 22:21:40
2019-06-26 08:03:36