标签:唯一id
有时候在某些业务中需要先生成一个唯一id,然后再进行存储.可以使用一下的方法:
1.借助mysql或者redis这类能够自增的数据库
这种方式可以满足需求但是需要跟数据库有一次额外的操作.对性能有一定的影响
2.毫秒级的时间加上一个随机数.
这种方式不需要借助数据,性能高些,但是随机数可能会重复,所以结果可能不是全局唯一的
3.毫秒级的时间加上进程id
这种方式可以既满足性能,又是唯一的
对于多核的cpu,每个cpu可以同时执行不同的进程,而每个进程有唯一的id,所以时间可能相同,但是进程的id一定是不同的,这样两者的组合就一定是全局唯一的.
至于选哪中我觉得还是看业务的并发量的.没什么并发的情况下第一种就可以了,虽然会影响性能,但是如果需要查看生成的总数就比较方便了,3比2多了次系统调用,理论上性能要低些.
标签:唯一id
原文地址:http://effective.blog.51cto.com/8296150/1702133