Redis

打开redis服务器和命令行

cd 命令切换到redis目录 运行:

redis-server.exe redis.windows.conf

redis-server.exe
Redis_第1张图片
新开cmd窗口
切换到 redis 目录下运行:

redis-cli.exe -h 127.0.0.1 -p 6379
Redis_第2张图片
设置键值对:

set myKey abc
取出键值对:

get myKey

连接redis工具

https://gitee.com/qishibo/AnotherRedisDesktopManager/releases
可以看到redis的信息
Redis_第3张图片Redis_第4张图片
可以看到刚才设置的key

Redis 数据类型

Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。

String(字符串)
string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。

string 类型是二进制安全的。意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象。

string 类型是 Redis 最基本的数据类型,string 类型的值最大能存储 512MB。
Hash(哈希)
Redis hash 是一个键值(key=>value)对集合。

Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。
HSET和HGET设置和获取hash值,每个 hash 可以存储 232 -1 键值对(40多亿)。

127.0.0.1:6379> HSET runoob field1 "Hello" field2 "world"
(integer) 2
127.0.0.1:6379> HGET runoob field1
"Hello"
127.0.0.1:6379> HGET runoob field2
"world"
127.0.0.1:6379>

List(列表)
Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。
lpush设置列表

127.0.0.1:6379> lpush runoob redis
(integer) 1
127.0.0.1:6379> lpush runoob mongodb
(integer) 2
127.0.0.1:6379> lpush runoob rabbitmq
(integer) 3
127.0.0.1:6379> lrange runoob 0 10
1) "rabbitmq"
2) "mongodb"
3) "redis"

图形化显示
Redis_第5张图片
Set(集合)
Redis 的 Set 是 string 类型的无序集合。

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。

sadd 命令
添加一个 string 元素到 key 对应的 set 集合中,成功返回 1,如果元素已经在集合中返回 0。
smembers jihe 获取集合的所有元素。
集合中最大的成员数为 232 - 1(4294967295, 每个集合可存储40多亿个成员)。

127.0.0.1:6379> sadd runoob redis
(error) WRONGTYPE Operation against a key holding the wrong kind of value
127.0.0.1:6379> sadd jihe redis
(integer) 1
127.0.0.1:6379> sadd jihe mongodb
(integer) 1
127.0.0.1:6379> sadd jihe rabbitmq
(integer) 1
127.0.0.1:6379> sadd jihe rabbitmq
(integer) 0
127.0.0.1:6379> smembers jihe
1) "redis"
2) "mongodb"
3) "rabbitmq"

Redis_第6张图片
zset(sorted set:有序集合)
Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

zset的成员是唯一的,但分数(score)却可以重复。

zadd 命令
添加元素到集合,元素在集合中存在则更新对应score
zadd key score member

127.0.0.1:6379> zadd youxujihe 0 redis
(integer) 1
127.0.0.1:6379> zadd youxujihe 0 mongodb
(integer) 1
127.0.0.1:6379> zadd youxujihe 0 rabbitmq
(integer) 1
127.0.0.1:6379> zadd youxujihe 0 rabbitmq
(integer) 0
127.0.0.1:6379> ZRANGEBYSCORE youxujihe 0 1000
1) "mongodb"
2) "rabbitmq"
3) "redis"

Redis_第7张图片

Redis 事务

Redis 事务可以一次执行多个命令, 并且带有以下三个重要的保证:

批量操作在发送 EXEC 命令前被放入队列缓存。
收到 EXEC 命令后进入事务执行,事务中任意命令执行失败,其余的命令依然被执行。
在事务执行过程,其他客户端提交的命令请求不会插入到事务执行命令序列中。
一个事务从开始到执行会经历以下三个阶段:

开始事务。
命令入队。
执行事务。
实例
以下是一个事务的例子, 它先以 MULTI 开始一个事务, 然后将多个命令入队到事务中, 最后由 EXEC 命令触发事务, 一并执行事务中的所有命令:

127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> set book-name "Master C++ in 21 days"
QUEUED
127.0.0.1:6379> GET book-name
QUEUED
127.0.0.1:6379> SADD tag "C++" "Programming" "Mastering Series"
QUEUED
127.0.0.1:6379> SMEMBERS tag
QUEUED
127.0.0.1:6379> EXEC
1) OK
2) "Master C++ in 21 days"
3) (integer) 3
4) 1) "Mastering Series"
   2) "C++"
   3) "Programming"

单个 Redis 命令的执行是原子性的,但 Redis 没有在事务上增加任何维持原子性的机制,所以 Redis 事务的执行并不是原子性的。

事务可以理解为一个打包的批量执行脚本,但批量指令并非原子化的操作,中间某条指令的失败不会导致前面已做指令的回滚,也不会造成后续的指令不做。

Redis 数据备份与恢复

Redis SAVE 命令用于创建当前数据库的备份。

语法
redis Save 命令基本语法如下:

redis 127.0.0.1:6379> SAVE
实例
redis 127.0.0.1:6379> SAVE
OK
该命令将dump.rdb文件。
Redis_第8张图片

Redis 性能测试

Redis 性能测试是通过同时执行多个命令实现的。

语法
redis 性能测试的基本命令如下:

redis-benchmark [option] [option value]
注意:该命令是在 redis 的目录下执行的,而不是 redis 客户端的内部指令。
Redis_第9张图片

你可能感兴趣的:(数据库,redis,缓存,java)