使用redis批量生成主键(订单)Id

在高并发场景下,为了创建唯一的订单Id,本文介绍了如何利用Redis预先生成批量Id并存储于队列中,通过线程安全的方式进行取用。包括创建Redis队列服务和线程生成批量Id的步骤,提供了简单易懂的使用方法。
摘要由CSDN通过智能技术生成

前言:

      在多线程、高并发情况下,某些业务场景需要创建唯一标识的主键(订单)Id;通常情况下都是一个请求创建一个,考虑到性能和QPS我们会提前生成好一堆随机id保存到redis;从redis进行poll。

     1、创建一个redis队列服务    

//redis 公共操作服务
@Service
public class RedisPublicService {
    @Resource
    public Redisson redisson;
    
    private RQueue<Long> pkQueue;

	@PostConstruct
    public void init() {
		pkQueue=redisson.getQueue("GENERATOR_PRIMARY_KEY"); 
    }
	public RQueue<Long> getPkQueue(){
		return pkQueue;
	}
}

 

   2、创建线程进行生成批量id

@Component
public class GeneratePrimaryKeyTask extends Thread{
	@Autowired
	private RedisPublicService redisService;
	private final int cnt=10000;

	private final Random random=new Random();
	public Long getPrimaryId() {
		//length=18 ;变量赋随机值1000-9999
		return System.currentTimeMillis
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值