第一种方案:利用Redis的incr函数
由于Redis是单线程的,因此订单号生成也就不会重复,但是Redis有个非常大的缺陷,那就是不太稳定,容易故障。我们可以使用Redis集群来提高安全性,但是还是有可能集群的所有Redis都挂掉了。因此这种方案不太稳定。
第二种方案:使用uuid的hashCode来生成订单编号
- package com.internet.order;
-
- import java.util.UUID;
-
- public class TestOrder {
-
- public static String getOrderIdByUUId(){
- int machineId = 1;//最大支持1-9个集群机器部署
- int hashCodev = UUID.randomUUID().toString().hashCode();
- System.out.println(UUID.randomUUID().toString());
- if(hashCodev < 0){
- //有可能是负数
- hashCodev = -hashCodev;
- }
- //"%015d"的意思:0代表不足位数的补0,这样可以确保相同的位数,15是位数也就是要得到到的字符串长度是15,d代表数字。
- return machineId + String.format("%015d", hashCodev);
- }
-
-
- public static void main(String[] args) {
- String orderNo = getOrderIdByUUId();
- String orderNo2 = getOrderIdByUUId();
- String orderNo3 = getOrderIdByUUId();
- System.out.println(orderNo);
- System.out.println(orderNo2);
- System.out.println(orderNo3);
- }
- }
第二种方案可以支持非常高的并发,不会重复。