redis学习之redis的安装和简介

本文涉及的产品
云原生内存数据库 Tair,内存型 2GB
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Redis 版,经济版 1GB 1个月
简介: redis简介Redis是一个开源的,高性能的,基于键值对的缓存与存储系统,通过设置各种键值数据类型来适应不同场景下的缓存与存储需求。同时redis的诸多高层级功能使其可以胜任消息队列,任务队列等不同角色。

redis简介

Redis是一个开源的,高性能的,基于键值对的缓存与存储系统,通过设置各种键值数据类型来适应不同场景下的缓存与存储需求。同时redis的诸多高层级功能使其可以胜任消息队列,任务队列等不同角色。

存储结构

Redis是REmote Dictionary Server(远程字典服务器)的缩写,它以字典结构存储数据,并允许其他应用通过TCP协议读写字典中的内容,目前为止redis支持的键值数据类型如下:字符串类型,散列类型,列表类型,集合类型,和有序集合类型。其中一个字符串类型键值允许存储的数据最大容量为521M.

内存存储与持久化

Redis数据库中的所有数据都存储在内存中。在一台普通的笔记本电脑上,Redis可以在一秒内读写超过10万个键值。
数据存储在内存也有问题比如断电。redis还提供了持久化的存储,既可以将内存的数据异步写入应哦按,同时不影响继续
提供服务。

功能丰富

Redis可以为每个键设置生存时间,生存时间到后期会自动删除,这一功能可以利用redis作为缓存系统来调用。
除此之外,redis的列表类型键可以用来实现队列,并且支持阻塞式读取,可以容易地实现一个高性能的优先级队列,同时在更高层上,redis还支持"发布/订阅"的消息模式,可以基于此构建聊天室。

redis的安装

参考windows安装redis

redis命令行客户端

通过redis-cli向redis发送命令,

通过-h和-p自定义地址和端口号
$redis-cli -h 127.0.0.1 -p 6379

通过ping命令测试连接是否正常

$redis-cli PING
####状态回复
PONG
####错误回复
如果上述命令不存在或者存在格式错误,会返回以error开头的错误。如
reids>ERRORCOMMEND
输出
(error)ERR unknow command 'ERRORCOMMEND'

获取先输入redis-cli进入交互模式,然后自由输入命令,例如PING.

整数回复

返回递增后的键值,类似mysql最后的索引值

依次执行以下命令
redis-cli
127.0.0.1:6379set foot bar
OK
127.0.0.1:6379INCR foo
(integer) 1
127.0.0.1:6379set foot bar
OK
127.0.0.1:6379INCR foo
(integer) 2

可以看到每次插入一条数据返回值都跟着变化。

字符串回复

127.0.0.1:6379set foot bar
OK
127.0.0.1:6379get foo
"bar"
127.0.0.1:6379set foo banana
OK
127.0.0.1:6379get foo
"banana"
127.0.0.1:6379>

可以看到get命令可以获取foo的最新的键值。

字符串多行回复

127.0.0.1:6379> KEYS *
1"proxies"
2"foo"
3"foot"

返回键名1是我之前执行的,3是之前foo打错了执行的。keys命令需要便利redis中的所有键,当键的数量较多时会影响性能,不建议生产环境中使用。

多行数据库

redis提供了多个来存储数据的字典,每个字典类型mysql的数据量,每个数据库对外都是以0开始递增,redis默认支持16个数据库,客户端连接到服务端时,redis默认使用0进行操作数据库,使用select可以根据数据库。比如选择1号数据库:

redis-cli
127.0.0.1:6379select 1
OK
127.0.0.1:6379[1]get foo
(nil)
127.0.0.1:6379[1]>

redis不支持自定义数据库的名字,每个数据库必须以编号命名。比如可以使用0号数据库存储某个应用生产环境的数据,1号数据库存储测试环境中的数据,需要注意的是不同的应用应该使用不同的redis实例redis也不支持为每个数据库设置不同的访问密码。
最重要的是redis实例中所有数据库的数据并不是完全隔离的,比如FLUSHALL可以清空一个redis实例中所有数据库中的数据。。由于redis非常轻量级,一个空的redis实例占用内存只有1MD左右,所以不用担心多个redis实例会额外占用很多内存。

几个基础命令

1.keys 见上面的例子

2.判断一个键是否存在

exists key 如果存在返回1 ,不存在返回0

0.0.1:6379exists foo
(integer) 1
127.0.0.1:6379exists foo2
(integer) 0
127.0.0.1:6379exists foot
(integer) 1
127.0.0.1:6379>

3.删除键

del key [key …]
可以删除一个或者多个空格间隔,返回值是删除的个数。del命令不支持通配符。

127.0.0.1:6379set f1 1
OK
127.0.0.1:6379set f3 1
OK
127.0.0.1:6379set f2 1
OK
127.0.0.1:6379keys *
1) "key"
2) "f1"
3) "proxies"
4) "f2"
5) "foot"
6) "foo"
7) "f3"
127.0.0.1:6379del f1
(integer) 1
127.0.0.1:6379del f2 f3
(integer) 2
127.0.0.1:6379>

3.获取键值的数据类型
type key
type命令用来获取键值类型,返回值可能是string,hash,list,set,zset(有序集合)。

127.0.0.1:6379set test 1
OK
127.0.0.1:6379type test
string
127.0.0.1:6379lpush test2 2
(integer) 1
127.0.0.1:6379type test2
list
127.0.0.1:6379>

