Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
apache
Shardingsphere
提交
ab78772d
Shardingsphere
项目概览
apache
/
Shardingsphere
通知
56
Star
3
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
Shardingsphere
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
ab78772d
编写于
12月 15, 2016
作者:
G
gaohongtao
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fixed #191 Using IP lowest bit to generate worker id
上级
3eed43bf
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
20 addition
and
8 deletion
+20
-8
sharding-jdbc-doc/content/post/release_notes.md
sharding-jdbc-doc/content/post/release_notes.md
+5
-0
sharding-jdbc-id-generator-parent/sharding-jdbc-self-id-generator/src/main/java/com/dangdang/ddframe/rdb/sharding/id/generator/self/CommonSelfIdGenerator.java
...rdb/sharding/id/generator/self/CommonSelfIdGenerator.java
+9
-0
sharding-jdbc-id-generator-parent/sharding-jdbc-self-id-generator/src/main/java/com/dangdang/ddframe/rdb/sharding/id/generator/self/IPIdGenerator.java
...ddframe/rdb/sharding/id/generator/self/IPIdGenerator.java
+6
-8
未找到文件。
sharding-jdbc-doc/content/post/release_notes.md
浏览文件 @
ab78772d
...
...
@@ -8,6 +8,11 @@ weight = 1
## 1.4.1-SNAPSHOT
### 功能提升
1.
[
ISSUE #191
](
https://github.com/dangdangdotcom/sharding-jdbc/issues/191
)
根据主机的IP生成workerId的IdGenerator实现
1.
[
ISSUE #192
](
https://github.com/dangdangdotcom/sharding-jdbc/issues/192
)
根据HOSTNAME的数字尾缀获取workerId的IdGenerator
### 缺陷修正
1.
[
ISSUE #194
](
https://github.com/dangdangdotcom/sharding-jdbc/issues/194
)
jdbc接口中资源释放错误
...
...
sharding-jdbc-id-generator-parent/sharding-jdbc-self-id-generator/src/main/java/com/dangdang/ddframe/rdb/sharding/id/generator/self/CommonSelfIdGenerator.java
浏览文件 @
ab78772d
...
...
@@ -112,6 +112,15 @@ public class CommonSelfIdGenerator implements IdGenerator {
CommonSelfIdGenerator
.
workerId
=
workerId
;
}
/**
* 获取工作Id的二进制长度.
*
* @return 工作Id的二进制长度
*/
public
static
long
getWorkerIdLength
()
{
return
WORKER_ID_BITS
;
}
/**
* 生成Id.
*
...
...
sharding-jdbc-id-generator-parent/sharding-jdbc-self-id-generator/src/main/java/com/dangdang/ddframe/rdb/sharding/id/generator/self/IPIdGenerator.java
浏览文件 @
ab78772d
...
...
@@ -23,9 +23,9 @@ import java.net.InetAddress;
import
java.net.UnknownHostException
;
/**
* 根据机器IP获取工作进程Id
,如果线上机器的IP二进制表示的最后10位不重复,
建议使用此种方式
*
,列如机器的IP为192.168.1.108,二进制表示:
11000000 10101000 00000001 01101100
*
,截取最后10位 01 01101100,转为十进制364,设置workerId为364
* 根据机器IP获取工作进程Id
,如果线上机器的IP二进制表示的最后10位不重复,
建议使用此种方式
*
,列如机器的IP为192.168.1.108,二进制表示:
11000000 10101000 00000001 01101100
*
,截取最后10位 01 01101100,转为十进制364,设置workerId为364.
*
* @author DonneyYoung
*/
...
...
@@ -39,15 +39,13 @@ public class IPIdGenerator implements IdGenerator {
static
void
initWorkerId
()
{
InetAddress
address
;
Long
workerId
;
try
{
address
=
InetAddress
.
getLocalHost
();
}
catch
(
UnknownHostException
e
)
{
}
catch
(
final
UnknownHostException
e
)
{
throw
new
IllegalStateException
(
"Cannot get LocalHost InetAddress, please check your network!"
);
}
String
[]
ipAddress
=
address
.
getHostAddress
().
split
(
"\\."
);
workerId
=
((
Long
.
valueOf
(
ipAddress
[
ipAddress
.
length
-
2
])
&
0b11
)
<<
8
)
+
Long
.
valueOf
(
ipAddress
[
ipAddress
.
length
-
1
]);
CommonSelfIdGenerator
.
setWorkerId
(
workerId
);
byte
[]
ipAddressByteArray
=
address
.
getAddress
();
CommonSelfIdGenerator
.
setWorkerId
((
long
)
(((
ipAddressByteArray
[
ipAddressByteArray
.
length
-
2
]
&
0B11
)
<<
Byte
.
SIZE
)
+
(
ipAddressByteArray
[
ipAddressByteArray
.
length
-
1
]
&
0xFF
)));
}
@Override
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录