阿里云Redis LUA脚本功能上线——轻量嵌入,极速扩展,业务轻松跨平台

简介: 阿里云Redis云数据库,全面支持LUA脚本功能,助力企业轻松迁移自建Redis数据库的业务逻辑,实现业务的跨平台复用,快速驱动业务上云。

    阿里云Redis云数据库,全面支持LUA脚本功能,助力企业轻松迁移自建Redis数据库的业务逻辑,实现业务的跨平台复用,快速驱动业务上云。LUA语言作为目前最流行的轻量级嵌入式脚本语言,凭借其语法简单、高效稳定、支持复杂数据结构以及自动内存管理等特点,已经在众多著名的游戏程序中大量被使用,如:愤怒的小鸟、星际争霸、魔兽世界等。



Redis支持LUA脚本的主要优势 

    LUA脚本的融合将使Redis数据库产生更多的使用场景,迸发更多新的优势:
  • 高效性:减少网络开销及时延,多次redis服务器网络请求的操作,使用LUA脚本可以用一个请求完成
  • 数据可靠性:Redis会将整个脚本作为一个整体执行,中间不会被其他命令插入。
  • 复用性:LUA脚本执行后会永久存储在Redis服务器端,其他客户端可以直接复用
  • 便捷性:实现程序热更新
  • 可嵌入性:可嵌入JAVA,C#等多种编程语言,支持不同操作系统跨平台交互
  • 简单强大:小巧轻便,资源占用率低,支持过程化和对象化的编程语言
  • 免费开源:遵循MIT Licence协议,可免费商用化

Redis LUA脚本应用场景

游戏开发:Lua大量用于游戏开发中,实现热升级,提升应用扩展性
  • 活跃用户判断:判断一个游戏用户是否属于活跃用户,如果符合标准,则活跃用户人数+1
    Lua脚本(sha: 089ccf077629d371793d5e928a3f06e9e483eb08)
if redis.call("EXISTS",KEYS[1]) == 1 then
  return redis.call("INCRBY",KEYS[1],ARGV[1])
else
  return nil
