Redis使用示例

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

下面是一个使用Spring Data Redis的例子: 1. 添加依赖 在Maven项目中,需要添加以下依赖: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> ``` 2. 配置Redis连接信息 在Spring Boot应用程序中,可以在application.properties或application.yml文件中配置Redis连接信息,例如: ``` spring.redis.host=localhost spring.redis.port=6379 spring.redis.password=123456 ``` 3. 编写Redis操作代码 在Spring Boot应用程序中,可以使用RedisTemplate或Spring Data Redis提供的Repository来操作Redis。以下是使用RedisTemplate操作Redis的例子: ``` @Service public class RedisService { @Autowired private RedisTemplate<String, String> redisTemplate; public void set(String key, String value) { redisTemplate.opsForValue().set(key, value); } public String get(String key) { return redisTemplate.opsForValue().get(key); } } ``` 在上面的代码中,我们通过注入RedisTemplate对象来操作Redis。set方法用于将key-value数据存储到Redis中,get方法用于从Redis中获取key对应的value值。 4. 测试 在Spring Boot应用程序中,可以编写单元测试代码来测试Redis操作是否正常。以下是一个简单的测试代码示例: ``` @RunWith(SpringRunner.class) @SpringBootTest public class RedisServiceTest { @Autowired private RedisService redisService; @Test public void testSetAndGet() { String key = "key1"; String value = "value1"; redisService.set(key, value); String result = redisService.get(key); Assert.assertEquals(value, result); } } ``` 在上面的代码中,我们通过注入RedisService对象来测试Redis操作是否正常。testSetAndGet方法用于测试set和get方法是否能够正常工作。 总之,Spring Data Redis是一个非常方便的模块,可以帮助开发人员快速集成Redis到Spring Boot应用程序中,并提供了一组简单易用的API,使得开发人员可以方便地进行Redis操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值