Redis使用示例
来源:互联网 发布:数据分析之量化投资 编辑:程序博客网 时间:2024/06/03 11:01
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
阅读全文
1 0
- Jedis(Redis)使用示例
- Redis使用示例
- Redis安装和使用示例
- Redis安装和使用示例
- Redis安装和使用示例
- Redis --- Jedis 使用简单示例
- Java使用Redis代码示例
- Java连接redis的使用示例
- Java连接redis的使用示例
- Java连接redis的使用示例
- redis的Java客户端jedis使用示例
- Java连接redis的使用示例
- Java连接redis的使用示例
- ASP.NET使用Redis共享缓存示例
- Spring-data-redis配置及使用示例
- Java连接redis的使用示例
- redis 示例
- redis示例
- local variable 'xxx' referenced before assignment
- 适配器模式
- SSH框架搭建配置
- 总结提高关键词排名最全的41个技巧
- LeetCode-22. Generate Parentheses
- Redis使用示例
- Python爬虫入门:Urllib库的高级使用
- UGUI坐标与世界坐标的转换
- java Excel解析
- qq引流新技能
- [noip2013]小朋友的数字(dp+规律)
- c语言实现对密码(字符串)进行加密,并解密
- 面向对象设计原则总结
- CMake error: error in configuration process, project files may be invalid