//导入redis模块
var redis = require('redis');
//新建连接 redis.createClient(端口,ip地址0); 端口参数可以是数值也可以是字符串
var client = redis.createClient(6379, 'ip地址');
//如果有密码,请认证
client.auth("密码");
client.select(1,function(error,data){
if(error){
console.log(error);
}
console.log('已切换数据库');
})
//事务说明
// 1.一个客户端开启事务,另一个客户端还是可操作该库
// 2.multi中的命令在执行exec前是不会执行的,只会对所有命令进行排队,执行exec后才会执行。如果其中一条命令出错,其他命令也会执行。
// 3.redis事务 “要不都执行,要不都不执行是主观的”,不是使用是否出现错误去决定是否全部执行。
// 4.执行exec后返回的是一个数组,有序的记录每一条命令执行的结果。
// 5.redis没有回滚的原因是他们认为redis以及过于简化,不需要回滚。有错误的话在开发阶段就能发现了。
// 6.redis事务的一大特色,可以监控指定的值,如果事务开始执行前被监控的值有发生改变,则整个事务中的命令都不会执行
//watch 是用来监控一个或多个键的命令,并且只能生效一次
//unwatch 用来解除监控。当客户端断开连接或者执行exec后,都会自动执行unwatch
client.watch('test001')
client.multi([
['set','test001','test002',''],
['set','test001','test002'],
['get','test001'],
]).exec(function(error,result){
if(error){
console.log(error);
client.discard();
}
console.log(result);
})
// redis脚本
// 连接:https://redisbook.readthedocs.io/en/latest/feature/scripting.html