作者:Mrheartheart | 来源:互联网 | 2023-12-09 18:01
安装启动最简启动命令行输入验证动态参数启动配置文件启动常用配置通用命令keysbdsize计算key的总数exists判断是否存在delkeyvalue删除指定的keyvalue成
安装
启动
最简启动
命令行输入
redis-server # 使用默认配置
验证
ps-ef I grep redis
netstat-antpl I grep redis
redis-cli-h ip-p port ping
动态参数启动
redis-server -p 6380
配置文件启动
redis-server /path/to/conf
常用配置
daemonize 是否是守护进程(nolyes)
port Redis 对外端口号
logfile Redis系统日志
dir Redis工作目录
config get *
通用命令
keys
keys *
key 后面可以使用正则表达式,但是一般推荐在生产环境中使用这个命令
bdsize 计算key的总数
exists 判断是否存在
存在就返回1,不存在就返回0
del key-value 删除指定的key-value 成功删除1 不存在0
expire
expire key seconds 设置seconds秒后过期
ttl
查看剩余的过期时间
persist
去掉过期时间
-2 代表不存在 -1代表存在,但是没有设置过期时间
上面的命令出了keys 是O(n),其他全都是O(1).
redis是单线程的
单线程为什么这么快?
1、纯内存2、非阻塞IO 3、避免线程切换和竟态消耗
一次只运行一次命令
拒绝长命令
字符串类型
字符串应用场景
缓存,分布式锁,计数器。
常用命令
get key 获取key对应的value值 时间复杂度为O(1)
set key value 设置key-value 时间复杂度为O(1)
del key 删除key-value 时间复杂度为O(1)
incr key |
key自增1,如果key不存在,自增后get(key)=1 |
O(1) |
decr key |
key自减1,如果key不存在,自减后get(key)=-1 |
O(1) |
incry key k |
key自增k,如果key不存在,自增后get(key)=k decr key k |
O(1) |
decr key k |
key自减k,如果key不存在,自减后get(key)=-k |
O(1) |
set key value |
不管key是否存在,都设置 |
O(1) |
setnx key value |
key不存在,才设置 |
O(1) |
set key value xx |
key存在,才设置 |
O(1) |
mget keyl key2 key3... |
#批量获取key,原子操作 |
O(n) |
mset keyl valuel key2 value2 key3 value3 |
#批量设置key-value |
|
getset key newvalue |
#set key newvalue并返回旧的value |
O(1) |
append key value |
#将value追加到旧的value |
O(1) |
strlen key |
#返回字符串的长度(注意中文) |
O(1) |
incrbyfloat key 3.5 |
#增加key对应的值3.5 |
O(1) |
getrange key start end |
#获取字符串指定下标所有的值 |
O(1) |
setrange key index value |
#设置指定下标所有对应的值 |
O(1) |
哈希
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/aa12fbc6e0895d6e.png)
特点:
MapMap?
field不能相同,但是值可以相同
API
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/cd3e13b627023d44.png)
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/4e3547449f297a2b.png)
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/36a10b41db6999b9.png)
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/172f78bf71a262ed.png)
不常用的
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/a5930433007d7ccc.png)
列表
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/8caf58b5a2595d34.png)
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/ca9d8a4429e47dfe.png)
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/25bd57c1dbc73610.png)
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/cfd4bfa5dd70c218.png)
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/139531cf7a1e650f.png)
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/34d6b65009cc2910.png)
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/e7155553f0ed1026.png)
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/cf7366e1bb652835.png)
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/31a9f22051461c00.png)
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/d523f02f81035470.png)
集合
集合的特点:无序性,无重复,集合间操作
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/66419f151a7ec648.png)
sinter (求交集)
sdiff(求差集)
sunion(求并集)
scard 计数
sismember 判断是不是集合中的数据
srandmember 随机返回一个集合中的元素
spop随机删除一个集合中的元素
smember 返回所有的数据 小心使用这个API
有序集合
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/a9482fb3aa42e8b3.png)
和有序集合的对比
重复值 |
无重复值 |
无重复值 |
可以有重复元素 |
有序无序 |
无序 |
有序 |
有序 |
存储 |
element |
score+element |
element |
重要API
zadd key score element 可以是多对 |
添加score和element |
O(logN) |
zrem key element 可以是多个 |
删除指定元素 |
O(1) |
zscore key element |
返回指定元素的分数 |
O(1) |
zincrby key increScore element 分数可以为负 |
增加或者减少元素的分数 |
O(1) |
zcard key |
返回元素的总个数 |
O(1) |
zrange key start end [withscores] |
返回指定索引范围内的升序元素[是否输出分值可选] |
O(logN + M) |
zrangebyscore key minScore MaxScore [withscores] |
返回指定索引分数内的升序元素[是否输出分值可选] |
O(logN + M) |
zremrangebyrangk key start stop |
删除指定排名内的升序元素 |
O(logN + M) |
zremrangebyscore key minScore MaxScore |
删除指定分数内的升序元素 |
O(logN + M) |
redis 主从复制
127.0.0.1:6380> slaveof 11.11.11.11 6370
OK (异步) 清空6380机器上的所有数据
127.0.0.1:6380> slaveof noone
ok 不会清除数据
配置文件
slaveof ip port
slave-read-only yes
![技术分享图片](https://img7.php1.cn/3cdc5/c7bc/78c/140501b4ec1ca57d.png)
redis配置
获取访问页面
localhost:5010/get
## ssdbadmin 网页上查看redis的数据内容
#是否作为守护进程运行
daemonize no
#Redis 默认监听端口
port 6379
#客户端闲置多少秒后,断开连接
timeout 300
#日志显示级别
loglevel verbose
#指定日志输出的文件名,也可指定到标准输出端口
logfile redis.log
#设置数据库的数量,默认最大是16,默认连接的数据库是0,可以通过select N 来连接不同的数据库
databases 32
#Dump持久化策略
#当有一条Keys 数据被改变是,900 秒刷新到disk 一次
#save 900 1
#当有10 条Keys 数据被改变时,300 秒刷新到disk 一次
save 300 100
#当有1w 条keys 数据被改变时,60 秒刷新到disk 一次
save 6000 10000
#当dump .rdb 数据库的时候是否压缩数据对象
rdbcompression yes
#dump 持久化数据保存的文件名
dbfilename dump.rdb
########### Replication #####################
#Redis的主从配置,配置slaveof则实例作为从服务器
#slaveof ip host
#主服务器连接密码
# masterauth
############## 安全性 ###########
#设置连接密码
#requirepass
############### LIMITS ##############
#最大客户端连接数
# maxclients 128
#最大内存使用率
# maxmemory
########## APPEND ONLY MODE #########
#是否开启日志功能
appendonly no
# AOF持久化策略
#appendfsync always
#appendfsync everysec
#appendfsync no
################ VIRTUAL MEMORY ###########
#是否开启VM 功能
#vm-enabled no
# vm-enabled yes
#vm-swap-file logs/redis.swap
#vm-max-memory 0
#vm-page-size 32
#vm-pages 134217728
#vm-max-threads 4
python连接redis提高效率
写单例
把连接放在单独的配置文件中,或者新建文件,在调用的时候从其他的地方导入过来
settings.py
import redis
POOL = redis.connectionpool(host ='127.0.0.1',port=6379,password='12',max_cOnnections=1000)
其他
from settings import POOL
cOnn= redis.Redis(connection_pool = POOL)
在hgetall中如果,redis的内存过大,会发生爆栈的情况。
应该用hscan_iter(key,count)
列表操作
var = conn.blpop(k1,timeout = 10)