草庐IT

multi-modules

全部标签

redis - Redis Multi/Exec 的 IO 成本

我想向Redis发送一个multi/exec命令,如下所示:redis127.0.0.1:6379>MULTIOKredis127.0.0.1:6379>LPUSH"JIMMY""ABC"QUEUEDredis127.0.0.1:6379>LRANGE"JIMMY"0-1QUEUEDredis127.0.0.1:6379>EXEC不过,我想了解一下网络I/O成本。似乎会有4次来回往返,但我认为Redis会保持连接打开?在一个block中发送所有这些命令不是更快吗?甚至可以这样做吗? 最佳答案 是的,这是可能的,这叫做pipelini

transactions - 在 Redis 中,当存在没有关联的 EXEC 或 DISCARD 的 MULTI 时会发生什么?

我有一系列在Redis集之间移动元素的脚本。有时这些操作需要是原子的。有时一个脚本会失败,但其他脚本会继续工作。我很好奇如果在一个脚本中我运行MULTI并启动但随后脚本以某种方式失败并且我从不调用EXEC或DISCARD会发生什么-我知道我的数据完整性很好因为事务永远不会发生,但是由于命令在某处排队并且从未执行我担心如果这种情况发生得太频繁(不应该,但谁知道呢?)我需要清理队列吗? 最佳答案 取决于“脚本失败”的确切含义如果与redis服务器的连接丢失,则查询缓冲区将被释放。如果与redis服务器的连接仍然活跃,而你的代码的其他部分

transactions - 在 Redis 中,当存在没有关联的 EXEC 或 DISCARD 的 MULTI 时会发生什么?

我有一系列在Redis集之间移动元素的脚本。有时这些操作需要是原子的。有时一个脚本会失败,但其他脚本会继续工作。我很好奇如果在一个脚本中我运行MULTI并启动但随后脚本以某种方式失败并且我从不调用EXEC或DISCARD会发生什么-我知道我的数据完整性很好因为事务永远不会发生,但是由于命令在某处排队并且从未执行我担心如果这种情况发生得太频繁(不应该,但谁知道呢?)我需要清理队列吗? 最佳答案 取决于“脚本失败”的确切含义如果与redis服务器的连接丢失,则查询缓冲区将被释放。如果与redis服务器的连接仍然活跃,而你的代码的其他部分

Magento Redis 配置问题 : Cannot find named PHP session module (redis)

我一直在尝试将Redis作为我们性能问题的潜在解决方案,但我在MagnetoEnterprise1.13.0.2中配置Redis时遇到问题。我收到以下错误Warning:session_module_name():CannotfindnamedPHPsessionmodule(redis)对我来说,这意味着它不知道session处理程序reddis。由于EE1.13Redis应该开箱即用,奇怪的是full_page_cache可以使用它,但标准的cache和session_save没有。我的local.xml配置:Mage_Cache_Backend_Redis127.0.0.1637

Magento Redis 配置问题 : Cannot find named PHP session module (redis)

我一直在尝试将Redis作为我们性能问题的潜在解决方案,但我在MagnetoEnterprise1.13.0.2中配置Redis时遇到问题。我收到以下错误Warning:session_module_name():CannotfindnamedPHPsessionmodule(redis)对我来说,这意味着它不知道session处理程序reddis。由于EE1.13Redis应该开箱即用,奇怪的是full_page_cache可以使用它,但标准的cache和session_save没有。我的local.xml配置:Mage_Cache_Backend_Redis127.0.0.1637

node.js - 带有 Bluebird promise 的 Redis multi

您是否知道将redis客户端的多事务命令与bluebirdpromises一起使用的方法?因为,下面的代码永远不会结束。var$redis=require('redis'),$p=require('bluebird'),$r=$p.promisifyAll($redis.multi());$r.setAsync('key','test').then(function(reply,data){//...});$r.exec(function(){$r.quit();process.exit();}); 最佳答案 命令不挂起唯一需要做的

node.js - 带有 Bluebird promise 的 Redis multi

您是否知道将redis客户端的多事务命令与bluebirdpromises一起使用的方法?因为,下面的代码永远不会结束。var$redis=require('redis'),$p=require('bluebird'),$r=$p.promisifyAll($redis.multi());$r.setAsync('key','test').then(function(reply,data){//...});$r.exec(function(){$r.quit();process.exit();}); 最佳答案 命令不挂起唯一需要做的

redis.clients.jedis.exceptions.JedisDataException : Please close pipeline or multi block before calling this method

我想要页面zrange,出现错误:请在调用此方法之前关闭管道或多block。,如何解决这个问题(我的集群不支持多命令https://github.com/CodisLabs/codis/blob/master/doc/unsupported_cmds.md)?runWithPipeline(newJedisPipelinedCallback(){@Overridepublicvoidexecute(Pipelinepipeline){intoffset=0;booleanfinished=false;do{//needtopaginatethekeysSetrawKeys=pipeli

redis.clients.jedis.exceptions.JedisDataException : Please close pipeline or multi block before calling this method

我想要页面zrange,出现错误:请在调用此方法之前关闭管道或多block。,如何解决这个问题(我的集群不支持多命令https://github.com/CodisLabs/codis/blob/master/doc/unsupported_cmds.md)?runWithPipeline(newJedisPipelinedCallback(){@Overridepublicvoidexecute(Pipelinepipeline){intoffset=0;booleanfinished=false;do{//needtopaginatethekeysSetrawKeys=pipeli

python - 模块未找到错误 : No module named 'redis'

我尝试通过pip安装redis-py库。安装成功,但是在python3shell中导入redis时出现如下错误:Traceback(mostrecentcalllast):File"",line1,inModuleNotFoundError:Nomodulenamed'redis'在python2中,它被正确导入。我已经在我的机器(ubuntu17.10)上尝试了所有三个pip、pip2、pip3。我也安装了python3.6。我也试过easy_install 最佳答案 您正在Python2.7中安装它(您可能已经知道这一pip)。