Rumah > pangkalan data > Redis > teks badan

Contoh analisis penggunaan redis dan arahan yang digunakan untuk pelbagai jenis data

WBOY
Lepaskan: 2023-05-30 13:09:34
ke hadapan
691 orang telah melayarinya

Kompilasi dan pasang redis

Mulakan penggunaan

[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
Salin selepas log masuk

Arahan gcc ralat tidak ditemui:

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
Salin selepas log masuk

#Selesaikan persekitaran pergantungan yang diperlukan untuk penyusunan dan pemasangan dan teruskan penggunaan

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]$
Salin selepas log masuk

Redis operasi pelayan dan sambungan klien

[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>
Salin selepas log masuk

redis konfigurasi

[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]$
Salin selepas log masuk

Redis mudah untuk dikonfigurasi dan dimulakan

[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>
Salin selepas log masuk

tetapkan dan dapatkan arahan

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>
Salin selepas log masuk

Pengenalan fail Konfigurasi Mudah

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

redis jenis data asas

redis ialah sistem storan kunci:nilai lanjutan, di mana nilai menyokong lima jenis data
Rentetan (rentetan)
Hashes
Senarai
Set
Set diisih

arahan redis

redis perintah mudah

kunci * Lihat semua kekunci
taip kekunci View jenis kekunci
tamat masa kekunci masa
ttl kekunci Lihat baki masa tamat tempoh kunci - 2 bermakna kunci tidak lagi wujud
berterusan Batalkan masa tamat tempoh kekunci -1 menunjukkan bahawa kunci itu wujud dan mempunyai tiada masa tamat tempoh

kekunci wujud Mengembalikan 1 jika kunci wujud, jika tidak 0
kekunci del Padam kekunci Anda boleh memadam berbilang
dbsize Kira bilangan kekunci
flushdb #Kosongkan Semua kekunci dalam redis , gunakan dengan berhati-hati
flushdb #Kosongkan semua kekunci dalam redis, gunakan dengan berhati-hati
flushdb #Kosongkan semua kekunci dalam redis, gunakan dengan berhati-hati

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>
Salin selepas log masuk

Perintah jenis rentetan

redis数据类型1,字符串类型,通过set命令,设置字符串类型的key
    strings类型
    set   设置key
    get   获取key
    append  追加string
    mset   设置多个键值对
    mget   获取多个键值对
    del  删除key
    incr  递增+1
    decr  递减-1
Salin selepas log masuk
rrree

senarai taip , Baris gilir dwiarah

lpush Sisipkan dari kiri senarai
rpush Sisipkan dari sebelah kanan senarai
ljulat Dapatkan elemen panjang tertentu ljulat hentian mula kunci
ltrim Memintas tertentu panjang senarai
lpop Padam paling kiri Satu elemen
rpop memadamkan elemen paling kanan
lpushx/rpushx Jika kunci itu wujud, tambahkan nilainya Jika ia tidak wujud, ia tidak akan diproses 🎜>

set   设置key
get   获取key
append  追加string
10.0.0.11:6379> set "name" "mcw"
OK
10.0.0.11:6379> get name
"mcw"
10.0.0.11:6379> append "name" "Haoren"
(integer) 9
10.0.0.11:6379> get name
"mcwHaoren"
10.0.0.11:6379> 
mset   设置多个键值对
mget   获取多个键值对
10.0.0.11:6379> mset name2 "xiaoma" "name3" xiaohong
OK
10.0.0.11:6379> keys *
1) "name2"
2) "name"
3) "name3"
10.0.0.11:6379> get name2
"xiaoma"
10.0.0.11:6379> get name3
"xiaohong"
10.0.0.11:6379> 
10.0.0.11:6379> mget name name2 name3
1) "mcwHaoren"
2) "xiaoma"
3) "xiaohong"
10.0.0.11:6379> 
del  删除key
10.0.0.11:6379> keys *
1) "name2"
2) "name"
3) "name3"
10.0.0.11:6379> del name
(integer) 1
10.0.0.11:6379> del name2 name3
(integer) 2
10.0.0.11:6379> keys *
(empty list or set)
10.0.0.11:6379> 
incr  递增+1
decr  递减-1
相当于把字符串转换为数字,计算后结果再改成字符串。
还可以减为负值
10.0.0.11:6379> keys *
(empty list or set)
10.0.0.11:6379> set "dian zan" 0
OK
10.0.0.11:6379> get "dian zan"
"0"
10.0.0.11:6379> incr "dian zan"
(integer) 1
10.0.0.11:6379> incr "dian zan"
(integer) 2
10.0.0.11:6379> get "dian zan"
"2"
10.0.0.11:6379> incr "dian zan"
(integer) 3
10.0.0.11:6379> get "dian zan"
"3"
10.0.0.11:6379> decr "dian zan"
(integer) 2
10.0.0.11:6379> get "dian zan"
"2"
10.0.0.11:6379> 
10.0.0.11:6379> keys *
1) "dian zan"
10.0.0.11:6379> 
10.0.0.11:6379> get "dian zan"
"2"
10.0.0.11:6379> decr "dian zan"
(integer) 1
10.0.0.11:6379> decr "dian zan"
(integer) 0
10.0.0.11:6379> decr "dian zan"
(integer) -1
10.0.0.11:6379> decr "dian zan"
(integer) -2
10.0.0.11:6379> decr "dian zan"
(integer) -3
Salin selepas log masuk

