1. Nach der Installation von Redis gibt es unter src und /usr/local/bin mehrere ausführbare Dateien, die als Redis-Shell bezeichnet werden.
1. Redis-Server startet Redis
2. Redis-Cli-Redis-Befehlszeilentool
4. redis-check-aof Tool zur Erkennung und Reparatur persistenter AOF-Dateien
5. redis-check-dump Tool zur Erkennung und Reparatur persistenter RDB-Dateien
6 🎜>
2. Es gibt zwei Möglichkeiten, eine Verbindung zum Redis-Server herzustellen. Erster Weg: interaktiver Modusredis-cli -h {host} -p {port}方式连接,然后所有的操作都是在交互的方式实现,不需要再执行redis-cli了。 $redis-cli -h 127.0.0.1-p 6379 127.0.0.1:6379>set hello world OK 127.0.0.1:6379>get hello "world"Zweiter Weg: Befehlsmodus
redis-cli -h {host} -p {port} {command}直接得到命令的返回结果。 $redis-cli -h 127.0.0.1-p 6379 get hello "world"redis-cli enthält viele Parameter, wie z. B. -h, -p, die Sie verstehen müssen Für alle Parameter verwenden Sie den Befehl redis-cli -help.
Der erste Teil der Befehlsmethode
$redis-cli -r 3 ping PONG PONG PONGDer Ping-Befehl kann verwendet werden, um zu erkennen, ob der Die Redis-Instanz ist aktiv. Wenn sie aktiv ist, wird PONG angezeigt.
2. -i
$redis-cli -r 3 -i 1 ping PONG PONG PONGrrree3, -x stellt das Lesen von Daten aus der Standardeingabe als letzten Parameter des Befehls dar.
$redis-cli -r 10 -i 1 info|grep used_memory_human used_memory_human:2.95G ..................................... used_memory_human:2.95G 每隔1秒输出内存的使用量,一共输出10次。 $redis-cli -h ip -p port info server|grep process_id process_id:999 获取redis的进程号999
4, -c
9. info: Serverinformationen und Statistiken bereitstellen 10. config resetstat: Bestimmte Statistiken im Info-Befehl zurücksetzen 11. config get: Informationen zur Konfigurationsdatei abrufen 12. Konfigurationssatz: Passen Sie die Konfiguration des Redis-Servers dynamisch an, ohne neu zu starten. Die Konfigurationsparameter können mit dem Befehl 13 aufgelistet werden umschreiben: die auf dem Redis-Server angegebene redis.conf-Datei umschreiben 15. Überwachen: Empfangene Anforderungen in Echtzeit sichern 16 >Befehle zum Veröffentlichen und Abonnieren: 1. psubscribe: Abonnieren Sie einen oder mehrere Kanäle, die einem bestimmten Muster entsprechen, z. B. psubscribe news.* tweet.*2 Nachricht an den angegebenen Kanal, z. B. Veröffentlichungsnachricht „Guten Morgen“3. Pubsub-Kanäle: Listen Sie die aktuell aktiven Kanäle auf, z. B. PUBSUB CHANNELS news.i*4. Gibt den angegebenen Kanal zurück. Die Anzahl der Abonnenten, z. B. PUBSUB NUMSUB news.it news.internet news.sport news.music5. Pubsub numpat: Gibt die Summe der Anzahl aller Modi zurück vom Kunden abonniert 6. punsubscribe: Weisen Sie den Kunden an, sich von allen angegebenen Modi abzumelden. 7. Abonnieren: Abonnieren Sie die Informationen eines oder mehrerer bestimmter Kanäle. Beispiel: abonnieren Sie die Nachricht chat_room8. Abmelden: Weisen Sie den Kunden an, sich vom angegebenen Kanal abzumelden. Befehle für KEY-Operationen:
1、exists(key):确认一个key是否存在
2、del(key):删除一个key
3、type(key):返回值的类型
4、keys(pattern):返回满足给定pattern的所有key
5、randomkey:随机返回key空间的一个
6、keyrename(oldname, newname):重命名key
7、dbsize:返回当前数据库中key的数目
8、expire:设定一个key的活动时间(s)
9、ttl:获得一个key的活动时间
10、move(key, dbindex):移动当前数据库中的key到dbindex数据库
11、flushdb:删除当前选择数据库中的所有key
12、flushall:删除所有数据库中的所有key
对String操作的命令:
1、set(key, value):给数据库中名称为key的string赋予值value
2、get(key):返回数据库中名称为key的string的value
3、getset(key, value):给名称为key的string赋予上一次的value
4、mget(key1, key2,…, key N):返回库中多个string的value
5、setnx(key, value):添加string,名称为key,值为value
6、setex(key, time, value):向库中添加string,设定过期时间time
7、mset(key N, value N):批量设置多个string的值
8、msetnx(key N, value N):如果所有名称为key i的string都不存在
9、incr(key):名称为key的string增1操作
10、incrby(key, integer):名称为key的string增加integer
11、decr(key):名称为key的string减1操作
12、decrby(key, integer):名称为key的string减少integer
13、append(key, value):名称为key的string的值附加value
14、substr(key, start, end):返回名称为key的string的value的子串
对List操作的命令:
1、rpush(key, value):在名称为key的list尾添加一个值为value的元素
2、lpush(key, value):在名称为key的list头添加一个值为value的 元素
3、llen(key):返回名称为key的list的长度
4、lrange(key, start, end):返回名称为key的list中start至end之间的元素
5、ltrim(key, start, end):截取名称为key的list
6、lindex(key, index):返回名称为key的list中index位置的元素
7、lset(key, index, value):给名称为key的list中index位置的元素赋值
8、lrem(key, count, value):删除count个key的list中值为value的元素
9、lpop(key):返回并删除名称为key的list中的首元素
10、rpop(key):返回并删除名称为key的list中的尾元素
11、blpop(key1, key2,… key N, timeout):lpop命令的block版本。
12、brpop(key1, key2,… key N, timeout):rpop的block版本。
13、rpoplpush(srckey, dstkey):返回并删除名称为srckey的list的尾元素,并将该元素添加到名称为dstkey的list的头部
对Set操作的命令:
1、sadd(key, member):向名称为key的set中添加元素member
2、srem(key, member) :删除名称为key的set中的元素member
3、spop(key) :随机返回并删除名称为key的set中一个元素
4、smove(srckey, dstkey, member) :移到集合元素
5、scard(key) :返回名称为key的set的基数
6、sismember(key, member) :member是否是名称为key的set的元素
7、sinter(key1, key2,…key N) :求交集
8、sinterstore(dstkey, (keys)) :求交集并将交集保存到dstkey的集合
9、sunion(key1, (keys)) :求并集
10、sunionstore(dstkey, (keys)) :求并集并将并集保存到dstkey的集合
11、sdiff(key1, (keys)) :求差集
12、sdiffstore(dstkey, (keys)) :求差集并将差集保存到dstkey的集合
13、smembers(key) :返回名称为key的set的所有元素
14、srandmember(key) :随机返回名称为key的set的一个元素
对Hash操作的命令
1、hset(key, field, value):向名称为key的hash中添加元素field
2、hget(key, field):返回名称为key的hash中field对应的value
3、hmget(key, (fields)):返回名称为key的hash中field i对应的value
4、hmset(key, (fields)):向名称为key的hash中添加元素field
5、hincrby(key, field, integer):将名称为key的hash中field的value增加integer
6、hexists(key, field):名称为key的hash中是否存在键为field的域
7、hdel(key, field):删除名称为key的hash中键为field的域
8、hlen(key):返回名称为key的hash中元素个数
9、hkeys(key):返回名称为key的hash中所有键
10、hvals(key):返回名称为key的hash中所有键对应的value
11、hgetall(key):返回名称为key的hash中所有的键(field)及其对应的value
实例
query在线分析
redis-cli MONITOR | head -n 5000 | ./redis-faina.py
监控正在请求执行的命令
在cli下执行monitor,生产环境慎用。
模拟oom
redis-cli debug oom
模拟宕机
redis-cli debug segfault
模拟hang
redis-cli -p 6379 DEBUG sleep 30
获取慢查询
SLOWLOG GET 10
结果为查询ID、发生时间、运行时长和原命令 默认10毫秒,默认只保留最后的128条。单线程的模型下,一个请求占掉10毫秒是件大事情,注意设置和显示的单位为微秒,注意这个时间是不包含网络延迟的。
slowlog get 获取慢查询日志
slowlog len 获取慢查询日志条数
slowlog reset 清空慢查询
配置:
config set slow-log-slower-than 20000 config set slow-max-len 1000 config rewrite
更多redis知识请关注PHP中文网redis教程栏目。
Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung des Redis-CLI-Befehls. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!