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是删除缓存


    参考:http://www.runoob.com/redis/redis-java.html


    转载至:http://www.qunjianinfo.com/com/qj/front/bookDetails.html?fmId=27

原创粉丝点击