众所周知redis中使用keys方法来获取全部或者模糊key列表是非常耗费性能的,所以在生产环境中可以使用scan方法来代替,因为keys方法不支持limit,而scan方式支持,示例:
原来的写法
$list=\Yii::$app->redis->keys("driver-*");
替换后的写法
$list=\Yii::$app->redis->scan(0,"MATCH","driver-*","COUNT",10);
scan方法一共五个参数:
第一个参数是游标位置,刚开始的时候填0;
第二个参数填MATCH的话则是开启模糊匹配吧(个人理解)
第三个参数则是匹配的规则,和keys的匹配规则类似
第四个参数填COUNT则是限制返回数量
第五个参数是规定返回的条数
该方法会返回两个元素,用户在下次迭代时需要使用第一个元素作为 SCAN 命令的游标参数, 以此来延续之前的迭代过程(类似于limit吧),第二个元素则是匹配到的key列表,如果第一个元素为0则表示迭代已结束。