koleksi redis ialah koleksi tidak tersusun Unsur-unsur dalam koleksi Tiada susunan keutamaan.

Terdapat juga banyak operasi berkaitan set, seperti menambah elemen baharu, memadamkan elemen sedia ada, mengambil persimpangan, mengambil kesatuan, mengambil perbezaan, dsb. Mari lihat contoh:

sadd/srem Tambah/padam elemen

sismember Tentukan sama ada ia elemen set
smembers Kembalikan semua ahli set
sdiff Kembalikan perbezaan antara set dan set lain
sinter mengembalikan persilangan beberapa set
sunion mengembalikan kesatuan beberapa set

lpush         从列表左边插
从左边插入,再从左边获取,先插入的在里面后取出,后插入的在左边先取出
10.0.0.11:6379> keys *
(empty list or set)
10.0.0.11:6379> lpush paidui mcw1 mcw2 mcw3 mcw4
(integer) 4
10.0.0.11:6379> lrange paidui 0 -1
1) "mcw4"
2) "mcw3"
3) "mcw2"
4) "mcw1"
10.0.0.11:6379> lpush paidui mcw5
(integer) 5
10.0.0.11:6379> lrange paidui 0 -1
1) "mcw5"
2) "mcw4"
3) "mcw3"
4) "mcw2"
5) "mcw1"
10.0.0.11:6379> 
rpush         从列表右边插
从列表左边取,第一个取出来的是最后推入的,最后一个取出的是第一个推入的。
可以想象成如下排队顺序, mcw5 mcw4 mcw3 mcw2 mcw1   
当从右边推入mcw6的时候就是 :mcw5 mcw4 mcw3 mcw2 mcw1 mcw6
当从左边取数据的时候就是:
第一次取:mcw5
第二次取: mcw4
....
第六次取:mcw6
10.0.0.11:6379> lrange paidui 0 -1
1) "mcw5"
2) "mcw4"
3) "mcw3"
4) "mcw2"
5) "mcw1"
10.0.0.11:6379> rpush paidui mcw6
(integer) 6
10.0.0.11:6379> lrange paidui 0 -1
1) "mcw5"
2) "mcw4"
3) "mcw3"
4) "mcw2"
5) "mcw1"
6) "mcw6"
lrange          获取一定长度的元素  lrange key  start stop
取列表类型的数据,指定开始数据和结束数据,比如开始0,结束-1,这是取列表所有的值
10.0.0.11:6379> lrange paidui 0 -1
1) "mcw5"
2) "mcw4"
3) "mcw3"
4) "mcw2"
5) "mcw1"
10.0.0.11:6379> 
10.0.0.11:6379> keys * 
1) "paidui"
10.0.0.11:6379> type paidui
list
10.0.0.11:6379> get paidui   #列表类型不能用get取值
(error) WRONGTYPE Operation against a key holding the wrong kind of value
10.0.0.11:6379> lrange paid 0 -1  #不存在的键
(empty list or set)
10.0.0.11:6379> 
10.0.0.11:6379> lrange paidui 0 -1
1) "mcw5"
2) "mcw4"
3) "mcw3"
4) "mcw2"
5) "mcw1"
10.0.0.11:6379> 
ltrim               截取一定长度列表
根据查询可知列表数据顺序如下:mcw5 mcw4 mcw3 mcw2 mcw1
索引分别是:                   0    1    2     3    4  
这里是从paidui左边截取,从索引1开始,从索引2结束,其中包含索引2的数据,截取之后,这个key的值就变成截取的值了mcw4 mcw3
然后从左边查询,第一个查出来的数据就是mcw4,第二个就是mcw3
10.0.0.11:6379> lrange paidui 0 -1
1) "mcw5"
2) "mcw4"
3) "mcw3"
4) "mcw2"
5) "mcw1"
10.0.0.11:6379> ltrim paidui 1 2
OK
10.0.0.11:6379> lrange paidui 0 -1
1) "mcw4"
2) "mcw3"
10.0.0.11:6379> 
lpop                 删除最左边一个元素
rpop                     删除最右边一个元素
根据lrange可以列表数据的顺序是:mcw5 mcw4 mcw3 mcw2 mcw1 mcw6
所以从左边删除,删的是mcw5,从右边删除,删的是mcw6
10.0.0.11:6379> lrange paidui 0 -1
1) "mcw5"
2) "mcw4"
3) "mcw3"
4) "mcw2"
5) "mcw1"
6) "mcw6"
10.0.0.11:6379> lpop paidui
"mcw5"
10.0.0.11:6379> rpop paidui
"mcw6"
10.0.0.11:6379> lrange paidui 0 -1
1) "mcw4"
2) "mcw3"
3) "mcw2"
4) "mcw1"
10.0.0.11:6379> 
lpushx/rpushx                key存在则添加值,不存在不处理
不存在返回个0。默认key不存在会创建key的
10.0.0.11:6379> keys * 
1) "paidui"
10.0.0.11:6379> lpushx paid mcw0
(integer) 0
10.0.0.11:6379> keys * 
1) "paidui"
10.0.0.11:6379> lpushx paidui mcw0
(integer) 5
10.0.0.11:6379> keys * 
1) "paidui"
10.0.0.11:6379> lrange paidui 0 -1
1) "mcw0"
2) "mcw4"
3) "mcw3"
4) "mcw2"
5) "mcw1"
10.0.0.11:6379>
Salin selepas log masuk

