目录
[一.SQL 与 NoSQL 的区别?](#一.SQL 与 NoSQL 的区别?)
[Redis 为什么那么快?](#Redis 为什么那么快?)
[redis-cli 命令行工具:](#redis-cli 命令行工具:)
[redis-benchmark 测试工具:](#redis-benchmark 测试工具:)
[四.Redis 数据库常用命令](#四.Redis 数据库常用命令)
一.SQL 与 NoSQL 的区别?
SQL:二维表格结构,纵向扩展(提升单机硬件性能),基于ACID原则,事务控制更稳定,细粒度更高,典型代表 :MySQL,SQL-Server
NoSQL:不固定的,通常存储在数据集中(比如键值对、文档、索引、图形结构、时间序列等),横向扩展(增加服务器节点数量),基于BASE原则,稳定性和细粒度控制方面不如SQL,典型代表 :Redis Memcached。
二.Redis
Redis :是 C语言开发的,开源的,基于内存运行的NoSQL。
数据存储结构 键值对(Key/Value KV)
默认端口号 TCP/6379
数据类型: 五大基础类型 String(字符串) List(列表) Hash(哈希/散列) Set(无序集合) Zset/Sorted Set(有序集合)
Redis 为什么那么快?
1)redis是基于内存运行的,数据读写都是在内存中完成的
2)数据读写采用单线程模式,避免了多线程切换带来的CPU性能消耗,同时也不要考虑各种锁的问题
3)采用IO多路复用模型,可以使线程处理更多的网络连接请求,提高并发能力
网站性能压测工具 :ab jmeter
redis 性能压测工具 : redis-benchmark -h <redis服务地址> -p <服务端口> -a <密码> -c <并发连接数> -n <请求数> -d <数据大小> -t <命令列表> -q
redis 客户端工具 : redis-cli -h <redis服务地址> -p <服务端口> -a <密码> [命令]
三.Redis的安装
开启一台服务器,修改内核配置文件:
data:image/s3,"s3://crabby-images/5d0e1/5d0e18142dd4aee41f017c02db0d93892eb8ccb2" alt=""
data:image/s3,"s3://crabby-images/738e6/738e6059cc980a528b3d952fd00c1de026a73471" alt=""
data:image/s3,"s3://crabby-images/6d08c/6d08cbccfa8ee32136f7b6e86dddceac2d5a0163" alt=""
安装redis:
data:image/s3,"s3://crabby-images/f4e57/f4e5785a983ab8d76b5d590118ba96025a0c6255" alt=""
data:image/s3,"s3://crabby-images/dd050/dd05086045efcb9a5b5be1bf040eab4c39ef19eb" alt=""
data:image/s3,"s3://crabby-images/77401/7740131ae57aedb3c7d30574bcad534b2f960333" alt=""
创建redis工作目录:
data:image/s3,"s3://crabby-images/f2539/f2539bd0c911e4806e2279f07577fc13fd2ef1cc" alt=""
复制配置文件:
data:image/s3,"s3://crabby-images/76a8a/76a8a8093874bdc812d96d1319bf8cce89386a3e" alt=""
创建用户redis:
data:image/s3,"s3://crabby-images/dffa0/dffa0675819b1d90c8e27de9c4c730cade98f333" alt=""
给redis目录下的所有目录添加权限:
data:image/s3,"s3://crabby-images/b2dbf/b2dbfd4d20a50d639f47fefa7e334dda43f2d116" alt=""
data:image/s3,"s3://crabby-images/dcc99/dcc99e28d8d5d385be6bdb92ca01fa097c6f6347" alt=""
添加环境变量:
data:image/s3,"s3://crabby-images/a03ee/a03eee990c50fd5ebdf1928a55af405dca481840" alt=""
data:image/s3,"s3://crabby-images/dff47/dff47d9ff20bc2b6c8a80c939838b8a2230bde43" alt=""
data:image/s3,"s3://crabby-images/f56cc/f56cc2fea01b25cc9dcd18e942a2c83fdd9d09cf" alt=""
修改redis配置文件:
添加监听主机:
data:image/s3,"s3://crabby-images/39a85/39a857466c0aeb82d86e3534dcf2639c9f520e0d" alt=""
将本机访问保护模式设置no:
data:image/s3,"s3://crabby-images/60d6f/60d6f16c97a51cefef4337c9404728c270190140" alt=""
设置为守护进程,后台启动:
data:image/s3,"s3://crabby-images/fb183/fb18304a1cc4b2ab4b2c95406fd46d63ac3f7e9f" alt=""
指定 PID 文件:
data:image/s3,"s3://crabby-images/39363/39363eab102ea0a6571d6841c6abba1bbc1654ed" alt=""
指定日志文件:
data:image/s3,"s3://crabby-images/7df6a/7df6a49c3e0a39c3c94b1f0ba632f0ae589f1dc1" alt=""
指定持久化文件所在目录:
data:image/s3,"s3://crabby-images/5492f/5492fa8469a0cad4be776bde91935d26798b56a9" alt=""
增加一行,设置redis密码:
data:image/s3,"s3://crabby-images/a5ae5/a5ae5f5894418fc7f28fa40f3cd6e8f858212221" alt=""
开启服务:
data:image/s3,"s3://crabby-images/a1d41/a1d41d4b2dfde776a7cd9ee6ca458bc6de6d8a37" alt=""
定义systemd服务管理脚本开启服务:
data:image/s3,"s3://crabby-images/88f14/88f14ca898cd2551d6554d55ff865b4e21f52363" alt=""
data:image/s3,"s3://crabby-images/17920/179209af6db98c7d8f3ae017e5bb091a8453cb0c" alt=""
data:image/s3,"s3://crabby-images/1208e/1208ec8db3994763e03cfb91c1bd396b0b5eb59f" alt=""
需要授权:
data:image/s3,"s3://crabby-images/c2149/c21494e1b9fd03f0ba90ce0f7c14d0333be1911d" alt=""
data:image/s3,"s3://crabby-images/8a382/8a3822597aca4f9b5495d6d48db8b8f46c91ef9a" alt=""
开启服务:
data:image/s3,"s3://crabby-images/86eff/86eff290ca04da204ea4a1a8dbda972178612a85" alt=""
Redis 命令工具 :
redis-server:Redis 服务器启动命令
redis-benchmark:性能测试工具,用于检测 Redis 在本机的运行效率
redis-check-aof:修复有问题的 AOF 持久化文件
redis-check-rdb:修复有问题的 RDB 持久化文件
redis-cli:Redis 客户端命令行工具
redis-sentinel:Redis 哨兵集群使用
redis-cli 命令行工具:
语法:redis-cli -h host -p port [-a password]
-h :指定远程主机
-p :指定 Redis 服务的端口号
-a :指定密码,未设置数据库密码可以省略-a 选项
若不添加任何选项表示,则使用 127.0.0.1:6379 连接本机上的 Redis 数据库
redis-benchmark 测试工具:
基本的测试语法:redis-benchmark [选项] [选项值]
-h :指定服务器主机名。
-p :指定服务器端口。
-s :指定服务器 socket
-c :指定并发连接数。
-n :指定请求数。
-d :以字节的形式指定 SET/GET 值的数据大小。
-k :1=keep alive 0=reconnect 。
-r :SET/GET/INCR 使用随机 key, SADD 使用随机值。
-P :通过管道传输<numreq>请求。
-q :强制退出 redis。仅显示 query/sec 值。
--csv :以 CSV 格式输出。
-l :生成循环,永久执行测试。
-t :仅运行以逗号分隔的测试命令列表。
-I :Idle 模式。仅打开 N 个 idle 连接并等待。
redis-benchmark 是官方自带的 Redis 性能测试工具,可以有效的测试 Redis 服务的性能。
进行测试:
data:image/s3,"s3://crabby-images/5dadb/5dadb969f07861e101770e12fc6a62ea65dae7cf" alt=""
四.Redis 数据库常用命令
keys *:看所有键
data:image/s3,"s3://crabby-images/c2c0a/c2c0a08e0cbb5943649837e50bc4429f52b2b795" alt=""
select 序号:多数据库间切换
data:image/s3,"s3://crabby-images/c67b4/c67b4d9132aa5f9f7cf4428e402c44811f2fa866" alt=""
多数据库间移动数据:move 键值 序号
data:image/s3,"s3://crabby-images/abf3a/abf3a29cb1332cb6495e9b206468295569832013" alt=""
清除数据库内数据(慎用):flushdb
data:image/s3,"s3://crabby-images/e266f/e266fe7ba2885ae5ed15f889bd724417d7765321" alt=""
清空所有库(慎用):flushall
data:image/s3,"s3://crabby-images/f297e/f297e1acb3d5d2ebac0d2bba026dca8b0ab39fa8" alt=""
data:image/s3,"s3://crabby-images/e99b0/e99b087da731486ec33429cde84378dd8e72f16f" alt=""
string(字符串)数据类型:
set 键 值:创建键
get 键:查看值
data:image/s3,"s3://crabby-images/36545/36545ffc6805871243a7ac6e5a55664c7a314a57" alt=""
del 键:删除键
data:image/s3,"s3://crabby-images/e2b6c/e2b6cae534532198e145841ec985ff7bd94f177c" alt=""
data:image/s3,"s3://crabby-images/9f398/9f398fbe1fda2d145af9b3e04fce8011888889d8" alt=""
exists 键 判断该键是否存在,存在返回1,否则返回0:
set命令为键设置新值,并覆盖原有值:
data:image/s3,"s3://crabby-images/a8956/a8956f07deeb4e55c17dcf60bf5ef8af346aa087" alt=""
strlen 键 :获取指定Key的字符长度
data:image/s3,"s3://crabby-images/cc274/cc27412135fea4703f9d665f8ec86bddcab37d71" alt=""
定义值:
data:image/s3,"s3://crabby-images/e2dd4/e2dd4443f67bb76a91d8781e60f9da2ceaf0bed4" alt=""
incr 键:Key的值递增1
data:image/s3,"s3://crabby-images/4fbea/4fbea7127cb031b438e00061eb1dc9ea4d964327" alt=""
decr 键:Key的值递减1
data:image/s3,"s3://crabby-images/329b1/329b1bcf7303ba98609e6b11c07388af4b6abf4b" alt=""
decrby 键 数字:减少指定的整数
data:image/s3,"s3://crabby-images/882f4/882f4d174a8a821fcdb7432232c8f88e37972645" alt=""
incrby 键 数字:增加指定的整数
data:image/s3,"s3://crabby-images/9f7ca/9f7ca035f28393b4a8510866d741b4e967ee88e9" alt=""
setex 键 秒数 值:指定Key的过期时间为多少秒。
data:image/s3,"s3://crabby-images/54c68/54c683a9763e33c55d6b762a31aea7a268d6728d" alt=""
data:image/s3,"s3://crabby-images/b4f1a/b4f1a5e8000b83a810b6f7c68a0dfb046c0967c6" alt=""
setnx 键 值 :键不存在,因此setnx命令执行成功,反馈1
data:image/s3,"s3://crabby-images/4a41d/4a41d00acdb77f42fdc286194ba47e8ef207a1dd" alt=""
mset 键1 值1 键2 值2 ......: 批量设置多个键
mget 键1 键2:批量获取键的值
data:image/s3,"s3://crabby-images/936e0/936e0b8c6bc4284c85176829e9f17d9abac49921" alt=""
msetnx 键1 值1 键2 值2 ....:批量设置键,键不存在执行成功并返回1
data:image/s3,"s3://crabby-images/126b2/126b26a13f6a1a84b60b2ad45040178af4abda4c" alt=""
键存在,返回0,由于key5没有设置成功,所以返回nil:
data:image/s3,"s3://crabby-images/29426/2942645db571a8745dff2e0666c86595c823da26" alt=""
List(列表)数据类型:
lpush 键 值1 值2 .... :创建list类型键,将参数从左到右依次插入
data:image/s3,"s3://crabby-images/56691/566916fd19f2468984124f8b064d0df286f68546" alt=""
lrange 键 起始下标 终止下标: 0(第一个) -1(最后一个)
data:image/s3,"s3://crabby-images/61e7d/61e7dd087cf6233b4a8b6c6a72714994a0ab5409" alt=""
lpushx 键 值1 值2 ....:键不存在则不创建不成功,返回0
data:image/s3,"s3://crabby-images/a7e90/a7e90ec9da432242520a40c4fe8b5e23fda30495" alt=""
lpop 键:移除并返回键的第一个元素,从左取
data:image/s3,"s3://crabby-images/47df4/47df4894d6f66016468f892e70052bcb5588ea9a" alt=""
llen 键:在执行lpop命令两次后,键值两个元素已经被弹出
data:image/s3,"s3://crabby-images/dc994/dc99449b1ab52b03aed0eda7cdf88448167e2558" alt=""
lrem 键 数值 已有值 :从头部(left)向尾部(right)变量链表,删除值,返回值为实际删除的数量。
data:image/s3,"s3://crabby-images/cc870/cc8709ab5b7c433629b1125c008cdb60a3fcb692" alt=""
lindex 键 数字:获取指定值
data:image/s3,"s3://crabby-images/1d228/1d228a43f6bf655fccde5bd60fcfc5427873c495" alt=""
lset 键 下标数字 新值:将下标的值,设为数值
data:image/s3,"s3://crabby-images/84fc5/84fc55a4ea96d91f5e3aed7b6310051f5cdf21e7" alt=""
linsert 键 before 已有值 新值:在已有值前添加新值
data:image/s3,"s3://crabby-images/7d4e6/7d4e67d724d18655510d3b63cac6573259700de6" alt=""
linsert 键 after 已有值 新值:在已有值后添加新值
data:image/s3,"s3://crabby-images/e870d/e870d6e7fe18ad4d32876ce12823c5f1355c93a9" alt=""
rpush 键 值1 值2 ...: 插入参数,插入顺序是从右到左依次插入
data:image/s3,"s3://crabby-images/fdb89/fdb89efdd87bf1ae39fcaadc6a86e08c439b3e32" alt=""
rpushx 键 新值:在键尾部插入新值
data:image/s3,"s3://crabby-images/5f155/5f1558fbbecd0c4de782320aeffdd8518bd06d7c" alt=""
rpop 键 :移除并返回键的第一个值,从右取
data:image/s3,"s3://crabby-images/322b8/322b817e5496a44ff71f0e531d8305ee5fdaff5f" alt=""
rpoplpush 键1 键2 : 将键1的尾部值移除,并插入到键2的开头
hash(散列)数据类型:
hset 键 字段1 值1 字段2 值2 ....:设置键
data:image/s3,"s3://crabby-images/482aa/482aafb6b23707176ce9b669bbe98a13559a482b" alt=""
data:image/s3,"s3://crabby-images/2efcb/2efcb395434db2ed04ca133f611441cc04a4eda4" alt=""
hlen 键:获取h键的字段数量
data:image/s3,"s3://crabby-images/0d897/0d89735a74ff27143d45a1f37ea6d91f52e0a46c" alt=""
hexists 键 字段:看键中字段是否存在,存在返回1,不存在返回0
data:image/s3,"s3://crabby-images/96e1e/96e1eb799994e72ecd3f5022e5a2d4b6be70ca2b" alt=""
hdel 键 字段:删除键中的字段
data:image/s3,"s3://crabby-images/fcc12/fcc12085b7f013d961ec3ab46e37e8c22a8e4fc1" alt=""
hsetnx 键 字段 值:给键重新添加字段和值,字段不存在返回1,字段存在返回0
data:image/s3,"s3://crabby-images/e54d9/e54d9897212bed0eeca1654dd83e4fb0347a4e22" alt=""
data:image/s3,"s3://crabby-images/39569/39569461add3c455f2764ac397a438b98e902731" alt=""
hincrby 键 字段 正数:给字段值加上正数值
data:image/s3,"s3://crabby-images/5c278/5c278bcc42a68e0ff576c51ae68a1c0d519a5d95" alt=""
hincrby 键 字段 负数:给字段值减数值
data:image/s3,"s3://crabby-images/7ea7e/7ea7e9140e29047f668598e39d553689f3e6c01e" alt=""
hmset 键 字段1 值1 字段2 值2 ....:一次性设置多个字段,显示没有设置的字段值为nil
data:image/s3,"s3://crabby-images/61351/6135120bc1a7b369a5a75964e8497c3ef6a1019a" alt=""
hgetall 键:查看键的字段和值
data:image/s3,"s3://crabby-images/1ec4b/1ec4b8ed8dfbe85607df98b8115d364ee039b8dc" alt=""
hkeys 键 :查看键的所有字段
data:image/s3,"s3://crabby-images/63fc7/63fc7ee4369458c65db6d329d97c848031b7f02d" alt=""
hvals 键:查看键的所有字段的值
data:image/s3,"s3://crabby-images/91ee4/91ee408270b56a43dbdabc2ab14f80e894d77d4b" alt=""
Set数据类型(无序集合)
sadd 键 值1 值2 值3 ....:创建键
data:image/s3,"s3://crabby-images/bc2e3/bc2e32e37222d89b5d1baa7ce8f3e034c21a9a34" alt=""
sismember 键 值:判断值是否存在,存在返回1,不存在返回0
data:image/s3,"s3://crabby-images/adbcc/adbcc496dee07f5452ff2dfb8ec3858453a013f3" alt=""
smembers 键 :查看键无顺序显示
data:image/s3,"s3://crabby-images/50b8a/50b8a7d49f8c38ff71b4ac88cb3d3261caa95c97" alt=""
scard 键:查看键值的数量
data:image/s3,"s3://crabby-images/b6d28/b6d28c8cad06ee0d292f3219e56f66ac0b0168bc" alt=""
srandmember 键:随机返回键的值
data:image/s3,"s3://crabby-images/5adbd/5adbdf6f628820c032a73dcd8256495642a3a9b7" alt=""
spop 键:随机的移除并返回的值
data:image/s3,"s3://crabby-images/e4507/e4507774fb60bbfe0674f5810aec2fcbb78fa775" alt=""
srem 键 值1 值2..:移除键的值,如有不存在的值则只返回存在值的总数
data:image/s3,"s3://crabby-images/70d38/70d38f8ea2f6ce15174d579a0f5fdb993b983930" alt=""
smove 键1 键2 键1的值:将键1的值移动到键2上,返回1成功,0失败
data:image/s3,"s3://crabby-images/f4451/f44515c863dcccf8731fc45f677ba2ae6837aa86" alt=""
data:image/s3,"s3://crabby-images/b8992/b8992779d85f333cc9f9b07501a4ec5930e4fb25" alt=""
zset(有序集合)数据类型:
zadd 键 字段 '值':创建zset数据类型键
data:image/s3,"s3://crabby-images/c0c9e/c0c9e3c4ea63500acdd161baab50fb7ddc8e16bd" alt=""
zrange 键 起始下标 末尾下标 withscores:查看键值 ,withscores选项表示返回的结果中包含字段值
data:image/s3,"s3://crabby-images/2cd26/2cd26a172e94199afe2ce55a08a41f2a34c2d852" alt=""
zrank 键 值:查看值的下标
data:image/s3,"s3://crabby-images/f66e4/f66e444a8dfce0253c86c80193f5b3d5cfd7ca24" alt=""
当值不存在返回nil:
data:image/s3,"s3://crabby-images/9189c/9189cd32ca49327f00f58f4d1e976fa18c0bbc32" alt=""
zcard 键:查看键的值数量
data:image/s3,"s3://crabby-images/972f8/972f8e46605ffa074cb89438a242f36bca60a5da" alt=""
zrem 键 值1 值2 ...:删除值
data:image/s3,"s3://crabby-images/aca97/aca97aee4c9f58fb50190b9189bb66880b828341" alt=""
data:image/s3,"s3://crabby-images/ee27d/ee27d3a743672b76ef15580cb7a639c92639ee3a" alt=""
zscore 键 字段:查看字段值
data:image/s3,"s3://crabby-images/b74bd/b74bdc6f1d02e959b6e6639a8ebde22e37fa44be" alt=""
查看没有的字段返回nil:
data:image/s3,"s3://crabby-images/29cda/29cda92ad276e97d9a1e30be0b39faaf9cd57d8e" alt=""
zincrby 键 正数 值:将值加为上数
data:image/s3,"s3://crabby-images/bc9b7/bc9b7daada3d30329dd318f69b3e9a5528c7278d" alt=""
zincrby 键 负数 值:将值减去数
data:image/s3,"s3://crabby-images/946c4/946c4c15686fc2a11ee36fc049a0645350c9c569" alt=""
zrangebyscore 键 开始下标 结尾下标:看键的最小值和最大值
data:image/s3,"s3://crabby-images/208e9/208e93c29bd6a17e10411abe2465b711a5869f8c" alt=""
zrangebyscore 键 (开始下标 结尾下标:看键的最大值,不包括最小值
data:image/s3,"s3://crabby-images/421fb/421fb91141cf84900c0d55750dede6d6de46c49e" alt=""
zrangebyscore 键 -inf +inf limit 最小值 最大值:-inf表示第一个(位置索引值最低的,即0),+inf表示最后一个(位置索引值最高的)limit后面的参数用于限制返回值,从索引值为2开始往后取3个值。
data:image/s3,"s3://crabby-images/8e123/8e1236699ea4b85f1390fbbd10ede1696428ff3d" alt=""
zremrangebyscore 键 开始下标 结尾下标:删除下标最小的和最大的值
data:image/s3,"s3://crabby-images/f1306/f1306029d7b48566e827b828e7dc76775262c719" alt=""
data:image/s3,"s3://crabby-images/bd5b0/bd5b054a89c1333ac8cdb0d23532afeff9c567de" alt=""
zrevrange 键 开始下标 结尾下标 withscores:查看键的字段和开始值到结尾值
data:image/s3,"s3://crabby-images/7d681/7d681b68e62d22c4216c72e4aeffe8cea0f35b9e" alt=""
zrevrank 键 值:从高到低的排序,返回键值的下标
data:image/s3,"s3://crabby-images/19612/196126ae905a58ae1182024b629213a9131413c4" alt=""
zrevrangebyscore 键 数字 数字 limit 数字 数字: 从高到底的顺序输出。
data:image/s3,"s3://crabby-images/1a00a/1a00a41975823fe5ec423e2c7a336abe0bd35aff" alt=""
zrevrangebyscore 键 +inf -inf limit 数字 数字:查看键的值