0
点赞
收藏
分享

微信扫一扫

【分布式】Redis分布式之BoundedBlockingQueue

金刚豆 2022-03-12 阅读 71
说明

配置文件参考:https://blog.csdn.net/qq_38428623/article/details/123217001?utm_source=app&app_version=5.1.1&code=app_1562916241&uLinkId=usr1mkqgl919blen

使用
package com.demo.redis.list;

import org.redisson.api.RBoundedBlockingQueue;
import org.redisson.api.RedissonClient;
import org.redisson.client.codec.StringCodec;
import org.springframework.stereotype.Component;
import org.springframework.util.Assert;

import javax.annotation.Resource;
import java.util.List;

/**
 * RedisBoundedBlockingQueue
 *
 * @author 王思勤
 */
@Component
public class RedisBoundedBlockingQueue {

    @Resource
    private RedissonClient redissonClient;

    /**
     * 获取 字符串 的 RSet
     *
     * @param name 名称
     * @return 返回 值
     */
    public RBoundedBlockingQueue<String> getBoundedBlockingQueue(String name) {
        RBoundedBlockingQueue<String> boundedBlockingQueue = redissonClient.getBoundedBlockingQueue(name, StringCodec.INSTANCE);
        Assert.notNull(boundedBlockingQueue, "boundedBlockingQueue is null");
        return boundedBlockingQueue;
    }

    /**
     * 新增 数据
     *
     * @param name  名称
     * @param value 值
     * @return 返回 是否成功
     */
    public boolean add(String name, String value) {
        return this.getBoundedBlockingQueue(name).add(value);
    }

    /**
     * 新增 数据
     *
     * @param name   名称
     * @param values 值
     * @return 返回 是否成功
     */
    public void addAll(String name, List<String> values) {
        this.getBoundedBlockingQueue(name).addAll(values);
    }

    /**
     * pop 数据
     *
     * @param name 名称
     * @return 返回 值
     */
    public String poll(String name) {
        return this.getBoundedBlockingQueue(name).poll();
    }

    /**
     * pop 数据
     *
     * @param name  名称
     * @return 返回 值
     */
    public List<String> readAll(String name) {
        return this.getBoundedBlockingQueue(name).readAll();
    }
}

举报

相关推荐

0 条评论