Heim >Datenbank >Redis >Beispielanalyse der Redis-Bereitstellung und der für verschiedene Datentypen verwendeten Befehle

Beispielanalyse der Redis-Bereitstellung und der für verschiedene Datentypen verwendeten Befehle

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBnach vorne
2023-05-30 13:09:34760Durchsuche

Kompilieren und installieren Sie Redis.

Bereitstellung starten

[root@mcw01 ~]$ ls
anaconda-ks.cfg  mongodb-linux-x86_64-3.2.8.tgz
[root@mcw01 ~]$ wget http://download.redis.io/releases/redis-4.0.10.tar.gz
--2022-03-05 18:27:02--  http://download.redis.io/releases/redis-4.0.10.tar.gz
Resolving download.redis.io (download.redis.io)... 45.60.125.1
Connecting to download.redis.io (download.redis.io)|45.60.125.1|:80... connected.
HTTP request sent, awaiting response... 200 OK
Length: 1738465 (1.7M) [application/octet-stream]

Saving to: ‘redis-4.0.10.tar.gz'

100%[====================>] 1,738,465   63.4KB/s   in 25s    

2022-03-05 18:27:27 (68.2 KB/s) - ‘redis-4.0.10.tar.gz' saved [1738465/1738465]

anaconda-ks.cfg  mongodb-linux-x86_64-3.2.8.tgz  redis-4.0.10.tar.gz
[root@mcw01 ~]$ tar xf redis-4.0.10.tar.gz 
anaconda-ks.cfg  mongodb-linux-x86_64-3.2.8.tgz  redis-4.0.10  redis-4.0.10.tar.gz
[root@mcw01 ~]$ cd redis-4.0.10/
[root@mcw01 ~/redis-4.0.10]$ ls  #有makefile文件,就不需要./configure配置
00-RELEASENOTES  COPYING  Makefile   redis.conf       runtest-sentinel  tests
BUGS             deps     MANIFESTO  runtest          sentinel.conf     utils
CONTRIBUTING     INSTALL  README.md  runtest-cluster  src
[root@mcw01 ~/redis-4.0.10]$ make

Einfache Konfiguration und Start von Redis

cd hiredis && make static
make[3]: Entering directory `/root/redis-4.0.10/deps/hiredis'
gcc -std=c99 -pedantic -c -O3 -fPIC  -Wall -W -Wstrict-prototypes -Wwrite-strings -g -ggdb  net.c
make[3]: gcc: Command not found
make[3]: *** [net.o] Error 127
make[3]: Leaving directory `/root/redis-4.0.10/deps/hiredis'
make[2]: *** [hiredis] Error 2
make[2]: Leaving directory `/root/redis-4.0.10/deps'
make[1]: [persist-settings] Error 2 (ignored)
    CC adlist.o
/bin/sh: cc: command not found
make[1]: *** [adlist.o] Error 127
make[1]: Leaving directory `/root/redis-4.0.10/src'
make: *** [all] Error 2

Set- und Get-Befehle

um install gcc patch libffi-devel python-devel  zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel openssl openssl-devel -y
然后重新执行:
[root@mcw01 ~/redis-4.0.10]$ make  #发现报错没有某个目录或文件。在这之前编译失败了,目录被改变了部分,所以直接删除重新解压,然后make编译
......
Hint: It's a good idea to run 'make test' ;)
make[1]: Leaving directory `/root/redis-4.0.10/src'
[root@mcw01 ~/redis-4.0.10]$ ls
00-RELEASENOTES  COPYING  Makefile   redis.conf       runtest-sentinel  tests
BUGS             deps     MANIFESTO  runtest          sentinel.conf     utils
CONTRIBUTING     INSTALL  README.md  runtest-cluster  src
[root@mcw01 ~/redis-4.0.10]$ make install 
cd src && make install
make[1]: Entering directory `/root/redis-4.0.10/src'
    CC Makefile.dep
    INSTALL install
