參考snowflake算法,基本思路:
序列12位(更格式化的輸出后,性能損耗導(dǎo)致每毫秒生成不了這么多,所以可以考慮減少這里的位,不過留著也并無影響)
機(jī)器位10位
毫秒為左移 22位
上述幾個做或運算后得出一個唯一的數(shù),轉(zhuǎn)10進(jìn)制后,最大10位,最小7位,string.format來統(tǒng)一為10,format性能影響,導(dǎo)致性能降低3倍左右
FilUtils不想用的話,1太機(jī)器可以直接考慮使用1,多機(jī)器根據(jù)代碼配置id
代碼如下:
package net.gitosc.lianqu1990.utils.code;import net.gitosc.lianqu1990.utils.date.DateFormatUtils;import net.gitosc.lianqu1990.utils.date.TimeMark;import org.apache.commons.io.FileUtils;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import java.io.File;/** * 缺陷是,訂單量沒那么大,導(dǎo)致機(jī)器碼|序列 后,一般都是4096 * 通過將毫秒引入序列后修正 * 后來加了format以后性能受損,比idcenter慢10倍,每秒可以生成50w,idcenter將近500w,不過這也是idcenter極限 * 夠用,暫不優(yōu)化 * @author hanchao * @date 2017/4/20 19:01 */public class OrderNoCenter { public static final Logger logger = LoggerFactory.getLogger(OrderNoCenter.class); private static final String WORKERID_PATH = "/etc/workerId"; private OrderNoCenter() { } private static class OrderNoCenterHolder{ private static OrderNoCenter instance = new OrderNoCenter(); } public static OrderNoCenter getInstance() { return OrderNoCenterHolder.instance; } /** * 節(jié)點 ID 默認(rèn)取1&