end
        游戏用户示例信息如下:
    > evalsha f74dd5c086898b8a3d69655334b94fa7e006a9b1 1 activeusers 1  (nil)
    > set activeusers 0 OK
    > evalsha f74dd5c086898b8a3d69655334b94fa7e006a9b1 1 activeusers 1  (integer) 1
    > evalsha f74dd5c086898b8a3d69655334b94fa7e006a9b1 1 activeusers 2  (integer) 3
    • 简单DDOS防护:限制n秒内同ip的访问次数
          Lua脚本(sha: 089ccf077629d371793d5e928a3f06e9e483eb08)
    local cnt = redis.call('INCR', KEYS[1])
    if cnt > tonumber(ARGV[1])
    then
      return 1
    end
    if cnt == 1
    then
      redis.call('PEXPIRE', KEYS[1], ARGV[2])
    end
    return 0
         示例信息如下: 10秒内192.168.1.1访问是否超过了5次
    > evalsha 089ccf077629d371793d5e928a3f06e9e483eb08 1 ratelimit:192.168.1.1 5 10000  (integer) 0
    > evalsha 089ccf077629d371793d5e928a3f06e9e483eb08 1 ratelimit:192.168.1.1 5 10000  (integer) 0
    > evalsha 089ccf077629d371793d5e928a3f06e9e483eb08 1 ratelimit:192.168.1.1 5 10000  (integer) 0
    > evalsha 089ccf077629d371793d5e928a3f06e9e483eb08 1 ratelimit:192.168.1.1 5 10000  (integer) 0
    > evalsha 089ccf077629d371793d5e928a3f06e9e483eb08 1 ratelimit:192.168.1.1 5 10000  (integer) 0
    > evalsha 089ccf077629d371793d5e928a3f06e9e483eb08 1 ratelimit:192.168.1.1 5 10000  (integer) 1
    • 用户游戏社区判断:判断当前用户是否在多个游戏社区中
         Lua脚本(Sha:d7550c872f553141096d5134c027af5eeed283db)
    for i=1,#KEYS do
      if redis.call('sismember', KEYS[i], ARGV[1]) == 1 then
        return 1
      end
    end
    return 0
          示例信息如下:
    > sadd users alice bob  (integer) 2
    > sadd admin jenny  (integer) 1
    > evalsha d7550c872f553141096d5134c027af5eeed283db 2 users admin alice  (integer) 1
    > evalsha d7550c872f553141096d5134c027af5eeed283db 3 users admin guests jenny  (integer) 1
    > evalsha d7550c872f553141096d5134c027af5eeed283db 2 users admin abner  (integer) 0
    • 获取游戏商店中的货品:取出hash表中符合条件的对象
         Lua脚本(SHA:700c06c5ce9835bf9eef2198c8bc4d268b3b5095)
    local fields = redis.call("SMEMBERS", KEYS[2])
    local values = redis.call("HMGET", KEYS[1], unpack(fields))
    local result = {}
    for i,k in ipairs(fields) do result[i] = {k, values[i]} end
    return result
         示例信息如下 :取出所有在produce集合中的对象在hash表groceries中的值
    > hset groceries bread 2  (integer) 1
    > hset groceries apples 5  (integer) 1
    > hset groceries oranges 6  (integer) 1
    > hset groceries broccoli 1  (integer) 1
    > sadd produce apples oranges broccoli  (integer) 3
    > evalsha 700c06c5ce9835bf9eef2198c8bc4d268b3b5095 2 groceries produce
    1) 1) "apples"
       2) "5"
    2) 1) "broccoli"
       2) "1"
    3) 1) "oranges"
       2) "6"

    数据分析:通过Lua脚本实现数据格式化,提供给软件平台通用接口能力
    • 实时平均值统计
          Lua脚本(sha:399fddde578fd9cb924edce746c783e8340d8251)
    local currentval = tonumber(redis.call('get', KEYS[1])) or 0
    local count = redis.call('incr', KEYS[2])
    
    currentval = tostring(currentval * (count - 1)/count + (ARGV[1]/count))
    
    redis.call('set', KEYS[1], currentval)
    return currentval
         示例如下:
    > evalsha 399fddde578fd9cb924edce746c783e8340d8251 2 score:avg score:count 80  "80"
    > evalsha 399fddde578fd9cb924edce746c783e8340d8251 2 score:avg score:count 100  "90"
    > evalsha 399fddde578fd9cb924edce746c783e8340d8251 2 score:avg score:count 75  "85"
    > evalsha 399fddde578fd9cb924edce746c783e8340d8251 2 score:avg score:count 98  "88.25"
    > evalsha 399fddde578fd9cb924edce746c783e8340d8251 2 score:avg score:count 98  "90.2"
    > evalsha 399fddde578fd9cb924edce746c783e8340d8251 2 score:avg score:count 98  "91.5"
    > get score:avg  "91.5"
    > get score:count  "6"


    阿里云Redis LUA脚本安全保障
    • 全局环境保护:阿里云Redis对Lua环境中的全局环境进行保护,禁止用户添加全局变量到Lua环境中
    • 外部代码防护:为了防止用户从外部文件引入不安全的代码,阿里云Redis不提供Loadfile等函数
    • 沙箱机制防护:阿里云Redis Lua不提供访问外部系统或者执行系统调用功能
    • 开通功能限制:为保证用户数据安全,阿里云Redis 仅对申请用户开通Lua脚本功能,用户可以通过工单开通
    相关文章
    |
    6月前
    |
    缓存 NoSQL 算法
    高并发秒杀系统实战(Redis+Lua分布式锁防超卖与库存扣减优化)
    秒杀系统面临瞬时高并发、资源竞争和数据一致性挑战。传统方案如数据库锁或应用层锁存在性能瓶颈或分布式问题,而基于Redis的分布式锁与Lua脚本原子操作成为高效解决方案。通过Redis的`SETNX`实现分布式锁,结合Lua脚本完成库存扣减,确保操作原子性并大幅提升性能(QPS从120提升至8,200)。此外,分段库存策略、多级限流及服务降级机制进一步优化系统稳定性。最佳实践包括分层防控、黄金扣减法则与容灾设计,强调根据业务特性灵活组合技术手段以应对高并发场景。
    1729 7
    |
    10月前
    |
    缓存 NoSQL 搜索推荐
    【📕分布式锁通关指南 03】通过Lua脚本保证redis操作的原子性
    本文介绍了如何通过Lua脚本在Redis中实现分布式锁的原子性操作,避免并发问题。首先讲解了Lua脚本的基本概念及其在Redis中的使用方法,包括通过`eval`指令执行Lua脚本和通过`script load`指令缓存脚本。接着详细展示了如何用Lua脚本实现加锁、解锁及可重入锁的功能,确保同一线程可以多次获取锁而不发生死锁。最后,通过代码示例演示了如何在实际业务中调用这些Lua脚本,确保锁操作的原子性和安全性。
    539 6
    【📕分布式锁通关指南 03】通过Lua脚本保证redis操作的原子性
    |
    9月前
    |
    缓存 NoSQL 测试技术
    Redis压测脚本及持久化机制
    Redis压测脚本及持久化机制简介: Redis性能压测通过`redis-benchmark`工具进行,可评估读写性能。持久化机制包括无持久化、RDB(定期快照)和AOF(操作日志),以及两者的结合。RDB适合快速备份与恢复,但可能丢失数据;AOF更安全,记录每次写操作,适合高数据安全性需求。两者结合能兼顾性能与安全性,建议同时开启并定期备份RDB文件以确保数据安全。
    199 9
    |
    10月前
    |
    NoSQL Redis 数据库
    Redis 功能扩展 Lua 脚本 对Redis扩展 eval redis.call redis.pcall
    通过本文的介绍,我们详细讲解了 Lua 脚本在 Redis 中的作用、`eval` 命令的使用方法以及 `redis.call` 和 `redis.pcall` 的区别和用法。通过合理使用 Lua 脚本,可以实现复杂的业务逻辑,确保操作的原子性,并减少网络开销,从而提高系统的性能和可靠性。
    581 13
    |
    监控 安全
    公司用什么软件监控电脑:Lua 脚本在监控软件扩展功能的应用
    在企业环境中,电脑监控软件对保障信息安全、提升效率至关重要。Lua 脚本在此类软件中用于扩展功能,如收集系统信息、监控软件使用时长及文件操作,向指定服务器发送数据,支持企业管理和运营。
    194 6
    |
    NoSQL API Redis
    redis的其他功能
    瑞士军刀Redis image.png 慢查询 image.png image.png image.png image.
    1134 0
    |
    7月前
    |
    缓存 NoSQL 关系型数据库
    美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
    美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
    美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
    |
    2月前
    |
    缓存 负载均衡 监控
    135_负载均衡:Redis缓存 - 提高缓存命中率的配置与最佳实践
    在现代大型语言模型(LLM)部署架构中,缓存系统扮演着至关重要的角色。随着LLM应用规模的不断扩大和用户需求的持续增长,如何构建高效、可靠的缓存架构成为系统性能优化的核心挑战。Redis作为业界领先的内存数据库,因其高性能、丰富的数据结构和灵活的配置选项,已成为LLM部署中首选的缓存解决方案。
    |
    3月前
    |
    存储 缓存 NoSQL
    Redis专题-实战篇二-商户查询缓存
    本文介绍了缓存的基本概念、应用场景及实现方式,涵盖Redis缓存设计、缓存更新策略、缓存穿透问题及其解决方案。重点讲解了缓存空对象与布隆过滤器的使用,并通过代码示例演示了商铺查询的缓存优化实践。
    215 1
    Redis专题-实战篇二-商户查询缓存
    |
    2月前
    |
    缓存 运维 监控
    Redis 7.0 高性能缓存架构设计与优化
    🌟蒋星熠Jaxonic,技术宇宙中的星际旅人。深耕Redis 7.0高性能缓存架构,探索函数化编程、多层缓存、集群优化与分片消息系统,用代码在二进制星河中谱写极客诗篇。

    相关产品

  • 云数据库 Tair(兼容 Redis)