一丶介绍redis
是一个高性能的key-value内存型数据库。
特点:
支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候自动再次加载进行使用。
既支持key-value类型的数据操作,还提供list,set,zset,hash等数据结构的存储。
支持数据的主从备份,采用master-slave模式的主从备份。
新版3.x也支持分布式布署模式,真正实现了数据块的分布式存储与响应。
性能极高–Redis读的速度是11万次/s,写的速度是8万次/s。
所有操作均为原子性操作
丰富的实 用特性,如订阅-发布模式,生产者消费者模式,key过期等常用易用的模式。
三种运行模式
单机布署
主备布署
分布式布署
二丶安装redis
选择2.8.*版本
下载完成后,直接解压即可投入使用。
通过配置文件启动服务:
redis-server.exe redis.windows.conf
redis客户端链接redis服务器
cmd进入对应目录后,找到服务命令redis-cli.exe.
直接运行即可,默认链接127.0.0.1IP地址下的6379端口
2.linux安装
通过浏览器直接打开,或者wget均可。
下载完成后,直接解压为源码包,需要编译后方可使用。
编译过程与server运行
tar -xzvf redis-2.8.24.tar.gz
cd redis-2.8.24
make //源代码编译
cd src //进入编译完成后的执行文件所在的主目录
./redis-server //按默认参数起动redis-server
或者./redis-server ../redis.conf //按指定的参数文件来起动redis-server,参数文件配置等同windows的conf文件
三丶redis架构设计
四丶redis常用命令
1 |
set key value |
设置kv对 |
2 |
get key |
通过给定key获取其对应的value |
3 |
del key |
删除指定的key |
5 |
exists key |
检查给定 key 是否存在 |
6 |
expire key seconds |
给指定key设置失效时间 |
7 |
expireat key timestamp |
EXPIREAT 的作用和 EXPIRE 类似,都用于为 key 设置过期时间。 不同在于 EXPIREAT 命令接受的时间参数是 UNIX 时间戳(unix timestamp) |
8 |
pexpire key milliseconds |
设置 key 的过期时间以毫秒计 |
12 |
ttl key |
以秒为单位,返回给定 key 的剩余生存时间(TTL, time to live) |
13 |
randomkey |
从当前数据库中随机返回一个 key |
2.hash结构操作常用命令
1 |
hset key field value |
将哈希表 key 中的字段 field 的值设为 value |
2 |
hsetnx key field value |
只有在字段 field 不存在时,设置哈希表字段的值 |
4 |
hdel key field1 [field2] |
删除一个或多个哈希表字段 |
3.列表(List)结构操作常用命令
1 |
lpush key value1 [value2] |
将一个或多个值插入到列表头部 |
2 |
lpushx key value |
将一个值插入到已存在的列表头部 |
3 |
lrange key start stop |
获取列表指定范围内的元素,用元素所在的下标值来作为范转围的上下限,如 lrange list1 0 10 |
4 |
rpop key |
移除并获取列表最后一个元素 |
5 |
rpush key value1 [value2] |
在列表中添加一个或多个值 |
6 |
rpushx key value |
为已存在的列表添加值 |
7 |
llen key |
获取列表长度 |
8 |
lpop key |
移除并获取列表的第一个元素 |
9 |
blpop key1 [key2 ] timeout |
移出并获取列表的第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。 |
10 |
brpop key1 [key2 ] timeout |
移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。 |
4.集合Set结构操作常用命令
1 |
sadd key member1 [member2] |
向集合添加一个或多个成员 |
2 |
srem key member1 [member2] |
移除集合中一个或多个成员 |
3 |
sismember key member |
判断 member 元素是否是集合 key 的成员 |
5.redis连接服务器操作
1 |
auth password |
验证密码是否正确 |
2 |
echo message |
打印字符串 |
3 |
ping |
查看服务是否运行,返回pong代表正常 |
4 |
quit |
关闭当前连接 |
5 |
select index |
切换到指定的数据库,默认redis有16个数据库,默认选择索引号为0的数据库 |
6.redis服务器操作
5 |
dbsize |
返回当前数据库的 key 的数量 |
6 |
flushall |
删除所有数据库的所有key |
7 |
flushdb |
删除当前数据库的所有key |
8 |
lastsave |
返回最近一次 redis 成功将数据保存到磁盘上的时间,以 unix 时间戳格式表示 |
9 |
monitor |
实时打印出 redis 服务器接收到的命令,调试用 |
7.基数统计结构HyperLogLog(基数即为去重)
序号 |
命令 |
作用 |
1 |
pfadd key element [element ...] |
添加指定元素到 HyperLogLog 中 |
2 |
pfcount key [key ...] |
返回给定 HyperLogLog 的基数估算值 |
3 |
pfmerge destkey sourcekey [sourcekey ...] |
将多个 HyperLogLog 合并为一个 HyperLogLog |
五丶java代码应用
1.配置:
4.0.0
com.tl.job002
RedisTest
0.0.1-SNAPSHOT
nexus-aliyun
Nexus aliyun
http://maven.aliyun.com/nexus/content/groups/public
redis.clients
jedis
2.8.2
RedisTest
maven-compiler-plugin
2.3.2
1.7
UTF-8
2.测试:
2.1测试1:
package com.tl.utils;
import redis.clients.jedis.Jedis;
public class RedisUtil {
public static void main(String[] args) {
// 连接本地的 Redis 服务
Jedis jedis = new Jedis("localhost", 6379);
// 查看服务是否运行
System.out.println("服务正在运行: " + jedis.ping());
}
}
2.2测试2:
package com.tl.utils;
import redis.clients.jedis.Jedis;
public class RedisUtil {
public static void main(String[] args) {
// 连接本地的 Redis 服务
Jedis jedis = new Jedis("localhost", 6379);
jedis.set("jedis_k1", "jedis_v1");
System.out.println("jedis_k1=:"+ jedis.get("jedis_k1"));
}
}
3.工具类化
import redis.clients.jedis.Jedis;
public class RedisUtil {
private Jedis jedis;
public Jedis getJedis() {
return jedis;
}
public void setJedis(Jedis jedis) {
this.jedis = jedis;
}
public RedisUtil(String host, int port, String password) {
jedis = new Jedis(host, port);
jedis.auth(password);
}
public void set(String key, String value) {
jedis.set(key, value);
}
public String getString(String key) {
return jedis.get(key);
}
public void close() {
this.jedis.close();
}
public static void main(String[] args) {
// 连接本地的 Redis 服务
RedisUtil redisUtil = new RedisUtil("localhost", 6379, "tianliangedu");
redisUtil.set("jedis_k1", "jedis_v1");
System.out.println("jedis_k1=:" + redisUtil.getString("jedis_k1"));
}
}
4.应用场景:
目标:加速客户端访问速度或其它要加速提效的功能点