redis学习和使用
概述
Redis是一个开源的,基于内存的数据结构存储,可用作于数据库、缓存、消息中间件。
Redis是基于内存,常用作于缓存的一种技术,并且Redis存储的方式是以key-value的形式。
我们可以发现这不就是Java的Map容器所拥有的特性吗,那为什么还需要Redis呢?
- Java实现的Map是本地缓存,如果有多台实例(机器)的话,每个实例都需要各自保存一份缓存,缓存不具有一致性
- Redis实现的是分布式缓存,如果有多台实例(机器)的话,每个实例都共享一份缓存,缓存具有一致性。
- Java实现的Map不是专业做缓存的,JVM内存太大容易挂掉的。一般用做于容器来存储临时数据,缓存的数据随着JVM销- 毁而结束。Map所存储的数据结构,缓存过期机制等等是需要程序员自己手写的。
- Redis是专业做缓存的,可以用几十个G内存来做缓存。Redis一般用作于缓存,可以将缓存数据保存在硬盘中,Redis重启了后可以将其恢复。原生提供丰富的数据结构、缓存过期机制等等简单好用的功能。
Redis的数据结构
Redis支持丰富的数据结构,常用的有string、list、hash、set、sortset这几种。
首先还是得声明一下,Redis的存储是以key-value的形式的。Redis中的key一定是字符串,value可以是string、list、hash、set、sortset这几种常用的。
Redis并没有直接使用这些数据结构来实现key-value数据库,而是基于这些数据结构创建了一个对象系统:Redis使用对象来表示数据库中的键和值。每次我们在Redis数据库中新创建一个键值对时,至少会创建出两个对象。一个是键对象,一个是值对象。
string–>简单的key-value
list–>有序列表(底层是双向链表)–>可做简单队列
set–>无序列表(去重)–>提供一系列的交集、并集、差集的命令
hash–>哈希表–>存储结构化数据
sortset–>有序集合映射(member-score)–>排行榜
使用docker启动redis
wangzheng@wangzheng-ubuntu:~$ docker run -p 6379:6379 -v /home/wangzheng/myredis/data/:/data -v /home/wangzheng/myredis/conf/redis.conf/:/usr/local/etc/redis/redis.conf -d redis:3.2 redis-server /usr/local/etc/redis/redis.conf --appendonly yes
89862b9b3ee12751d28ec2ea8ea96bface7339754a989784721118a6a2d2853b
wangzheng@wangzheng-ubuntu:~$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
89862b9b3ee1 redis:3.2 "docker-entrypoint.s…" About a minute ago Up About a minute 0.0.0.0:6379->6379/tcp hungry_boyd
使用客户端连接redis
wangzheng@wangzheng-ubuntu:~$ docker exec -it 89862b9b3ee1 redis-cli
127.0.0.1:6379> select 0
OK
127.0.0.1:6379> set u1 name1
OK
127.0.0.1:6379> get u1
"name1"
127.0.0.1:6379> select 1
OK
127.0.0.1:6379[1]> get u1
(nil)
127.0.0.1:6379[1]>