在Spring Boot中使用Redis生成订单号,并且保证当天有效性

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 在Spring Boot中使用Redis生成订单号,并且保证当天有效性

在Spring Boot中使用Redis生成订单号,并且保证当天有效性,可以通过以下步骤实现:

 

### 1. 配置Redis连接

 

首先,确保你的Spring Boot项目中已经配置好了连接Redis的依赖和配置。可以使用Spring Boot提供的`spring-boot-starter-data-redis`依赖,并配置Redis连接信息。

 

### 2. 实现订单号生成器

 

创建一个订单号生成器的服务类,该类负责生成唯一的订单号,并且保证在Redis中存储并检查订单号的有效性。

```java
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.stereotype.Service;
 
import java.time.LocalDate;
import java.time.format.DateTimeFormatter;
 
@Service
public class OrderNumberGenerator {
 
    private static final String REDIS_KEY_PREFIX = "order_number:";
 
    @Autowired
    private StringRedisTemplate redisTemplate;
 
    public String generateOrderNumber() {
        LocalDate today = LocalDate.now();
        String key = REDIS_KEY_PREFIX + today.format(DateTimeFormatter.ofPattern("yyyyMMdd"));
        
        Long number = redisTemplate.opsForValue().increment(key);
        
        // Ensure the number is padded with zeros
        String paddedNumber = String.format("%04d", number);
        
        return today.format(DateTimeFormatter.ofPattern("yyyyMMdd")) + paddedNumber;
    }
}
```

### 3. 使用Redis原子操作生成订单号

 

在上述代码中,我们使用了Redis的原子操作`increment`来生成唯一的订单号。每次调用`generateOrderNumber`方法时,会在Redis中递增存储的当天订单计数器,并返回生成的订单号。

 

### 4. 控制订单号的有效性

 

订单号的有效性通过Redis的Key的过期时间来控制。可以在生成订单号时设置Redis Key的过期时间,使得订单号在一定时间后自动失效,或者第二天重新开始计数。

 

```java
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.stereotype.Service;
 
import java.time.Duration;
import java.time.LocalDate;
import java.time.format.DateTimeFormatter;
 
@Service
public class OrderNumberGenerator {
 
    private static final String REDIS_KEY_PREFIX = "order_number:";
    private static final Duration REDIS_EXPIRATION = Duration.ofDays(1); // Redis key expiration: 1 day
 
    @Autowired
    private StringRedisTemplate redisTemplate;
 
    public String generateOrderNumber() {
        LocalDate today = LocalDate.now();
        String key = REDIS_KEY_PREFIX + today.format(DateTimeFormatter.ofPattern("yyyyMMdd"));
        
        Long number = redisTemplate.opsForValue().increment(key);
        
        // Ensure the number is padded with zeros
        String paddedNumber = String.format("%04d", number);
        
        // Set expiration if key does not exist yet
        if (!redisTemplate.hasKey(key)) {
            redisTemplate.expire(key, REDIS_EXPIRATION);
        }
        
        return today.format(DateTimeFormatter.ofPattern("yyyyMMdd")) + paddedNumber;
    }
}
```

### 5. 使用订单号生成器

 

在需要生成订单号的地方注入`OrderNumberGenerator`服务,调用`generateOrderNumber`方法即可获取当天有效的订单号。

```java
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
@RestController
@RequestMapping("/orders")
public class OrderController {
 
    @Autowired
    private OrderNumberGenerator orderNumberGenerator;
 
    @GetMapping("/generate")
    public String generateOrder() {
        String orderNumber = orderNumberGenerator.generateOrderNumber();
        return "Generated Order Number: " + orderNumber;
    }
}
```

这样,你就可以在Spring Boot应用中使用Redis生成当天有效的订单号了。确保在实际生产环境中,对Redis的配置和订单号生成算法进行适当的优化和安全性保护。

 

补充一些关于订单号生成器的实现细节和注意事项:

 

### 1. Redis连接配置

 

确保在Spring Boot项目的`application.properties`或`application.yml`中正确配置Redis连接信息。例如:

```yaml
spring:
  redis:
    host: localhost
    port: 6379
    password:  # 如果有密码的话
```

### 2. RedisTemplate配置

 

在使用`StringRedisTemplate`时,Spring Boot会自动配置好该Bean,但如果需要定制化配置,可以通过@Bean方式手动配置。例如:

```java
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.StringRedisTemplate;
 
@Configuration
public class RedisConfig {
 
    @Bean
    public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory connectionFactory) {
        return new StringRedisTemplate(connectionFactory);
    }
}
```

### 3. 订单号的格式化和存储

 

在示例中,订单号格式为`yyyyMMddNNNN`,其中NNNN表示当天的递增序号,保证了订单号的唯一性。可以根据实际需求修改格式化方式。

 

### 4. 并发安全性

 

使用Redis的`increment`操作能够保证在并发情况下生成唯一的递增序号,因为Redis的命令是原子性的。这样可以避免多个并发请求同时获取到相同的订单号。

 

### 5. 订单号的过期处理

 

为了避免Redis中无限增长的key,可以设置订单号的Redis Key在当天结束后自动过期。这样可以控制Redis内存的使用,并且在第二天重新开始计数。

 

### 6. 异常处理和日志记录

 

在实际应用中,考虑到网络问题、Redis连接异常等情况,需要合适地处理异常并记录日志,以保证系统的稳定性和可靠性。

