第一种方案:利用Redis的incr函数
由于Redis是单线程的,因此订单号生成也就不会重复,但是Redis有个非常大的缺陷,那就是不太稳定,容易故障。我们可以使用Redis集群来提高安全性,但是还是有可能集群的所有Redis都挂掉了。因此这种方案不太稳定。
第二种方案:使用uuid的hashCode来生成订单编号(前面可以加上应用机器编号)!
public class PrimaryKey { 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); } }
第二种方案可以支持非常高的并发,不会重复。