读多写多的服务中,实时交互类服务非常多,对数据的实时性要求也很高,用集中型缓存很难满足服务所需。为此,行业里多数会通过服务内存数据来提供实时交互服务,但这么做维护起来十分麻烦,重启后需要恢复数据。为了实现业务逻辑无重启的更新,行业里通常会使用内嵌脚本的热更新方案。 常见的通用脚本引擎是 lua,这是一个十分流行且方便的脚本引擎,在行业中,很多知名游戏及服务都使用 lua 来实现高性能服务的定制化业务功能,比如 Nginx、Redis 等。 把 lua 和我们的定制化缓存服务结合起来,即可制作出很多强大的功能来应对不同的场景。由于 lua 十分节省内存,我们在进程中开启成千上万的 lua 小线程,甚至一个用户一个 LState 线程对客户端提供状态机一样的服务。 用上面的方法,再结合 lua 和静态语言交换数据相互调用,并配合上我们的任务管理以及各种数据驱动,就能完成一个几乎万能的缓存服务
相关推荐
Java水解4 分钟前
MySQL 正则表达式:REGEXP 和 RLIKE 操作符详解金銀銅鐵5 分钟前
[Java] 用 Swing 生成一个最大公约数计算器(展示计算过程)知其然亦知其所以然5 分钟前
面试官笑了:我用这套方案搞定了“2000w vs 20w”的Redis难题!计算机学姐12 分钟前
基于SpringBoot的新闻管理系统【协同过滤推荐算法+可视化统计】aiopencode22 分钟前
Charles抓包工具详解,开发者必备的网络调试与流量分析神器一 乐27 分钟前
远程在线诊疗|在线诊疗|基于java和小程序的在线诊疗系统小程序设计与实现(源码+数据库+文档)楼田莉子1 小时前
Linux学习:进程的控制大菠萝学姐1 小时前
基于springboot的旅游攻略网站设计与实现回家路上绕了弯1 小时前
服务器大量请求超时?从网络到代码的全链路排查指南SimonKing2 小时前
SpringBoot邮件发送怎么玩?比官方自带的Mail更好用的三方工具