1.安装篇
a) Window版本64位下载地址
https://github.com/microsoftarchive/redis/releases
下载完成后
Windows 解压 redis压缩包
启动redis-server.exe
b) Linux版本下载
下载完成之后
Linux 解压 tar-zxvf redis 压缩包
启动redis-server.exe
2.安装redis集群篇
暂时不考虑
3.命令篇
远程服务执行命令
语法:redis-cli -h host -p port -a password
host:ip
port:端口
password: 密码
示例:redis-cli -h 127.0.0.1 -p 6379 -a "wll123"
redis 键key
redistext:0>set run redis
键为run 值为redis set语法
给键一个redis的值
redistext:0>del run
删除名为run的键key
redistext:0>dump run
序列化给定的key并返回被序列化的值
redistext:0>exists key
返回1为存在返回0不存在
redistext:0>expire run 10
设置key的过期时间,10的单位为秒
redistext:0>pexpire run 1000
设置key的过期时间以毫秒计
redistext:0>move wll 1
移动当前的key到指定的db中
redistext:0>select 1
切换库
redistext:1>persist wll
移除当前ley的过期时间
redistext:1>randomkey
随机返回当前库的key
redistext:1>rename wll gyx
修改当前的key名字 库中若是有 替换库中的key
redistext:1>renamenx wll gyx
修改当前key的名字 库中没有时才会修改成功
redistext:1>type wll
返回key的存储类型
4.类型篇
4.1Redis字符串(String)
redistext:1>set wll 2365900668
添加key为wll 值为2365900668
redistext:1>get wll
获取key为wll的val值
redistext:1>getrange wll 2 5
获取wll的指定字符 2 字符开始 5字符结束
redistext:1>getset wll 93075627
给定key为wll的一个新的值 返回旧的值
redistext:1>getbit wll 11
例如java char值得取值范围 如何把a变成b 修改char值
redistext:1>mget wll gyx
获取所有给定的key
redistext:1>setnx job kil
只有设置的key值不存在时才会为key设置指定的值 (set区别)
redistext:1>strlen wll
返回key的长度
redistext:1>mset key1 wll key2 gyx
设置一个或者多个key-val对
redistext:1>append wll 111
APPEND 命令将指定的 value 追加到该 key 原来值(value)的末尾 (值是字符串)
4.2Redis哈希(hash)
Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象。
Redis 中每个 hash 可以存储 2的32次方- 1 键值对(40多亿)。
命令:
redistext:1>hmset run wll "瞬发" gyx "mhg"
同时将多个field-value(域-值)对设置到哈希表的key中 key为run wll gyx 域-值 redistext:1>hmget run wll gyx
获取 run中的wll gyx域中的值
redistext:1>hdel run wll
删除一个或者多个hash表字段
redistext:1>hexists run gyx
查看hash表key中,指定的字段是否存在
redistext:0>hset site redis redis.com
添加site hash表中添加key为redis val为redis.com
redistext:0>hget site redis
获取 site hash表中key为redis的value值
redistext:0>hkeys site
获取所有hash表中的所有字段
redistext:0>hlen site
获取hash表字段的数量
redistext:0>hvals site
获取hash表中所有的值
4.3Redis列表(list)、
Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)
一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个元素)。
redistext:0>blpop wll 10
移出并获取列表的第一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
redistext:0>brpop wll 10
移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
redistext:0>lindex wll 0
通过索引获取列表元素
redistext:0>linsert wll before "age" "pipi"
命令用于在列表的元素前或者后插入元素。当指定元素不存在于列表中时,不执行任何操作。
redistext:0>llen wll
获取列表的长度
redistext:0>lpop wll
移除并获取列表的第一个元素
redistext:0>lpush wll ju ku
将一个或多个值插入到列表头部。如果 key不存在,一个空列表会被创建并执行 LPUSH操作。当key存在但不是列表类型时,返回一个错误。
redistext:0>lrem wll -4 aa
根据参数 COUNT 的值,移除列表中与参数 VALUE 相等的元素。
count > 0 : 从表头开始向表尾搜索,移除与 VALUE 相等的元素,数量为 COUNT 。
count < 0 : 从表尾开始向表头搜索,移除与 VALUE 相等的元素,数量为 COUNT 的绝对值。
count = 0 : 移除表中所有与 VALUE 相等的值。
redistext:0>lpushx wll jui
将一个值插入到已存在的列表头部
redistext:0>lset wll 0 kij
向列表的指定位置添加值
redistext:0>rpush wll ok ok
列表添加一个或者多个值与lpush区别 lpush添加头部
4.4redis集合(set)
Redis 的 Set 是 String 类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。
Redis 中集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。
集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。
命令:
redistext:0>sadd buba wll
向集合中添加一个或者多个成员
redistext:0>smembers buba
查看集合的成员
redistext:0>scard buba
获取集合的成员数
redistext:0>sdiff key1 key2
返回给定所有集合的差集
redistext:0>sinter key1 key2
返回交集数据
redistext:0>sismember key1 a
判断该成员是不是集合中的成员 是返回1
redistext:0>smembers key1
返回该集合中的所有成员
redistext:0>spop key1
移除并返回集合中的随机元素
redistext:0>srandmember key1
返回集合中一个随机元素
redistext:0>sunion key1 key2
返回给定集合的并集
SUNIONSTORE destination key1 [key2]
所有给定集合的并集存储在 destination 集合中
4.5有序集合(sorted set)
Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
有序集合的成员是唯一的,但分数(score)却可以重复。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。
命令:
zadd 添加元素
了解
5.redis数据备份和恢复
备份数据
Redis中save命令用于创建当前数据库的备份
语法:redistext:0>save
恢复数据
如果需要恢复数据,只需将备份文件(dump.rdb) 移动到 redis 安装目录并启动服务即可。获取redis目录可以使用CONFIG命令
redis 127.0.0.1:6379> CONFIG GET dir
1) "dir"
2) "/usr/local/redis/bin"
5.Redis安全
我们可以通过redis的配置文件设置密码参数这样客户端连接到redis服务就需要密码验证这样就可以使redis服务更加安全
查看是否设置密码
127.0.0.1:6379> CONFIG get requirepass
1) "requirepass"
2) ""
没有设置密码
Redis 密码runoob
Java示例
import redis.clients.jedis.Jedis;
public class RedisJava {
public static void main(String[] args) {
//连接本地的 Redis 服务
Jedis jedis = new Jedis("localhost");
System.out.println("连接成功");
//查看服务是否运行
System.out.println("服务正在运行: "+jedis.ping());
}
}
import redis.clients.jedis.Jedis;
public class RedisStringJava {
public static void main(String[] args) {
//连接本地的 Redis 服务
Jedis jedis = new Jedis("localhost");
System.out.println("连接成功");
//设置 redis 字符串数据
jedis.set("runoobkey", "www.runoob.com");
// 获取存储的数据并输出
System.out.println("redis 存储的字符串为: "+ jedis.get("runoobkey"));
}
}
import java.util.List;
import redis.clients.jedis.Jedis;
public class RedisListJava {
public static void main(String[] args) {
//连接本地的 Redis 服务
Jedis jedis = new Jedis("localhost");
System.out.println("连接成功");
//存储数据到列表中
jedis.lpush("site-list", "Runoob");
jedis.lpush("site-list", "Google");
jedis.lpush("site-list", "Taobao");
// 获取存储的数据并输出
List<String> list = jedis.lrange("site-list", 0 ,2);
for(int i=0; i<list.size(); i++) {
System.out.println("列表项为: "+list.get(i));
}
}
}
import java.util.Iterator;
import java.util.Set;
import redis.clients.jedis.Jedis;
public class RedisKeyJava {
public static void main(String[] args) {
//连接本地的 Redis 服务
Jedis jedis = new Jedis("localhost");
System.out.println("连接成功");
// 获取数据并输出
Set<String> keys = jedis.keys("*");
Iterator<String> it=keys.iterator() ;
while(it.hasNext()){
String key = it.next();
System.out.println(key);
}
}
}