ToB企服应用市场:ToB评测及商务社交产业平台

标题: 【Redis】Redis变乱和Lua脚本的区别 [打印本页]

作者: 美丽的神话    时间: 2025-1-17 08:17
标题: 【Redis】Redis变乱和Lua脚本的区别
Redis变乱

概念

变乱:Redis变乱是一组命令的聚集,这些命令会被序列化地执行,中间不会被其他命令插入。
MULTI/EXEC:Redis变乱通过MULTI命令开始,通过EXEC命令执行所有已入队的命令。
特点

  1. import redis.clients.jedis.Jedis;
  2. public class RedisTransactionExample {
  3.     public static void main(String[] args) {
  4.         Jedis jedis = new Jedis("localhost");
  5.         try {
  6.             jedis.watch("key1", "key2");
  7.             Transaction tx = jedis.multi();
  8.             tx.set("key1", "value1");
  9.             tx.set("key2", "value2");
  10.             tx.exec();
  11.         } catch (Exception e) {
  12.             System.out.println("Transaction failed: " + e.getMessage());
  13.         } finally {
  14.             jedis.unwatch();
  15.             jedis.close();
  16.         }
  17.     }
  18. }
复制代码
Lua脚本

概念

Lua脚本:Redis支持在服务器端执行Lua脚本,脚本中的所有命令都会被原子地执行。
特点

  1. import redis.clients.jedis.Jedis;
  2. public class RedisLuaScriptExample {
  3.     public static void main(String[] args) {
  4.         Jedis jedis = new Jedis("localhost");
  5.         String script = "return redis.call('set', KEYS[1], ARGV[1])";
  6.         String key = "key1";
  7.         String value = "value1";
  8.         Object result = jedis.eval(script, 1, key, value);
  9.         System.out.println("Script result: " + result);
  10.         jedis.close();
  11.     }
  12. }
复制代码

总结

特性Redis变乱Lua脚本原子性保证变乱中的所有命令要么全部执行,要么全部不执行保证脚本中的所有命令原子执行命令排队命令在MULTI和EXEC之间排队,不会立即执行脚本中的所有命令立即执行条件判断不支持条件判断支持复杂的逻辑和条件判断网络开销多个命令必要多次网络往返多个命令打包成一个脚本执行,减少网络往返错误处理变乱中的错误不会停止其他命令的执行脚本中的错误会立即停止脚本执行适用场景简单的批量操作复杂的、必要逻辑处理的操作
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4