目录
相关文章
|
23天前
|
NoSQL Java 调度
分布式锁与分布式锁使用 Redis 和 Spring Boot 进行调度锁(不带 ShedLock)
分布式锁是分布式系统中用于同步多节点访问共享资源的机制,防止并发操作带来的冲突。本文介绍了基于Spring Boot和Redis实现分布式锁的技术方案,涵盖锁的获取与释放、Redis配置、服务调度及多实例运行等内容,通过Docker Compose搭建环境,验证了锁的有效性与互斥特性。
分布式锁与分布式锁使用 Redis 和 Spring Boot 进行调度锁(不带 ShedLock)
|
6月前
|
NoSQL 安全 Java
深入理解 RedisConnectionFactory:Spring Data Redis 的核心组件
在 Spring Data Redis 中,`RedisConnectionFactory` 是核心组件,负责创建和管理与 Redis 的连接。它支持单机、集群及哨兵等多种模式,为上层组件(如 `RedisTemplate`)提供连接抽象。Spring 提供了 Lettuce 和 Jedis 两种主要实现,其中 Lettuce 因其线程安全和高性能特性被广泛推荐。通过手动配置或 Spring Boot 自动化配置,开发者可轻松集成 Redis,提升应用性能与扩展性。本文深入解析其作用、实现方式及常见问题解决方法,助你高效使用 Redis。
576 4
|
3月前
|
NoSQL Java Redis
Redis基本数据类型及Spring Data Redis应用
Redis 是开源高性能键值对数据库,支持 String、Hash、List、Set、Sorted Set 等数据结构,适用于缓存、消息队列、排行榜等场景。具备高性能、原子操作及丰富功能,是分布式系统核心组件。
389 2
|
5月前
|
消息中间件 缓存 NoSQL
基于Spring Data Redis与RabbitMQ实现字符串缓存和计数功能(数据同步)
总的来说,借助Spring Data Redis和RabbitMQ,我们可以轻松实现字符串缓存和计数的功能。而关键的部分不过是一些"厨房的套路",一旦你掌握了这些套路,那么你就像厨师一样可以准备出一道道饕餮美食了。通过这种方式促进数据处理效率无疑将大大提高我们的生产力。
191 32
|
4月前
|
机器学习/深度学习 数据采集 人机交互
springboot+redis互联网医院智能导诊系统源码,基于医疗大模型、知识图谱、人机交互方式实现
智能导诊系统基于医疗大模型、知识图谱与人机交互技术,解决患者“知症不知病”“挂错号”等问题。通过多模态交互(语音、文字、图片等)收集病情信息,结合医学知识图谱和深度推理,实现精准的科室推荐和分级诊疗引导。系统支持基于规则模板和数据模型两种开发原理:前者依赖人工设定症状-科室规则,后者通过机器学习或深度学习分析问诊数据。其特点包括快速病情收集、智能病症关联推理、最佳就医推荐、分级导流以及与院内平台联动,提升患者就诊效率和服务体验。技术架构采用 SpringBoot+Redis+MyBatis Plus+MySQL+RocketMQ,确保高效稳定运行。
274 0
|
7月前
|
存储 人工智能 NoSQL
SpringBoot整合Redis、ApacheSolr和SpringSession
本文介绍了如何使用SpringBoot整合Redis、ApacheSolr和SpringSession。SpringBoot以其便捷的配置方式受到开发者青睐,通过引入对应的starter依赖,可轻松实现功能整合。对于Redis,可通过配置RedisSentinel实现高可用;SpringSession则提供集群Session管理,支持多种存储方式如Redis;整合ApacheSolr时,借助Zookeeper搭建SolrCloud提高可用性。文中详细说明了各组件的配置步骤与代码示例,方便开发者快速上手。
109 11
|
7月前
|
NoSQL Java API
微服务——SpringBoot使用归纳——Spring Boot 中集成Redis——Spring Boot 集成 Redis
本文介绍了在Spring Boot中集成Redis的方法,包括依赖导入、Redis配置及常用API的使用。通过导入`spring-boot-starter-data-redis`依赖和配置`application.yml`文件,可轻松实现Redis集成。文中详细讲解了StringRedisTemplate的使用,适用于字符串操作,并结合FastJSON将实体类转换为JSON存储。还展示了Redis的string、hash和list类型的操作示例。最后总结了Redis在缓存和高并发场景中的应用价值,并提供课程源代码下载链接。
1666 0
|
7月前
|
NoSQL Java Redis
微服务——SpringBoot使用归纳——Spring Boot 中集成Redis——Redis 安装
本教程介绍在 VMware 虚拟机(CentOS 7)或阿里云服务器中安装 Redis 的过程,包括安装 gcc 编译环境、下载 Redis(官网或 wget)、解压安装、修改配置文件(如 bind、daemonize、requirepass 等设置)、启动 Redis 服务及测试客户端连接。通过 set 和 get 命令验证安装是否成功。适用于初学者快速上手 Redis 部署。
156 0
|
存储 SQL 消息中间件
springboot整合redis
redis是一个支持key-value的数据库,数据全部在内存中处理,在在一定时间间隔中将数据固化到磁盘。因为是内存操作,所以速度特别快。(这里我们主要介绍redis作为缓存使用)
263 0
springboot整合redis
|
存储 缓存 NoSQL
SpringBoot整合Redis
SpringBoot整合Redis
516 0
SpringBoot整合Redis

热门文章

最新文章