lpush命令是向指定的列表类型键中增加一个元素,如果不存在则创建。后面详解。

读取键值

get key
根据键获取其值。

127.0.0.1:6379get fo
(nil)
127.0.0.1:6379get foo
"banana"
127.0.0.1:6379>

不存在的时候返回nil.

递增数字

INCR key

增加指定的整数

INCRBY key increment
incrby和incr命令效果差不多,区别是incrby可以指定增加的数字

127.0.0.1:6379incrby bar 2
(integer) 2
127.0.0.1:6379incrby bar 5
(integer) 7
127.0.0.1:6379incr bar
(integer) 8
127.0.0.1:6379incr bar
(integer) 9
127.0.0.1:6379>

增加指定的浮点数

incrbyfloat key inrement
这个命令类似上面两个只不过是可以传递一个浮点数而已

127.0.0.1:6379incrbyfloat bar 3.14
"12.140000000000001"
127.0.0.1:6379incrbyfloat bar 3.14e+9
"3140000012.1399999"
127.0.0.1:6379>

减少指定的整数

有增加就有减少
decr和decrby和增加的用法一样,只不过是键值递减。
decrby key 4相当于incrbu key -4

向尾部追加值

向键值的末尾加字符串,如果不存在就是相当于set key value

127.0.0.1:6379append bar "345"
(integer) 21
127.0.0.1:6379get bar
"3140000012.1399999345"
127.0.0.1:6379>
127.0.0.1:6379append asd "hello dj"
(integer) 8
127.0.0.1:6379get asd
"hello dj"
127.0.0.1:6379>

获取字符串长度

STRLEN key
返回键值长度,不存在返回0.

127.0.0.1:6379set key "￀￷ᄎᆭ"
OK
127.0.0.1:6379strlen key
(integer) 4
127.0.0.1:6379set key "ᅣ ̄채"
OK
127.0.0.1:6379strlen key
(integer) 4
127.0.0.1:6379>

同时设置多个键值

Mget key/mset key value
mget/mset和get/set相似,前者可以获取/设置多个值。

(integer) 4
127.0.0.1:6379mget bar foo
1) "3140000012.1399999345"
2) "banana"
127.0.0.1:6379mset a 1 b 2
OK
127.0.0.1:6379>

位操作

getbit key offset
setbit key offset value
bitcount key [start][end]
bitop operation destkey key [key ….]
一个字节由8个二进制位组成,redis提供了以上四个命令可以直接对二进制进行操作。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
25天前
|
存储 NoSQL Redis
Redis系列学习文章分享---第十六篇(Redis原理1篇--Redis数据结构-动态字符串,insert,Dict,ZipList,QuickList,SkipList,RedisObject)
Redis系列学习文章分享---第十六篇(Redis原理1篇--Redis数据结构-动态字符串,insert,Dict,ZipList,QuickList,SkipList,RedisObject)
46 1
|
25天前
|
NoSQL Java Redis
Redis系列学习文章分享---第十八篇(Redis原理篇--网络模型,通讯协议,内存回收)
Redis系列学习文章分享---第十八篇(Redis原理篇--网络模型,通讯协议,内存回收)
39 0
|
25天前
|
存储 消息中间件 缓存
Redis系列学习文章分享---第十七篇(Redis原理篇--数据结构,网络模型)
Redis系列学习文章分享---第十七篇(Redis原理篇--数据结构,网络模型)
38 0
|
18天前
|
NoSQL Java Redis
软件开发常见流程之宝塔初始化安装环境配置,Lam前面不选,直接跳商城,在宝塔内点击软件商城,安Mysql5.7,安java项目管理器,安Ngnix最新版,安Redis
软件开发常见流程之宝塔初始化安装环境配置,Lam前面不选,直接跳商城,在宝塔内点击软件商城,安Mysql5.7,安java项目管理器,安Ngnix最新版,安Redis
|
21天前
|
存储 消息中间件 缓存
apt安装Redis 7
【7月更文挑战第2天】
|
25天前
|
存储 NoSQL 安全
Redis系列学习文章分享---第十五篇(Redis最佳实践--设计优雅的key+合适的数据结构+持久化如何配置+慢查询问题解决)
Redis系列学习文章分享---第十五篇(Redis最佳实践--设计优雅的key+合适的数据结构+持久化如何配置+慢查询问题解决)
34 1
|
25天前
|
缓存 负载均衡 NoSQL
Redis系列学习文章分享---第十四篇(Redis多级缓存--封装Http请求+向tomcat发送http请求+根据商品id对tomcat集群负载均衡)
Redis系列学习文章分享---第十四篇(Redis多级缓存--封装Http请求+向tomcat发送http请求+根据商品id对tomcat集群负载均衡)
40 1
|
25天前
|
存储 缓存 NoSQL
Redis系列学习文章分享---第十三篇(Redis多级缓存--JVM进程缓存+Lua语法)
Redis系列学习文章分享---第十三篇(Redis多级缓存--JVM进程缓存+Lua语法)
42 1
|
18天前
|
NoSQL Linux Redis
redis的安装和配置
redis的安装和配置
51 0
|
18天前
|
NoSQL Redis Windows
redis双击闪退解决方法,windows版的redis资源,redis安装,win资源可下
redis双击闪退解决方法,windows版的redis资源,redis安装,win资源可下