Struktur data cincang

cincang ialah cincang. Hash ialah struktur data yang hanya tersedia sejak versi redis-2.0.0.

Cincangan menyimpan pemetaan antara rentetan dan nilai rentetan Contohnya, jika pengguna ingin menyimpan nama penuh, nama keluarga, umurnya, dsb., adalah sesuai untuk menggunakan cincang.

hset Tetapkan nilai cincang

hget Dapatkan nilai cincang
hmset Tetapkan berbilang pasangan nilai cincang
hmget Dapatkan berbilang pasangan nilai cincang
hsetnx Jika cincang sudah wujud, maka Tidak ditetapkan (untuk mengelakkan penggantian kunci)
hkeys Mengembalikan semua fail
hvals Mengembalikan semua nilai
hlen Mengembalikan bilangan medan (medan) yang terkandung dalam cincang
hdel Padam medan (medan) ditentukan oleh cincang
hexists menentukan sama ada terdapat

sadd/srem   添加/删除 元素
smembers    返回集合所有的成员
10.0.0.11:6379> keys *
(empty list or set)
10.0.0.11:6379> sadd zoo gou mao zhu  #添加
(integer) 3
1) "zoo"
10.0.0.11:6379> type zoo
set
10.0.0.11:6379> smembers zoo  #查询
1) "mao"
2) "zhu"
3) "gou"
10.0.0.11:6379> 
10.0.0.11:6379> srem zoo zhu  #删除
(integer) 1
10.0.0.11:6379> smembers zoo
2) "gou"
新增成员
10.0.0.11:6379> sadd zoo zhu #新增
sismember   判断是否为set的一个元素
mao是集合zoo里的成员吗,是,返回的是1;
zhu是集合zoo里的成员吗,不是,返回的是0
10.0.0.11:6379> sismember zoo mao
10.0.0.11:6379> sismember zoo zhu
(integer) 0
sdiff             返回一个集合和其他集合的差异
如下,sdiff 集合1 集合2 
返回集合1中有的,而集合2中没有的。就是取差集
1) "zoo2"
2) "zoo"
10.0.0.11:6379> smembers zoo2
1) "she"
3) "shu"
10.0.0.11:6379> sdiff zoo zoo2
10.0.0.11:6379> sdiff zoo2 zoo
2) "shu"
sinter           返回几个集合的交集
如下,几个集合应该不只是包含两个集合
10.0.0.11:6379> sinter zoo zoo2
1) "zhu"
10.0.0.11:6379> sinter zoo2 zoo
sunion          返回几个集合的并集
集合取并集,几个集合应该不只是能用两个集合
10.0.0.11:6379> sunion zoo zoo2
4) "mao"
5) "shu"
10.0.0.11:6379>
Salin selepas log masuk
Terbitkan dan langgan

