黑马点评--优惠卷秒杀

黑马点评–优惠卷秒杀

全局ID生成器:

是一种在分布式系统下用来生成全局唯一ID的工具,一般要满足下列特性:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lvc2qD5J-1668574944843)(C:\Users\20745\AppData\Roaming\Typora\typora-user-images\image-20221113221848596.png)]

为了增加ID的安全性,我们可以不直接使用Redis自增的数值,而是拼接一些其它信息:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FM7N8l3N-1668574944844)(C:\Users\20745\AppData\Roaming\Typora\typora-user-images\image-20221113222812554.png)]

Redis自增ID策略:

  • 每天一个key,方便统计订单量
  • iD结构是时间戳+计数器
    /**
     * 开始时间戳
     */
    private static final long BEGIN_TIMESTAMP = 1640995200;
    /**
     * 序列号的位数
     */
    private static final int COUNT_BITS = 32;
    /**
     * id生成策略
     *
     * @param keyPrefix 业务前缀
     * @return
     */
    @Resource
    private StringRedisTemplate stringRedisTemplate;

    public long nextId(String keyPrefix) {
   
   
        //1.生成时间戳
        LocalDateTime now = LocalDateTime.now();
        long nowSecond = now.toEpochSecond(ZoneOffset.UTC);
        long timestamp = nowSecond - BEGIN_TIMESTAMP;
        //2.生成序列号
        //2.1获取当前日期,精确到天
        String date = now.format(DateTimeFormatter.ofPattern("yyyy:MM:dd"));
        //2.2自增长
        Long count = stringRedisTemplate.opsForValue().increment("icr:" + keyPrefix + ":" + date);
        //3.拼接并返回

        return timestamp << COUNT_BITS | count;
    }


    public static void main(String[] args) {
   
   

        LocalDateTime time = LocalDateTime.of(2022, 1, 1, 0, 0, 0);
        long second = time.toEpochSecond(ZoneOffset.UTC);
        System.out.println(second);
    }

测试ID自增生成策略:

500个线程每一个线程生成100id一共50000个id花的时间:

private ExecutorService service = Executors.newFixedThreadPool(500);
    @Test
    void testIdWorker() throws InterruptedException {
   
   
        CountDownLatch latch =
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值