Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
C
commons
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
3
Merge Requests
3
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
DevOps
commons
Commits
70a7c44a
Commit
70a7c44a
authored
May 09, 2018
by
xiaoguang.xu
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'remotes/origin/new_id_generator' into feature/0.2.0
parents
3b3deea6
7e7aa7cc
Changes
6
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
239 additions
and
127 deletions
+239
-127
OIDGenerator.java
...g/src/main/java/cn/quantgroup/tech/util/OIDGenerator.java
+1
-1
BitsAllocator.java
...c/main/java/cn/quantgroup/tech/util/id/BitsAllocator.java
+0
-18
DisposableWorkerIdAssigner.java
...n/quantgroup/tech/util/id/DisposableWorkerIdAssigner.java
+0
-46
IDGenerateException.java
.../java/cn/quantgroup/tech/util/id/IDGenerateException.java
+4
-35
IDGenerator.java
...src/main/java/cn/quantgroup/tech/util/id/IDGenerator.java
+234
-0
UidGenerator.java
...rc/main/java/cn/quantgroup/tech/util/id/UidGenerator.java
+0
-27
No files found.
commons-spring/src/main/java/cn/quantgroup/tech/util/IDGenerator.java
→
commons-spring/src/main/java/cn/quantgroup/tech/util/
O
IDGenerator.java
View file @
70a7c44a
...
@@ -35,7 +35,7 @@ import java.util.concurrent.locks.ReentrantLock;
...
@@ -35,7 +35,7 @@ import java.util.concurrent.locks.ReentrantLock;
@Component
@Component
@ConditionalOnClass
(
RedisTemplate
.
class
)
@ConditionalOnClass
(
RedisTemplate
.
class
)
@ConditionalOnProperty
(
name
=
"data.center.id"
)
@ConditionalOnProperty
(
name
=
"data.center.id"
)
public
class
IDGenerator
{
public
class
O
IDGenerator
{
private
static
final
String
REDIS_WORK_ID_KEY
=
"GLOBAL:WORK:ID:"
;
private
static
final
String
REDIS_WORK_ID_KEY
=
"GLOBAL:WORK:ID:"
;
private
static
final
String
ID_FORMAT
=
"yyyyMMddHHmmss"
;
private
static
final
String
ID_FORMAT
=
"yyyyMMddHHmmss"
;
...
...
commons-spring/src/main/java/cn/quantgroup/tech/util/id/BitsAllocator.java
View file @
70a7c44a
/*
* Copyright (c) 2017 Baidu, Inc. All Rights Reserve.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package
cn
.
quantgroup
.
tech
.
util
.
id
;
package
cn
.
quantgroup
.
tech
.
util
.
id
;
import
org.apache.commons.lang3.builder.ToStringBuilder
;
import
org.apache.commons.lang3.builder.ToStringBuilder
;
...
@@ -24,8 +9,6 @@ import java.math.BigInteger;
...
@@ -24,8 +9,6 @@ import java.math.BigInteger;
/**
/**
* Allocate 64 bits for the UID(long)<br>
* Allocate 64 bits for the UID(long)<br>
* sign (fixed 1bit) -> deltaSecond -> workerId -> sequence(within the same second)
* sign (fixed 1bit) -> deltaSecond -> workerId -> sequence(within the same second)
*
* @author yutianbao
*/
*/
public
class
BitsAllocator
{
public
class
BitsAllocator
{
/**
/**
...
@@ -81,7 +64,6 @@ public class BitsAllocator {
...
@@ -81,7 +64,6 @@ public class BitsAllocator {
/**
/**
* Allocate bits for UID according to delta seconds & workerId & sequence<br>
* Allocate bits for UID according to delta seconds & workerId & sequence<br>
* <b>Note that: </b>The highest bit will always be 0 for sign
*
*
* @param deltaSeconds
* @param deltaSeconds
* @param workerId
* @param workerId
...
...
commons-spring/src/main/java/cn/quantgroup/tech/util/id/DisposableWorkerIdAssigner.java
deleted
100644 → 0
View file @
3b3deea6
/*
* Copyright (c) 2017 Baidu, Inc. All Rights Reserve.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package
cn
.
quantgroup
.
tech
.
util
.
id
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.data.redis.core.StringRedisTemplate
;
import
org.springframework.stereotype.Component
;
@Component
public
class
DisposableWorkerIdAssigner
{
private
static
final
Logger
LOGGER
=
LoggerFactory
.
getLogger
(
DisposableWorkerIdAssigner
.
class
);
private
static
final
String
REDIS_WORK_ID_KEY
=
"GLOBAL:WORK:ID:"
;
@Autowired
private
StringRedisTemplate
redisTemplate
;
/**
* Assign worker id base on database.<p>
* If there is host name & port in the environment, we considered that the node runs in Docker container<br>
* Otherwise, the node runs on an actual machine.
*
* @param dataCenterId
* @param bitsAllocator
* @return assigned worker id
*/
public
long
assignWorkerId
(
long
dataCenterId
,
BitsAllocator
bitsAllocator
)
{
return
redisTemplate
.
opsForValue
().
increment
(
REDIS_WORK_ID_KEY
+
dataCenterId
,
1
)
%
bitsAllocator
.
getMaxWorkerId
();
}
}
commons-spring/src/main/java/cn/quantgroup/tech/util/id/
Uid
GenerateException.java
→
commons-spring/src/main/java/cn/quantgroup/tech/util/id/
ID
GenerateException.java
View file @
70a7c44a
...
@@ -16,11 +16,9 @@
...
@@ -16,11 +16,9 @@
package
cn
.
quantgroup
.
tech
.
util
.
id
;
package
cn
.
quantgroup
.
tech
.
util
.
id
;
/**
/**
* UidGenerateException
* IDGenerateException
*
* @author yutianbao
*/
*/
public
class
Uid
GenerateException
extends
RuntimeException
{
public
class
ID
GenerateException
extends
RuntimeException
{
/**
/**
* Serial Version UID
* Serial Version UID
...
@@ -30,45 +28,16 @@ public class UidGenerateException extends RuntimeException {
...
@@ -30,45 +28,16 @@ public class UidGenerateException extends RuntimeException {
/**
/**
* Default constructor
* Default constructor
*/
*/
public
Uid
GenerateException
()
{
public
ID
GenerateException
()
{
super
();
super
();
}
}
/**
* Constructor with message & cause
*
* @param message
* @param cause
*/
public
UidGenerateException
(
String
message
,
Throwable
cause
)
{
super
(
message
,
cause
);
}
/**
* Constructor with message
*
* @param message
*/
public
UidGenerateException
(
String
message
)
{
super
(
message
);
}
/**
* Constructor with message format
*
* @param msgFormat
* @param args
*/
public
UidGenerateException
(
String
msgFormat
,
Object
...
args
)
{
super
(
String
.
format
(
msgFormat
,
args
));
}
/**
/**
* Constructor with cause
* Constructor with cause
*
*
* @param cause
* @param cause
*/
*/
public
Uid
GenerateException
(
Throwable
cause
)
{
public
ID
GenerateException
(
Throwable
cause
)
{
super
(
cause
);
super
(
cause
);
}
}
...
...
commons-spring/src/main/java/cn/quantgroup/tech/util/id/
DefaultUid
Generator.java
→
commons-spring/src/main/java/cn/quantgroup/tech/util/id/
ID
Generator.java
View file @
70a7c44a
This diff is collapsed.
Click to expand it.
commons-spring/src/main/java/cn/quantgroup/tech/util/id/UidGenerator.java
deleted
100644 → 0
View file @
3b3deea6
package
cn
.
quantgroup
.
tech
.
util
.
id
;
/**
* Represents a unique id generator.
*
* @author yutianbao
*/
public
interface
UidGenerator
{
/**
* Get a unique ID
*
* @return UID
* @throws UidGenerateException
*/
String
getUID
(
String
preFix
)
throws
UidGenerateException
;
/**
* Parse the UID into elements which are used to generate the UID. <br>
* Such as timestamp & workerId & sequence...
*
* @param uid
* @return Parsed info
*/
String
parseUID
(
String
uid
);
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment