Redis中keys()方法作用原理是什么?
大家讲道理
大家讲道理 2017-04-21 11:15:47
0
3
808

鄙人蠢,读不懂redis源码~
有一天用redis-py连上Redis备用服务器,想看一下某类型的key有多少个。

rds = redis.Redis(ip, host)
print len(rds.keys('xxx_*'))

最后有大概400w个,阻塞了很久才算出来结果。
令我疑惑的是,这个客户端进程CPU占用率一直在100%以上(为什么会超过100%我也不知道),反倒内存占用率不高。

理论上keys的运算结果应该是服务端计算出来的,客户端接收数据顶多就是内存消耗多点儿,为什么实际情况中客户端CPU占用率如此之高,客户端自己做了什么奇怪的计算?

大家讲道理
大家讲道理

光阴似箭催人老,日月如移越少年。

répondre à tous(3)
PHPzhong

Les déplacements dans les matchs sont définitivement lents. L'auteur a dit que vous devriez essayer de ne pas utiliser la commande Keys

伊谢尔伦

La raison du processeur élevé est principalement le décodage du format de transmission et sa conversion en un objet python

洪涛

Utilisez-vous top pour regarder ? Plus de 100 % est probablement dû au processeur multicœur

Il est préférable de ne pas utiliser de clé. Vous pouvez utiliser redis-rdb-tools, un petit outil de redis. Comment l'utiliser ? Quelqu'un semble l'avoir mentionné dans cette recherche

Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal