SpringBoot项目集成Redis

pom

<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

application.yml

spring:
  redis:
    host: 127.0.0.1
    port: 6379
    password: password

RedisUtil 工具类

import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisCallback;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component;

import javax.annotation.PostConstruct;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.TimeUnit;

@Component
@Slf4j
public class RedisUtil {

    @Autowired
    private RedisTemplate<Object, Object> redisTemplateBean;

    private static RedisTemplate<Object, Object> redisTemplate;

    @SuppressWarnings("static-access")
    @PostConstruct
    public void init() {
        redisTemplate = redisTemplateBean;
    }

    public static void save(final String key, Object value) {
        saveWithExpir(key, value, 0);
    }

    public static <T> T get(final String key) {
        return get(key, false);
    }

    public static void saveWithExpir(final String key, Object value, final long expirtime) {
        final byte[] vbytes = SerializeUtil.serialize(value);
        redisTemplate.execute((RedisCallback<Object>) connection -> {
            byte[] kbytes = redisTemplate.getStringSerializer().serialize(key);
            connection.set(kbytes, vbytes);
            if (expirtime > 0) {
                connection.expire(kbytes, expirtime);
            }
            return null;
        });
    }

    public static void saveWithExpir(final String key, Object value) {
        final byte[] vbytes = SerializeUtil.serialize(value);
        redisTemplate.execute((RedisCallback<Object>) connection -> {
            byte[] kbytes = redisTemplate.getStringSerializer().serialize(key);
            connection.set(kbytes, vbytes);
            return null;
        });
    }

    /**
     * 返回自增的key值
     *
     * @param key
     * @return
     * @date 2017年7月3日 下午3:49:26
     */
    public static <T> T getIncrKey(final String key) {
        final byte[] incrbytes = redisTemplate.getStringSerializer().serialize(key);
        return redisTemplate.execute((RedisCallback<T>) connection -> {
            Long key1 = connection.incr(incrbytes);
            return (T) key1;
        });
    }

    /**
     * 获取
     *
     * @param key
     * @return
     */
    public static <T> T get(final String key, final boolean delete) {
        return redisTemplate.execute((RedisCallback<T>) connection -> {
            byte[] keybytes = redisTemplate.getStringSerializer().serialize(key);
            if (connection.exists(keybytes)) {
                byte[] valuebytes = connection.get(keybytes);
                T value = (T) SerializeUtil.unserialize(valuebytes);
                if (delete) {
                    connection.del(keybytes);
                }
                return value;
            }
            return null;
        });
    }

    /**
     * 存值
     *
     * @param key
     * @param value
     * @return
     */
    public static boolean set(String key, Object value) {
        try {
            redisTemplate.opsForValue().set(key, value);
            return true;
        } catch (Exception e) {
            log.error("redis set error:{}", e.getMessage(), e);
            return false;

        }

    }

    /**
     * 存值并设置过期时间
     *
     * @param key
     * @param value
     * @param time
     * @return
     */
    public static boolean set(String key, Object value, long time) {
        try {
            if (time > 0) {
                redisTemplate.opsForValue().set(key, value, time, TimeUnit.SECONDS);
            } else {
                set(key, value);
            }
            return true;
        } catch (Exception e) {
            log.error("redis set error:{}", e.getMessage(), e);
            return false;
        }
    }

    /**
     * 批量获取
     *
     * @param keys
     * @return
     */
    public static <T> T batchGet(final List<String> keys) {
        return redisTemplate.execute((RedisCallback<T>) connection -> {
            byte[][] byteKeys = new byte[keys.size()][128];
            for (int index = 0; index < keys.size(); ++index) {
                byteKeys[index] = redisTemplate.getStringSerializer().serialize(keys.get(index));
            }
            List<byte[]> byteValus = connection.mGet(byteKeys);
            List<T> result = new ArrayList<>();
            for (byte[] byteValue : byteValus) {
                T value = null;
                if (null != byteValue) {
                    value = (T) SerializeUtil.unserialize(byteValue);
                }
                result.add(value);
            }
            return (T) result;
        });
    }

    /**
     * 删除
     *
     * @param key
     * @return
     */
    public static void delete(final String key) {
        redisTemplate.execute((RedisCallback<Object>) connection -> {
            byte[] keybytes = redisTemplate.getStringSerializer().serialize(key);
            connection.del(keybytes);
            return null;
        });
    }

    public static Long getKeyTtl(final String key) {
        return redisTemplate.execute((RedisCallback<Long>) connection -> {
            byte[] keybytes = redisTemplate.getStringSerializer().serialize(key);
            return connection.ttl(keybytes);
        });
    }

    public static void setExpir(final String key, final long expirtime) {
        redisTemplate.execute((RedisCallback<Object>) connection -> {
            byte[] keybytes = redisTemplate.getStringSerializer().serialize(key);
            connection.expire(keybytes, expirtime);
            return null;
        });
    }

    public static String getMapValue(final String key, final String hashKey) {
        String value = (String) redisTemplate.opsForHash().get(key, hashKey);
        return value;
    }

    public static void setMapValue(final String key, final String hashKey, final String value) {
        redisTemplate.opsForHash().put(key, hashKey, value);
    }

}

SerializeUtil

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;

public class SerializeUtil {

	/**
	 * 序列化
	 * 
	 * @param object
	 * @return<update
	 */
	public static byte[] serialize(Object object) {
		ObjectOutputStream oos = null;
		ByteArrayOutputStream baos = null;
		try {
			baos = new ByteArrayOutputStream();
			oos = new ObjectOutputStream(baos);
			oos.writeObject(object);
			return baos.toByteArray();
		} catch (Exception e) {
			throw new RuntimeException(e.getMessage(), e);
		}
	}

	/**
	 * 反序列化
	 * 
	 * @param bytes
	 * @return
	 */
	public static Object unserialize(byte[] bytes) {
		ByteArrayInputStream bais = null;
		try {
			bais = new ByteArrayInputStream(bytes);
			ObjectInputStream ois = new ObjectInputStream(bais);
			return ois.readObject();
		} catch (Exception e) {
			throw new RuntimeException(e.getMessage(), e);
		}
	}
	
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要在Spring Boot项目集成Redis哨兵模式并使用分布式锁,您需要完成以下步骤: 1. 在您的项目中引入Redis相关依赖,包括`spring-boot-starter-data-redis`和`commons-pool2`。这可以通过在`pom.xml`文件中添加以下依赖项来实现: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-pool2</artifactId> <version>2.6.0</version> </dependency> ``` 2. 配置Redis的哨兵模式。您可以创建一个`sentinel.conf`文件,其中包含您的Redis哨兵的配置信息。然后,在您的应用程序的配置文件中,如`application.yml`中,指定Redis连接的哨兵主机和端口。 3. 在您的Spring Boot应用程序中实现分布式锁。您可以使用Redis的`setnx`命令来获取锁,即在Redis中设置一个键,只有一个客户端能够成功设置该键,其他客户端将无法获取锁。然后,使用`expire`命令设置锁的过期时间,以避免死锁情况。 4. 在您的测试类中验证分布式锁的功能。您可以编写一个简单的测试方法,在多个线程或多个应用程序实例中尝试获取锁并执行某些操作。通过检查锁是否被成功获得,您可以验证分布式锁的功能。 请注意,集成Redis哨兵模式和实现分布式锁是一个相对复杂的过程,需要综合考虑多个因素,如网络延迟、多线程并发等。确保在实际应用中仔细测试和调试您的代码,以确保其稳定性和正确性。 总结:要在Spring Boot项目集成Redis的哨兵模式并实现分布式锁,您需要添加Redis相关依赖,配置哨兵模式,并在应用程序中实现分布式锁的逻辑。确保测试和验证您的代码以确保其正确性和可靠性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [企业级开发SpringBoot集成Redis哨兵模式(全网最新)](https://blog.csdn.net/qq_41107231/article/details/115743857)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Springboot集成Redis——实现分布式锁](https://blog.csdn.net/tang_seven/article/details/126769580)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

刘水水

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值