【重点】 redis为什么这么快? (应届)
①redis是纯内存结构,避免磁盘I/O的耗时
②redis核心模块是一个单进程,减少线程切换和回收线程资源时间
③redis采用的是I/O的多路复用机制(每一个执行线路可以同时完成读、写),提升高并发效率(注:redis的读写仍然是单进程处理)
1、redis的服务控制命令
/etc/init.d/redis_6379 restart stop start status
data:image/s3,"s3://crabby-images/71229/712293f72cd5e47135693d60767c42bacaa55726" alt=""
2、redis的命令工具
redis-server:直接启动redis,只能启动
redis-benchmark:检测redis在本机的运行效果
redis-cli:命令行工具
redis-check-aof:检测AOF文件是否正常
redis-check-rdb:检测RDB文件是否正常
3、redis-benchmark语法
-h指定服务器的主机名(IP地址)
-p指定服务器的端口号6379
-c指定并发连接数
-n指定请求数
-a指定登录密码
data:image/s3,"s3://crabby-images/76817/76817c3946436eaccc6be81eefecdd893b792d12" alt=""
data:image/s3,"s3://crabby-images/e736a/e736a1924f3498c0a2bfeaee76bee50fecba09a3" alt=""
4、登录redis
①方法1:redis-cli -h 20.0.0.14 -p 6379远程登录本机或别的服务器
②方法2:redis-cli直接使用,仅限于本地,远程登录仍需要指定目标服务器的IP地址
data:image/s3,"s3://crabby-images/b1ee5/b1ee539aeee2560f889f8502d8a7f5c3209563fd" alt=""
data:image/s3,"s3://crabby-images/30b1d/30b1db0c9d9514928de376c6e76e0c75123cd64b" alt=""
|-------------|------------------------------------------|
| redis整个库 ||
| 查看当前库中的键的数量 | DBSIZE |
| 切换库 | SELECT 2 |
| 移动键值到指定库15 | move guoqi1 15 |
| 设置密码 | config set requirepass 123456 |
| 在外声明密码 | redis-cli -h 20.0.0.14 -p 6379 -a 123456 |
| 在内声明密码 | auth 123456 |
①查看当前库中的键的数量DBSIZE
data:image/s3,"s3://crabby-images/5dbd0/5dbd0a83a68f38ed7e2ca72d8ce99c35ea4c510a" alt=""
redis默认有16个库,第一个是0,最后一个是15,每个数据库之间互相独立、互不干扰
②切换库SELECT 2
data:image/s3,"s3://crabby-images/449d2/449d2799d295eda4bb4a076720f3872a5077328a" alt=""
③移动键值到指定库15
move guoqi1 15
data:image/s3,"s3://crabby-images/85d80/85d80e73554526aebf89a80a2043dc871f9c3bce" alt=""
④设置密码config set requirepass 123456
data:image/s3,"s3://crabby-images/6e214/6e2141a779601dd71fde482829896754225f5144" alt=""
在内声明密码auth 123456
data:image/s3,"s3://crabby-images/4d541/4d54117692414a6c68bcaee11272cdd3002b513e" alt=""
在外声明密码redis-cli -h 20.0.0.14 -p 6379 -a 123456
data:image/s3,"s3://crabby-images/43084/43084199d04c72863769cc10556f39c5b3ca4ea4" alt=""
data:image/s3,"s3://crabby-images/637a2/637a22cba7f00578d11d140bd499ff200e0376b8" alt=""
⑤删除当前库FLUSHDB(删库跑路!坐牢)
data:image/s3,"s3://crabby-images/cc8b8/cc8b85394e48729d847343d45dc0c96460f7a8b3" alt=""
⑥删除所有库FLUSHALL(删库跑路!坐牢)
data:image/s3,"s3://crabby-images/96e9c/96e9ce329e4f04a030f2805343f7f8ad09f34d93" alt=""
5、redis五大数据类型 【重点】
1) string 字符串 类型------string
默认类型,最大存储512MB的数据,可以存储任何数据,比如数字、文字、图片等
|---------------------------|---------------------------------------------|
| string字符串类型 ||
| 查看当前库的键值对 | KEYS * KEYS test KEYS t* KEYS t? KEYS t?? |
| 创建string类型的键值对 | set test guoqi |
| 查看键值对 | get test |
| 判断键是否存在(返回1代表存在;返回0代表不存在) | EXISTS test |
| 删除键 | del test1 test2 |
| 查看键的类型 | type test |
| 追加键值 | append test1 hello |
| 查看键的长度 | STRLEN test1 |
| 自增键值 自减键值 | INCR test1 decr test1 |
| 给键值增加/减少指定数值 | DECRBY test1 3 INCRBY test1 50 |
| 给键值设置过期时间 | SETEX test2 15 lo |
| 对已有键值对修改生命周期 | EXPIRE test 30 |
| 批量设置键值对 | MSET key1 hello key2 world |
| 批量打印多个键值对 | MGET key1 key2 |
| 对键重命名 | RENAME test guoqi |
①查看当前库的键值对KEYS test
data:image/s3,"s3://crabby-images/37438/37438472a628ebe2cf2573b6c84f8ad3d6b25f4a" alt=""
②创建键值对set test guoqi
③查看键值对get test
data:image/s3,"s3://crabby-images/a59db/a59dbdd21d23376c76aaef29a596de96092c843a" alt=""
data:image/s3,"s3://crabby-images/ad7a5/ad7a55190b14bff293eddfa6d19e9791456d3a39" alt=""
data:image/s3,"s3://crabby-images/e3e3e/e3e3e5853636ee4dd7dd146af506ccf5a361a23f" alt=""
④判断键值对test是否存在EXISTS test
data:image/s3,"s3://crabby-images/fd17f/fd17f8046e3ccbefa168c6f0886262909efdf1ad" alt=""
⑤删除键值对del test1 test2
data:image/s3,"s3://crabby-images/433d6/433d69e08e311f60191c37ca70332e563b47dece" alt=""
⑥查看键值对的类型type test
data:image/s3,"s3://crabby-images/7540e/7540e5bb59a965842744071bd063272b2f28a963" alt=""
⑦追加键值append test1 hello
键已存在,会追加到原有键值后,返回拼接后键值的长度
键不存在,会创建键,直接将键值写入,返回当前键值长度
data:image/s3,"s3://crabby-images/d8aa7/d8aa7fa81216f7504084bb645bd4c5b9c3fef16c" alt=""
data:image/s3,"s3://crabby-images/cd67a/cd67a031a23717d0bbb9ba6b98f303a872ab2b30" alt=""
⑧查看键值长度STRLEN test1
data:image/s3,"s3://crabby-images/591f2/591f20738173b9c0b1a49c2a35b5aaf4897295b3" alt=""
⑨自增键值INCR test1
自减键值 decr test1
注:只能对数字进行操作
data:image/s3,"s3://crabby-images/d65f3/d65f30c1b88075bdcc567c461dfcad5ab8302985" alt=""
⑩给键值增加/减少指定数值
DECRBY test1 3
INCRBY test1 50
data:image/s3,"s3://crabby-images/ceba3/ceba391fb2cb0ab07e2e26bba59dfb02c38b0a16" alt=""
⑪给键值设置过期时间 SETEX test2 15 lo
data:image/s3,"s3://crabby-images/20671/2067185d7c064a2871a480c1b764151c78c83ace" alt=""
-2表示键值对已过期
-1表示键值对永不过期
⑫对已有键值对修改生命周期EXPIRE test 30
data:image/s3,"s3://crabby-images/da123/da123ab28ced68ca1f7f4b95dcf980ea1e24dce1" alt=""
⑬批量设置键值对
MSET key1 hello key2 world
⑭打印多个键值对
duMGET key1 key2
data:image/s3,"s3://crabby-images/42eb4/42eb4d05a54337c20eec2148c1ab42c2d67677e5" alt=""
⑮对键重命名RENAME test guoqi
data:image/s3,"s3://crabby-images/5346a/5346a6af25102bb3ee08c971c45109a2698a443d" alt=""
2)list列表类型------string
列表中的元素是string类型
|--------------------------|-----------------------------------------------|
| list列表类型 ||
| 创建list类型的键值对 | lpush guoqi a b c d e f g |
| 查看键值对 | lrange guoqi 0 -1 |
| 查看某个键值对【下标索引】 | lindex guoqi1 0 |
| 查看1-2范围内的键值对 【下标索引,从0开始】 | lrange guoqi1 1 2 |
| 插入数值 | lpush guoqi1 10插入左侧 rpush guoqi1 20插入右侧 |
| 删除数值 | LPOP guoqi1 RPOP guoqi1 |
| 修改数值 | LSET guoqi1 3 shuai (根据下表索引,3代表下表索引) |
| 指定数值前插入 | LINSERT guoqi1 before 3 zhende (3代表数值,不是下表索引) |
①创建列表键值对
lpush guoqi a b c d e f g倒序
rpush guoqi a b c d e f g正序
data:image/s3,"s3://crabby-images/27283/272838218ffb65979f8605de7bd0ab1aadd9dce4" alt=""
data:image/s3,"s3://crabby-images/a1bc1/a1bc109ab790bbf7aaf8c50d881e12c282ea4fd2" alt=""
②查看某个键值对lindex guoqi1 0
data:image/s3,"s3://crabby-images/ab3a1/ab3a1a2a1b89db9068211db3df10383cc36857ba" alt=""
③查看1-2范围内的键值对lrange guoqi1 1 2
data:image/s3,"s3://crabby-images/e79f1/e79f13db2fcc971f4fcf88b00480dabe6f2b543a" alt=""
④插入数值
lpush guoqi1 10在左侧插入
rpush guoqi1 20在右侧插入
data:image/s3,"s3://crabby-images/98f6f/98f6f3dac6c288539e531159d1ac6bc127bed28b" alt=""
⑤删除数值
LPOP guoqi1
RPOP guoqi1
data:image/s3,"s3://crabby-images/e39c1/e39c13117054846d71c6e7441776fa8b1234306d" alt=""
⑥修改数值
LSET guoqi1 3 shuai(根据下表索引,3代表下表索引)
data:image/s3,"s3://crabby-images/d9799/d97995b951f394c313bbcdc30854732dfafea3b8" alt=""
⑦指定数值前插入LINSERT guoqi1 before 3 zhende(3代表数值,不是下表索引)
data:image/s3,"s3://crabby-images/ff2cf/ff2cff183781e3826f9f7420037c36c09c3c2b2f" alt=""
3 ) hash类型
hash类型用于存储对象,采用hash格式进行操作,占用磁盘空间少,一个hash类型可以存储4294967295个(42亿个)键值对
|--------------|---------------------------------------|
| hash类型 ||
| 创建hsah类型的键值对 | HSET guoqi2 tall yes(tall代表字段类型) |
| 查看键值对 | hget guoqi2 tall |
| 添加新字段 | hset guoqi2 tall yes |
| 删除字段 | hdel guoqi2 hansdon tall |
| 创建多个字段和数值 | hmset guoqi3 tall rich age 23 fcz yes |
| 查询字段 | hgetall guoqi3 |
| 直接查询字段及数值 | hkeys guoqi3 |
| 直接查询数值 | hvals guoqi3 |
| 删除键值对 | del guoqi3 |
①创建hsah类型的键值对
HSET guoqi2 tall yes
②添加新字段hset guoqi2 tall yes
data:image/s3,"s3://crabby-images/f57a7/f57a7e9712569ab694f2599b2e8968a2a87a5d05" alt=""
③查看多个字段的内容hmget info name address iphone
data:image/s3,"s3://crabby-images/e8092/e80923e07d99cec4860cb6183cf5e9c9d6ed69f7" alt=""
④删除字段 hdel info iphone
data:image/s3,"s3://crabby-images/b193f/b193f5cef33c54929fe24951b8e245abca69f4d8" alt=""
⑤创建多个字段和数值hmset guoqi3 tall rich age 23 fcz yes
data:image/s3,"s3://crabby-images/41f28/41f2882f392f5e7c943ec777939eab0edf43470a" alt=""
⑥查询字段及数值、直接查询字段、直接查询数值
hgetall guoqi3
hkeys guoqi3
hvals guoqi3
data:image/s3,"s3://crabby-images/3a3d1/3a3d105a6194ae6e9a3eb6f2b83020385e175893" alt=""
⑦删除键值对del guoqi3
data:image/s3,"s3://crabby-images/d2c83/d2c83da9671388aba83af93701aaff3f7e7a9679" alt=""
4 ) set 无序集合 类型------string
元素类型也是string,元素是唯一的,不允许重复,多个集合类型可以进行并集、交集、差集进行运算
使用场景:set中的元素类型是唯一的,可以跟踪一些唯一性数据,例如访问微博的用户名,只要把对应名称写入redis,set自动保存唯一性,方便下次访问
|----------------|-------------------|
| set无序集合类型 ||
| 创建set类型的键值对 | SADD myset a c |
| 查看成员 | SMEMBERS myset |
| 查看当前集合中的元素是否存在 | SISMEMBER myset a |
| 随机返回集合中的一个元素 | SRANDMEMBER myset |
| 随机移除 | SPOP myset |
| 指定移除 | SREM myset h k |
①创建set类型键值 SADD myset a c
data:image/s3,"s3://crabby-images/3b9ea/3b9eaa87a96609fba2644f73dc1e01d499696081" alt=""
②查看成员SMEMBERS myset
data:image/s3,"s3://crabby-images/524a1/524a185522365d87d6fa13cdaf6dc6631dc74989" alt=""
③查看当前集合中的元素是否存在SISMEMBER myset a
data:image/s3,"s3://crabby-images/ab72c/ab72c21e970a1d90b65181f102c82a85efaccb24" alt=""
④随机返回集合中的一个元素SRANDMEMBER myset
data:image/s3,"s3://crabby-images/abcdb/abcdb7044ade4ce6c228921bd307b705ef625d54" alt=""
⑤随机移除SPOP myset
data:image/s3,"s3://crabby-images/c9283/c92830f0cfb53ec9c473602ccf7e3213f6161e23" alt=""
⑥指定移除 SREM myset h k
data:image/s3,"s3://crabby-images/c4e85/c4e85a4a4392e8cfceb7ebc882e7b87cac6d6278" alt=""
5 ) zset 有序集合 类型------string
元素类型也是string,元素唯一,不能重复。每个元素都会关联一个double类型(小数点)的分数(score,表示权重),可以通过权重的大小进行排序,元素的权重可以相同
使用场景:在线积分的排行榜,实时更新用户的分数
zrange命令获取积分top10的用户,zrank命令通过username获取用户的排行信息
|-------------------|-------------------------------|
| zset 有序集合 类型 ||
| 创建zset类型的键值 | ZADD myzset 1 one |
| 查看元素和权重 | ZRANGE myzset 0 -1 withscores |
| 查看成员的权重 | ZSCORE myzset two |
| 查询成员数量 | ZCARD myzset |
| 统计权重在1~2范围内的成员数量 | ZCOUNT myzset 1 2 |
| 删除成员 | ZREM myzset three |
| 获取位置索引 | ZRANK myzset one |
①创建zset类型的键值ZADD myzset 1 one
data:image/s3,"s3://crabby-images/db7bf/db7bf1d11c47e603549309dc71c83c4503bf0027" alt=""
②查看元素和权重ZRANGE myzset 0 -1 withscores
data:image/s3,"s3://crabby-images/8b48f/8b48fc10ab020ffc4f652996b749b2c23fcae03d" alt=""
③查看成员的权重ZSCORE myzset two
data:image/s3,"s3://crabby-images/45778/45778db7687f7850dc1d91c1591881879837fd96" alt=""
④获取位置索引 ZRANK myzset one
data:image/s3,"s3://crabby-images/ebbdd/ebbdd73355206a144c6a68956390dff00984d5fa" alt=""
⑤查询成员数量ZCARD myzset
data:image/s3,"s3://crabby-images/289fd/289fdb5a4c7aedd6755cf32c6acb7953d44144bf" alt=""
⑥统计权重在1~2范围内的成员数量ZCOUNT myzset 1 2
data:image/s3,"s3://crabby-images/44aac/44aac70d845acad58e8877a06547a8b70209e0d5" alt=""
data:image/s3,"s3://crabby-images/93471/93471ee9723e7266a74286390919a634bfff1fd5" alt=""
⑦删除成员ZREM myzset three
data:image/s3,"s3://crabby-images/9c295/9c295fa840253094850855800118d3e52274b855" alt=""
6、普通类型set和hash类型hset该如何选择?
一般情况下,无特殊需求时,普通创建方式即可;但对一个键值进行多字段存储及节省内存可以使用hash方式