Redis使用指南
简介:介绍如何使用Redis缓存来提高性能。解决高并发时,频繁读库,导致I/O瓶颈问题。
第一章 准备
一、前提:
使用Redis时,需下载对应的软件,我用的是: 服务端-《Redis-x64-3.2.100》;Java调用Redis对应的jar包- jedis-2.9.0.jar。可以到如下网站下载:
官方推荐版本 2.8 Or 3.2
压缩版 下载地址 :
https://github.com/MSOpenTech/redis/releases/download/win-3.2.100/Redis-x64-3.2.100.zip
安装版 下载地址 :
https://github.com/MSOpenTech/redis/releases/download/win-3.2.100/Redis-x64-3.2.100.msi
两者的最大不同是后者会主动添加环境变量并且创建会创建服务。
推荐使用解压版。
Java调用Redis对应的jar包 下载地址 :
http://static.runoob.com/download/jedis-2.9.0.jar
二、使用场景:
是不是只要加了Redis,就一定能解决性能问题呢?
肯定不是的,若是操作不当,反而可能对性能有不好的影响。比如本来读库就可以解决的问题,现在还要再放入Redis。要是程序写的好,做了异步,可能好一点;要是做的是同步,则反而降低性能。
纠结哪些场景是适合使用Redis的呢?
原则:1、会被频繁访问的;2、各个数据比较小,方便一下子在内存中定位到的。
示例:
1. 显示最新的项目列表
2. 删除与过滤
3. 排行榜相关
4. 按照用户投票和时间排序
5. 过期项目处理
6. 计数
7. 特定时间内的特定项目
8. 实时分析正在发生的情况,用于数据统计与防止垃圾邮件等
9. 具体某个线路的航空班次列表、火车汽车票列表等
10. 其它需要缓存的数据
第二章 使用
一、Redis公共处理类RedisUtil:
public class RedisUtil {
private static Jedis jedis = null;
/**
*初始化Redis连接
*/
private static void initial() {
//此处可以换成读取配置文件,这样将来只要修改配置即可
jedis = new Jedis("localhost");
}
/**
* 获取缓存中数据(String类型)
* @param key
* @return
*/
public static String getCacheValue(String key) {
if (jedis == null) {
initial();
}
String value = jedis.get(key);
return value;
}
/**
* 获取缓存中数据(byte类型)
* @param key
* @return
*/
public static byte[] getBitCacheValue(String key) {
if (jedis == null) {
initial();
}
byte[] value = jedis.get(key.getBytes());
return value;
}
/**
* 设置缓存值(String类型,缓存时间默认为30分钟)
* @param key
* @param value
*/
public static void setCacheValue(String key, String value) {
if (jedis == null) {
initial();
}
setCacheValue(key, value, 1800);
}
/**
* 设置缓存值(String类型,指定过期时间s)
* @param key
* @param value
* @param secondsForExpired 过期时间(s 秒)
*/
public static void setCacheValue(String key, String value, int secondsForExpired) {
if (jedis == null) {
initial();
}
jedis.setex(key, secondsForExpired, value);
}
/**
* 设置缓存值(byte类型,缓存时间默认为30分钟)
* @param key
* @param bitValue
*/
public static void setBitCacheValue(String key, byte[] bitValue) {
if (jedis == null) {
initial();
}
setBitCacheValue(key, bitValue, 1800);
}
/**
* 设置缓存值(byte类型,指定过期时间s)
* @param key
* @param bitValue
* @param secondsForExpired 过期时间(s 秒)
*/
public static void setBitCacheValue(String key, byte[] bitValue, int secondsForExpired) {
if (jedis == null) {
initial();
}
jedis.setex(key.getBytes(), secondsForExpired, bitValue);
}
public static void delKey(String key) {
jedis.del(key);
}
public static void main(String[] args) {
String key = "KEY";
String value = "Value";
setCacheValue(key,value);
System.out.println("[ZG Test]\t" + getCacheValue(key));
}
}
二、使用说明:
Redis使用其实是很方便的,先将Redis服务端启动。然后此处连接的就是该服务器对应的域名或IP,本处实在本机测试的,所以用的localhost。
将来可以换成读取配置文件,方便以后维护。
上面的类中:
set是设置缓存,若没有设置过期时间的话,自动默认为1800s,即30分钟,此处也可以写成配置文件,方便以后维护;
get是读取缓存,若没有的话,则设置为空。
delKey是删除缓存
简介:介绍如何使用Redis缓存来提高性能。解决高并发时,频繁读库,导致I/O瓶颈问题。
第一章 准备
一、前提:
使用Redis时,需下载对应的软件,我用的是: 服务端-《Redis-x64-3.2.100》;Java调用Redis对应的jar包- jedis-2.9.0.jar。可以到如下网站下载:
官方推荐版本 2.8 Or 3.2
压缩版 下载地址 :
https://github.com/MSOpenTech/redis/releases/download/win-3.2.100/Redis-x64-3.2.100.zip
安装版 下载地址 :
https://github.com/MSOpenTech/redis/releases/download/win-3.2.100/Redis-x64-3.2.100.msi
两者的最大不同是后者会主动添加环境变量并且创建会创建服务。
推荐使用解压版。
Java调用Redis对应的jar包 下载地址 :
http://static.runoob.com/download/jedis-2.9.0.jar
二、使用场景:
是不是只要加了Redis,就一定能解决性能问题呢?
肯定不是的,若是操作不当,反而可能对性能有不好的影响。比如本来读库就可以解决的问题,现在还要再放入Redis。要是程序写的好,做了异步,可能好一点;要是做的是同步,则反而降低性能。
纠结哪些场景是适合使用Redis的呢?
原则:1、会被频繁访问的;2、各个数据比较小,方便一下子在内存中定位到的。
示例:
1. 显示最新的项目列表
2. 删除与过滤
3. 排行榜相关
4. 按照用户投票和时间排序
5. 过期项目处理
6. 计数
7. 特定时间内的特定项目
8. 实时分析正在发生的情况,用于数据统计与防止垃圾邮件等
9. 具体某个线路的航空班次列表、火车汽车票列表等
10. 其它需要缓存的数据
第二章 使用
一、Redis公共处理类RedisUtil:
public class RedisUtil {
private static Jedis jedis = null;
/**
*初始化Redis连接
*/
private static void initial() {
//此处可以换成读取配置文件,这样将来只要修改配置即可
jedis = new Jedis("localhost");
}
/**
* 获取缓存中数据(String类型)
* @param key
* @return
*/
public static String getCacheValue(String key) {
if (jedis == null) {
initial();
}
String value = jedis.get(key);
return value;
}
/**
* 获取缓存中数据(byte类型)
* @param key
* @return
*/
public static byte[] getBitCacheValue(String key) {
if (jedis == null) {
initial();
}
byte[] value = jedis.get(key.getBytes());
return value;
}
/**
* 设置缓存值(String类型,缓存时间默认为30分钟)
* @param key
* @param value
*/
public static void setCacheValue(String key, String value) {
if (jedis == null) {
initial();
}
setCacheValue(key, value, 1800);
}
/**
* 设置缓存值(String类型,指定过期时间s)
* @param key
* @param value
* @param secondsForExpired 过期时间(s 秒)
*/
public static void setCacheValue(String key, String value, int secondsForExpired) {
if (jedis == null) {
initial();
}
jedis.setex(key, secondsForExpired, value);
}
/**
* 设置缓存值(byte类型,缓存时间默认为30分钟)
* @param key
* @param bitValue
*/
public static void setBitCacheValue(String key, byte[] bitValue) {
if (jedis == null) {
initial();
}
setBitCacheValue(key, bitValue, 1800);
}
/**
* 设置缓存值(byte类型,指定过期时间s)
* @param key
* @param bitValue
* @param secondsForExpired 过期时间(s 秒)
*/
public static void setBitCacheValue(String key, byte[] bitValue, int secondsForExpired) {
if (jedis == null) {
initial();
}
jedis.setex(key.getBytes(), secondsForExpired, bitValue);
}
public static void delKey(String key) {
jedis.del(key);
}
public static void main(String[] args) {
String key = "KEY";
String value = "Value";
setCacheValue(key,value);
System.out.println("[ZG Test]\t" + getCacheValue(key));
}
}
二、使用说明:
Redis使用其实是很方便的,先将Redis服务端启动。然后此处连接的就是该服务器对应的域名或IP,本处实在本机测试的,所以用的localhost。
将来可以换成读取配置文件,方便以后维护。
上面的类中:
set是设置缓存,若没有设置过期时间的话,自动默认为1800s,即30分钟,此处也可以写成配置文件,方便以后维护;
get是读取缓存,若没有的话,则设置为空。
delKey是删除缓存
参考:http://www.runoob.com/redis/redis-java.html
转载至:http://www.qunjianinfo.com/com/qj/front/bookDetails.html?fmId=27