[root@mcw01 ~/redis-4.0.10]$ 
[root@mcw01 ~/redis-4.0.10]$ redis-c   #当编译好之后,就可以命令补全,也就是已经配置好环境变量了
redis-check-aof  redis-check-rdb  redis-cli        
[root@mcw01 ~/redis-4.0.10]$ which redis-server  #默认编译安装到/usr/local下去了
/usr/local/bin/redis-server
[root@mcw01 ~/redis-4.0.10]$

Einfache Einführung in die Konfigurationsdatei

[root@mcw01 ~]$ redis-server  #安装好之后,直接运行这个命令
24270:C 05 Mar 18:43:08.857 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
24270:C 05 Mar 18:43:08.857 # Redis version=4.0.10, bits=64, commit=00000000, modified=0, pid=24270, just started
24270:C 05 Mar 18:43:08.857 # Warning: no config file specified, using the default config. In order to specify a config file use redis-server /path/to/redis.conf
                _._                                                  
           _.-``__ ''-._                                             
      _.-``    `.  `_.  ''-._           Redis 4.0.10 (00000000/0) 64 bit
  .-`` .-```.  ```\/    _.,_ ''-._                                   
 (    '      ,       .-`  | `,    )     Running in standalone mode
 |`-._`-...-` __...-.``-._|'` _.-'|     Port: 6379
 |    `-._   `._    /     _.-'    |     PID: 24270
  `-._    `-._  `-./  _.-'    _.-'                                   
 |`-._`-._    `-.__.-'    _.-'_.-'|                                  
 |    `-._`-._        _.-'_.-'    |           http://redis.io        
  `-._    `-._`-.__.-'_.-'    _.-'                                   
 |    `-._`-._        _.-'_.-'    |                                  
      `-._    `-.__.-'    _.-'                                       
          `-._        _.-'                                           
              `-.__.-'                                               
24270:M 05 Mar 18:43:08.880 # Server initialized
24270:M 05 Mar 18:43:08.880 # WARNING overcommit_memory is set to 0! Background save may fail under low memory condition. To fix this issue add 'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effect.
24270:M 05 Mar 18:43:08.880 # WARNING you have Transparent Huge Pages (THP) support enabled in your kernel. This will create latency and memory usage issues with Redis. To fix this issue run the command 'echo never > /sys/kernel/mm/transparent_hugepage/enabled' as root, and add it to your /etc/rc.local in order to retain the setting after a reboot. Redis must be restarted after THP is disabled.
24270:M 05 Mar 18:43:08.880 * Ready to accept connections
客户端连接:
[root@mcw01 ~]$ redis-cli 127.0.0.1 6379  ^C #我再开一个窗口,默认连接的ip 端口
[root@mcw01 ~]$ redis-cli  #连上之后,ping命令,返回pong,说明连接成功的
127.0.0.1:6379> ping
PONG
127.0.0.1:6379>

Redis-Grunddatentypen

Redis ist ein erweitertes Schlüssel-Wert-Speichersystem, bei dem Werte fünf Datentypen unterstützen

Zeichenfolge (Zeichenfolgen)

Hashes

Listen

Mengen

Sortierte Mengen

Redis-Befehl


Redis einfacher Befehl

Schlüssel * Alle Schlüssel anzeigen
Schlüsseltyp anzeigen Schlüsseltyp anzeigen
Schlüssel ablaufen lassen Sekunden Ablaufzeit

ttl-Schlüssel Überprüfen Sie die verbleibende Zeit des Schlüssels expiration – 2 bedeutet, dass der Schlüssel nicht mehr vorhanden ist

persist Abbruch der Ablaufzeit des Schlüssels – 1 bedeutet, dass der Schlüssel existiert, es gibt keine Ablaufzeit

exists key Gibt 1 zurück, um zu beurteilen, ob der Schlüssel existiert, andernfalls 0

del keys Schlüssel löschen Sie können mehrere löschen

dbsize Berechnen Sie die Anzahl der Schlüssel
flushdb #Alle Redis-Schlüssel löschen, mit Vorsicht verwenden
flushdb #Alle Redis-Schlüssel löschen, mit Vorsicht verwenden
flushdb #Alle Redis-Schlüssel löschen, mit Vorsicht verwenden

[root@mcw01 ~]$ ln -s redis-4.0.10  redis 
[root@mcw01 ~]$ ls
anaconda-ks.cfg  dump.rdb  mongodb-linux-x86_64-3.2.8.tgz  redis  redis-4.0.10  redis-4.0.10.tar.gz
[root@mcw01 ~]$ ls redis
00-RELEASENOTES  COPYING  Makefile   redis.conf       runtest-sentinel  tests
BUGS             deps     MANIFESTO  runtest          sentinel.conf     utils
CONTRIBUTING     INSTALL  README.md  runtest-cluster  src
[root@mcw01 ~]$ cd redis
[root@mcw01 ~/redis]$ egrep -v "^#|^$" redis.conf >mcwRedis.conf
[root@mcw01 ~/redis]$ cat mcwRedis.conf 
bind 127.0.0.1   
protected-mode yes  #保护模式开启,并且绑定ip是本机,应该是不支持远程访问,只支持本机访问。
port 6379
tcp-backlog 511
timeout 0
tcp-keepalive 300
daemonize no
supervised no
pidfile /var/run/redis_6379.pid
loglevel notice
logfile ""
databases 16
always-show-logo yes
save 900 1
save 300 10
save 60 10000
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb
dir ./
slave-serve-stale-data yes
slave-read-only yes
repl-diskless-sync no
repl-diskless-sync-delay 5
repl-disable-tcp-nodelay no
slave-priority 100
lazyfree-lazy-eviction no
lazyfree-lazy-expire no
lazyfree-lazy-server-del no
slave-lazy-flush no
appendonly no
appendfilename "appendonly.aof"
appendfsync everysec
no-appendfsync-on-rewrite no
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
aof-load-truncated yes
aof-use-rdb-preamble no
lua-time-limit 5000
slowlog-log-slower-than 10000
slowlog-max-len 128
latency-monitor-threshold 0
notify-keyspace-events ""
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
list-max-ziplist-size -2
list-compress-depth 0
set-max-intset-entries 512
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
hll-sparse-max-bytes 3000
activerehashing yes
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit slave 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
hz 10
aof-rewrite-incremental-fsync yes
[root@mcw01 ~/redis]$

Befehl vom Typ String

[root@mcw01 ~/redis]$ cat mcwRedis.conf 
bind 10.0.0.11
protected-mode yes
port 6379
requirepass mcw123 #配置认证密码
daemonize yes #后台守护进程的方式开启
pidfile /var/run/redis_6379.pid
loglevel notice
logfile ""
[root@mcw01 ~/redis]$ 
[root@mcw01 ~/redis]$ ls  
00-RELEASENOTES  COPYING  Makefile       README.md   runtest-cluster   src
BUGS             deps     MANIFESTO      redis.conf  runtest-sentinel  tests
CONTRIBUTING     INSTALL  mcwRedis.conf  runtest     sentinel.conf     utils
[root@mcw01 ~/redis]$ redis-server mcwRedis.conf  #指定配置文件启动。这应该是后面有注释导致的吧,去掉注释
*** FATAL CONFIG FILE ERROR ***
Reading the configuration file, at line 4
>>> 'requirepass mcw123 #配置认证密码'
Bad directive or wrong number of arguments
去掉注释,然后成功启动,这里不能在配置后面加注释,容易出错
[root@mcw01 ~/redis]$ vim mcwRedis.conf 
requirepass mcw123
daemonize yes
[root@mcw01 ~/redis]$ redis-server mcwRedis.conf 
24391:C 05 Mar 19:10:38.749 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
24391:C 05 Mar 19:10:38.749 # Redis version=4.0.10, bits=64, commit=00000000, modified=0, pid=24391, just started
24391:C 05 Mar 19:10:38.749 # Configuration loaded
[root@mcw01 ~/redis]$ netstat -lntup|grep redis #成功启动了
tcp        0      0 10.0.0.11:6379          0.0.0.0:*               LISTEN      24392/redis-server  
[root@mcw01 ~/redis]$ redis-cli  #现在直接这么连接就不行了
Could not connect to Redis at 127.0.0.1:6379: Connection refused
not connected> 
[root@mcw01 ~/redis]$ redis-cli  -h 10.0.0.11 -p 6379   #指定ip端口连接
10.0.0.11:6379> ping
(error) NOAUTH Authentication required.
10.0.0.11:6379> auth mcw123
OK
10.0.0.11:6379> ping  #认证之后就可以正常执行命令了
PONG
10.0.0.11:6379>
10.0.0.11:6379> set name mcw
OK
10.0.0.11:6379> get name
"mcw"
10.0.0.11:6379> set age  18  
OK
10.0.0.11:6379> get age  #它将值改为字符串类型的了
"18"
10.0.0.11:6379>

Listentyp, bidirektionale Warteschlange

lpush Von links in die Liste einfügen
rpush Von rechts in die Liste einfügen
lrange Elemente einer bestimmten Länge abrufen lrange-Taste Start Stop

ltrim Eine bestimmte Länge der Liste abfangen

lpop Löschen Sie das Element ganz links.

rpop Löschen Sie das Element ganz links. Wenn das Element rechts im Schlüssel

lpushx/rpushx vorhanden ist, wird der Wert hinzugefügt. Wenn er nicht vorhanden ist, wird er nicht verarbeitet Sammlung, und die Elemente in der Sammlung haben keine Reihenfolge.

Es gibt auch viele satzbezogene Operationen, wie z. B. das Hinzufügen neuer Elemente, das Löschen vorhandener Elemente, das Ermitteln von Schnittpunkten, das Ermitteln von Vereinigungen, das Ermitteln von Differenzen usw. Schauen wir uns ein Beispiel an:

sadd/srem Elemente hinzufügen/löschen
sismember Bestimmen, ob es ein Element der Menge ist
smembers Gibt alle Mitglieder der Menge zurück
sdiff Gibt die Differenz zwischen einer Menge und anderen Mengen zurück
sinter Gibt die Schnittmenge zurück von mehreren Mengen

sunion Gibt die Vereinigung mehrerer Mengen zurück

bind 192.168.182.130  #绑定服务端地址 
protected-mode yes    #安全模式 
port 6800        #端口 
requirepass  haohaio                #密码                                                                       
daemonize yes    #后台运行 
pidfile /var/run/redis_6379.pid    #进程id文件
loglevel notice        #日志等级
logfile ""

Hash-Datenstruktur

Hashes sind Hashes. Hash ist eine Datenstruktur, die erst seit der Version redis-2.0.0 verfügbar ist.


Hashes speichern die Zuordnung zwischen Zeichenfolgen und Zeichenfolgenwerten. Wenn ein Benutzer beispielsweise seinen vollständigen Namen, Nachnamen, Alter usw. speichern möchte, ist die Verwendung von Hashes geeignet.

hset Setzt den Hash-Wert
hget Ruft den Hash-Wert ab
hmset Setzt mehrere Paare von Hash-Werten

hmget Ruft mehrere Paare von Hash-Werten ab

hsetnx Wenn der Hash bereits existiert, wird er nicht gesetzt (um ein Überschreiben zu verhindern). key)

hkeys Gibt alle Felder zurück

hvals gibt alle Werte zurück

hlen gibt die Anzahl der im Hash enthaltenen Felder zurück

hdel löscht das durch den Hash angegebene Feld

hexists bestimmt, ob es existiert

keys * 
10.0.0.11:6379> keys *
1) "age"
2) "name"
10.0.0.11:6379> set gender man
OK
1) "gender"
2) "age"
3) "name"
10.0.0.11:6379> 
keys *         查看所有key
type key      查看key类型
添加一个列表,查看key类型,是列表类型
10.0.0.11:6379> type name
string
10.0.0.11:6379> LPUSH paidui1 xiaoma mcw
(integer) 2
10.0.0.11:6379> keys * 
1) "paidui1"
2) "gender"
3) "age"
4) "name"
10.0.0.11:6379> type paidui1
list
expire key seconds    过期时间
ttl key     查看key过期剩余时间        -2表示key已经不存在了
给已有的paidui1设置一个过期时间多少秒,然后ttl  key可以查看过期时间,当-2时就已经过期了,过期了就已经被移除了
10.0.0.11:6379> EXPIRE paidui1 10
(integer) 1
10.0.0.11:6379> ttl paidui1
(integer) -2
persist     取消key的过期时间   -1表示key存在,没有过期时间
比如下面,将name设置50秒过期,当要取消name的过期时间,执行命令后,ttl值变成-1,就不会出现过期删除的情况了
10.0.0.11:6379> EXPIRE name 50
10.0.0.11:6379> ttl name
(integer) 22
(integer) 19
10.0.0.11:6379> PERSIST name
(integer) -1
exists key     判断key存在    存在返回1    否则0
10.0.0.11:6379> exists name
10.0.0.11:6379> exists mcw
(integer) 0
del keys     删除key    可以删除多个
4) "myname"
10.0.0.11:6379> del myname
dbsize         计算key的数量
10.0.0.11:6379> dbsize
(integer) 3
flushdb  #清除redis所有key,慎用
10.0.0.11:6379> flushdb
(empty list or set)
10.0.0.11:6379>

veröffentlichen und abonnieren

Hauptanwendungen : Benachrichtigungen, Ankündigungen
können als Nachrichtenwarteschlange oder Nachrichtenpipeline verwendet werden

Eine Veröffentlichung, mehrere Abonnements
Veröffentlichen: Der Radiosenderkanal kann Sprachnachrichten an alle Personen senden, die diesen Kanal empfangen.
Abonnieren: Viele Personen können die Nachrichten darüber erhalten Radiosender

Zum Beispiel QQ-Gruppenankündigung: Eine Veröffentlichung, mehrere Abonnements (erhalten)

Wie folgt: Ein Herausgeber, zwei Abonnenten: Abonnent 1 abonniert Nachrichten im Zusammenhang mit Python- und Linux-Kanälen; Abonnent 2 abonniert Nachrichten im Zusammenhang mit Golang und Linux



Wenn der Herausgeber eine Nachricht veröffentlicht, erhält Abonnent 1 die Nachricht vom Abonnementkanal Python

Wenn der Herausgeber auf dem Linux-Kanal veröffentlicht, erhalten beide Abonnenten die Nachricht. Der Herausgeber gibt außerdem zurück, wie viele Abonnenten die Nachricht erhalten haben. Der obige Artikel wurde falsch geschrieben und auf einem Kanal veröffentlicht, den niemand abonniert hat, was zu 0 Abonnenten führt. Der vom Herausgeber veröffentlichte und empfangene Kanal erfordert ein genaues Urteilsvermögen und kann nicht mit der empfangenen Nachricht übereinstimmen

Wenn der Abonnent hier psubscribe verwendet, wird daraus ein Muster Reichweite erhalten Abonnenten

Beispielanalyse der Redis-Bereitstellung und der für verschiedene Datentypen verwendeten Befehle

Das obige ist der detaillierte Inhalt vonBeispielanalyse der Redis-Bereitstellung und der für verschiedene Datentypen verwendeten Befehle. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:yisu.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen