赞
踩
第一种方案:利用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); } }
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。