Aplikasi utama: pemberitahuan, pengumuman

Boleh digunakan sebagai baris gilir mesej atau saluran paip mesej

Satu penerbitan, berbilang langganan

Terbitkan: Saluran stesen radio boleh menghantar mesej suara kepada semua orang yang menerima saluran ini
Langgan: Ramai orang boleh menerima mesej daripada stesen radio ini

Sebagai contoh , pengumuman kumpulan QQ: satu terbitan, berbilang langganan (Diterima)

Seperti berikut, satu penerbit, dua pelanggan, Pelanggan 1 melanggan mesej yang berkaitan dengan saluran python dan linux Pelanggan 2 melanggan mesej yang berkaitan dengan golang dan Linux

Contoh analisis penggunaan redis dan arahan yang digunakan untuk pelbagai jenis data

Apabila penerbit menerbitkan mesej, Pelanggan 1 menerima mesej daripada python saluran langganan

Contoh analisis penggunaan redis dan arahan yang digunakan untuk pelbagai jenis data

Apabila penerbit menghantar mesej kepada Apabila saluran linux diterbitkan, kedua-dua pelanggan menerima mesej tersebut. Penerbit juga mengembalikan bilangan pelanggan yang menerima mesej tersebut. Artikel di atas telah ditulis secara salah dan telah diterbitkan ke saluran yang tiada siapa yang melanggan, mengembalikan 0 pelanggan

Contoh analisis penggunaan redis dan arahan yang digunakan untuk pelbagai jenis data

Saluran yang diterbitkan oleh penerbit dan saluran yang diterima, ini diperlukan Pertimbangan yang tepat, tidak boleh padanan kabur

Contoh analisis penggunaan redis dan arahan yang digunakan untuk pelbagai jenis data

apabila pelanggan menggunakan planggan di sini, ia menjadi corak

Contoh analisis penggunaan redis dan arahan yang digunakan untuk pelbagai jenis data

Apabila pelanggan menggunakan arahan psubscribe dan saluran yang dilanggan menggunakan wildcard, maka saluran yang diterbitkan oleh penerbit yang boleh dipadankan secara kabur dengan pelanggan akan diterima oleh pelanggan

Contoh analisis penggunaan redis dan arahan yang digunakan untuk pelbagai jenis data

Atas ialah kandungan terperinci Contoh analisis penggunaan redis dan arahan yang digunakan untuk pelbagai jenis data. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:yisu.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!