Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
apache
Shardingsphere
提交
99626b56
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 搜索 >>
提交
99626b56
编写于
3月 31, 2018
作者:
T
terrymanu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix gson adapter for config
上级
f96c088e
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
138 addition
and
10 deletion
+138
-10
sharding-jdbc-orchestration/src/main/java/io/shardingjdbc/orchestration/internal/json/KeyGeneratorGsonTypeAdapter.java
...hestration/internal/json/KeyGeneratorGsonTypeAdapter.java
+57
-0
sharding-jdbc-orchestration/src/main/java/io/shardingjdbc/orchestration/internal/json/MasterSlaveLoadBalanceAlgorithmGsonTypeAdapter.java
.../json/MasterSlaveLoadBalanceAlgorithmGsonTypeAdapter.java
+61
-0
sharding-jdbc-orchestration/src/main/java/io/shardingjdbc/orchestration/internal/json/ShardingRuleConfigurationConverter.java
...ion/internal/json/ShardingRuleConfigurationConverter.java
+4
-0
sharding-jdbc-orchestration/src/main/java/io/shardingjdbc/orchestration/internal/json/ShardingStrategyConfigurationGsonTypeAdapter.java
...al/json/ShardingStrategyConfigurationGsonTypeAdapter.java
+7
-3
sharding-jdbc-orchestration/src/test/java/io/shardingjdbc/orchestration/internal/json/ShardingRuleConfigurationConverterTest.java
...internal/json/ShardingRuleConfigurationConverterTest.java
+9
-7
未找到文件。
sharding-jdbc-orchestration/src/main/java/io/shardingjdbc/orchestration/internal/json/KeyGeneratorGsonTypeAdapter.java
0 → 100644
浏览文件 @
99626b56
/*
* Copyright 1999-2015 dangdang.com.
* <p>
* 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.
* </p>
*/
package
io.shardingjdbc.orchestration.internal.json
;
import
com.google.common.base.Preconditions
;
import
com.google.common.base.Strings
;
import
com.google.gson.TypeAdapter
;
import
com.google.gson.stream.JsonReader
;
import
com.google.gson.stream.JsonWriter
;
import
io.shardingjdbc.core.keygen.KeyGenerator
;
import
io.shardingjdbc.core.keygen.KeyGeneratorFactory
;
import
java.io.IOException
;
/**
* Key generator gson type adapter.
*
* @author zhangliang
*/
public
final
class
KeyGeneratorGsonTypeAdapter
extends
TypeAdapter
<
KeyGenerator
>
{
@Override
public
KeyGenerator
read
(
final
JsonReader
in
)
throws
IOException
{
String
keyGeneratorClassName
=
null
;
in
.
beginObject
();
while
(
in
.
hasNext
())
{
Preconditions
.
checkArgument
(
"keyGenerator"
.
equals
(
in
.
nextName
()));
keyGeneratorClassName
=
in
.
nextString
();
}
in
.
endObject
();
return
Strings
.
isNullOrEmpty
(
keyGeneratorClassName
)
?
null
:
KeyGeneratorFactory
.
newInstance
(
keyGeneratorClassName
);
}
@Override
public
void
write
(
final
JsonWriter
out
,
final
KeyGenerator
value
)
throws
IOException
{
out
.
beginObject
();
if
(
null
!=
value
)
{
out
.
name
(
"keyGenerator"
).
value
(
value
.
getClass
().
getName
());
}
out
.
endObject
();
}
}
sharding-jdbc-orchestration/src/main/java/io/shardingjdbc/orchestration/internal/json/MasterSlaveLoadBalanceAlgorithmGsonTypeAdapter.java
0 → 100644
浏览文件 @
99626b56
/*
* Copyright 1999-2015 dangdang.com.
* <p>
* 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.
* </p>
*/
package
io.shardingjdbc.orchestration.internal.json
;
import
com.google.common.base.Preconditions
;
import
com.google.common.base.Strings
;
import
com.google.gson.TypeAdapter
;
import
com.google.gson.stream.JsonReader
;
import
com.google.gson.stream.JsonWriter
;
import
io.shardingjdbc.core.api.algorithm.masterslave.MasterSlaveLoadBalanceAlgorithm
;
import
io.shardingjdbc.core.exception.ShardingJdbcException
;
import
java.io.IOException
;
/**
* Master-slave load balance algorithm gson type adapter.
*
* @author zhangliang
*/
public
final
class
MasterSlaveLoadBalanceAlgorithmGsonTypeAdapter
extends
TypeAdapter
<
MasterSlaveLoadBalanceAlgorithm
>
{
@Override
public
MasterSlaveLoadBalanceAlgorithm
read
(
final
JsonReader
in
)
throws
IOException
{
String
masterSlaveLoadBalanceAlgorithmClassName
=
null
;
in
.
beginObject
();
while
(
in
.
hasNext
())
{
Preconditions
.
checkArgument
(
"masterSlaveLoadBalanceAlgorithm"
.
equals
(
in
.
nextName
()));
masterSlaveLoadBalanceAlgorithmClassName
=
in
.
nextString
();
}
in
.
endObject
();
try
{
return
Strings
.
isNullOrEmpty
(
masterSlaveLoadBalanceAlgorithmClassName
)
?
null
:
(
MasterSlaveLoadBalanceAlgorithm
)
Class
.
forName
(
masterSlaveLoadBalanceAlgorithmClassName
).
newInstance
();
}
catch
(
ReflectiveOperationException
ex
)
{
throw
new
ShardingJdbcException
(
ex
);
}
}
@Override
public
void
write
(
final
JsonWriter
out
,
final
MasterSlaveLoadBalanceAlgorithm
value
)
throws
IOException
{
out
.
beginObject
();
if
(
null
!=
value
)
{
out
.
name
(
"masterSlaveLoadBalanceAlgorithm"
).
value
(
value
.
getClass
().
getName
());
}
out
.
endObject
();
}
}
sharding-jdbc-orchestration/src/main/java/io/shardingjdbc/orchestration/internal/json/ShardingRuleConfigurationConverter.java
浏览文件 @
99626b56
...
...
@@ -17,8 +17,10 @@
package
io.shardingjdbc.orchestration.internal.json
;
import
io.shardingjdbc.core.api.algorithm.masterslave.MasterSlaveLoadBalanceAlgorithm
;
import
io.shardingjdbc.core.api.config.ShardingRuleConfiguration
;
import
io.shardingjdbc.core.api.config.strategy.ShardingStrategyConfiguration
;
import
io.shardingjdbc.core.keygen.KeyGenerator
;
import
lombok.AccessLevel
;
import
lombok.NoArgsConstructor
;
...
...
@@ -32,6 +34,8 @@ public final class ShardingRuleConfigurationConverter {
static
{
GsonFactory
.
registerTypeAdapter
(
ShardingStrategyConfiguration
.
class
,
new
ShardingStrategyConfigurationGsonTypeAdapter
());
GsonFactory
.
registerTypeAdapter
(
KeyGenerator
.
class
,
new
KeyGeneratorGsonTypeAdapter
());
GsonFactory
.
registerTypeAdapter
(
MasterSlaveLoadBalanceAlgorithm
.
class
,
new
MasterSlaveLoadBalanceAlgorithmGsonTypeAdapter
());
}
/**
...
...
sharding-jdbc-orchestration/src/main/java/io/shardingjdbc/orchestration/internal/json/ShardingStrategyConfigurationGsonTypeAdapter.java
浏览文件 @
99626b56
...
...
@@ -17,6 +17,7 @@
package
io.shardingjdbc.orchestration.internal.json
;
import
com.google.common.base.Strings
;
import
com.google.gson.TypeAdapter
;
import
com.google.gson.stream.JsonReader
;
import
com.google.gson.stream.JsonWriter
;
...
...
@@ -88,9 +89,12 @@ public final class ShardingStrategyConfigurationGsonTypeAdapter extends TypeAdap
final
String
algorithmClassName
,
final
String
preciseAlgorithmClassName
,
final
String
rangeAlgorithmClassName
,
final
String
algorithmInlineExpression
)
{
if
(
type
.
equals
(
ShardingStrategyType
.
STANDARD
.
name
()))
{
return
new
StandardShardingStrategyConfiguration
(
shardingColumn
,
ShardingAlgorithmFactory
.
newInstance
(
preciseAlgorithmClassName
,
PreciseShardingAlgorithm
.
class
),
ShardingAlgorithmFactory
.
newInstance
(
rangeAlgorithmClassName
,
RangeShardingAlgorithm
.
class
));
if
(
Strings
.
isNullOrEmpty
(
rangeAlgorithmClassName
))
{
return
new
StandardShardingStrategyConfiguration
(
shardingColumn
,
ShardingAlgorithmFactory
.
newInstance
(
preciseAlgorithmClassName
,
PreciseShardingAlgorithm
.
class
));
}
else
{
return
new
StandardShardingStrategyConfiguration
(
shardingColumn
,
ShardingAlgorithmFactory
.
newInstance
(
preciseAlgorithmClassName
,
PreciseShardingAlgorithm
.
class
),
ShardingAlgorithmFactory
.
newInstance
(
rangeAlgorithmClassName
,
RangeShardingAlgorithm
.
class
));
}
}
if
(
type
.
equals
(
ShardingStrategyType
.
COMPLEX
.
name
()))
{
return
new
ComplexShardingStrategyConfiguration
(
shardingColumns
,
ShardingAlgorithmFactory
.
newInstance
(
algorithmClassName
,
ComplexKeysShardingAlgorithm
.
class
));
...
...
sharding-jdbc-orchestration/src/test/java/io/shardingjdbc/orchestration/internal/json/ShardingRuleConfigurationConverterTest.java
浏览文件 @
99626b56
...
...
@@ -41,11 +41,13 @@ import static org.junit.Assert.assertThat;
public
final
class
ShardingRuleConfigurationConverterTest
{
private
final
String
commonShardingRuleConfigJson
=
"{\"tableRuleConfigs\":[{\"logicTable\":\"t_order\",\"actualDataNodes\":\"t_order_${[0, 1]}\","
+
"\"databaseShardingStrategyConfig\":{},\"tableShardingStrategyConfig\":{}},"
+
"\"databaseShardingStrategyConfig\":{},\"tableShardingStrategyConfig\":{}
,\"keyGenerator\":{}
},"
+
"{\"logicTable\":\"t_order_item\",\"actualDataNodes\":\"t_order_item_${[0, 1]}\","
+
"\"databaseShardingStrategyConfig\":{},\"tableShardingStrategyConfig\":{}}"
+
"\"databaseShardingStrategyConfig\":{},\"tableShardingStrategyConfig\":{}
,\"keyGenerator\":{}
}"
+
"],\"bindingTableGroups\":[\"t_order, t_order_item\"],\"defaultDatabaseShardingStrategyConfig\":{},"
;
private
final
String
defaultKeyGenerator
=
",\"defaultKeyGenerator\":{}"
;
private
final
String
masterSlaveRuleConfigJson
=
",\"masterSlaveRuleConfigs\":[]}"
;
@Test
...
...
@@ -149,27 +151,27 @@ public final class ShardingRuleConfigurationConverterTest {
+
"\"defaultTableShardingStrategyConfig\":{\"type\":\"STANDARD\",\"shardingColumn\":\"order_id\","
+
"\"preciseAlgorithmClassName\":\"io.shardingjdbc.orchestration.internal.json.fixture.TestPreciseShardingAlgorithm\","
+
"\"rangeAlgorithmClassName\":\"io.shardingjdbc.orchestration.internal.json.fixture.TestRangeShardingAlgorithm\"}"
+
masterSlaveRuleConfigJson
;
+
defaultKeyGenerator
+
masterSlaveRuleConfigJson
;
}
private
String
getJsonForComplexStrategy
()
{
return
commonShardingRuleConfigJson
+
"\"defaultTableShardingStrategyConfig\":{\"type\":\"COMPLEX\",\"shardingColumns\":\"order_id,item_id\","
+
"\"algorithmClassName\":\"io.shardingjdbc.orchestration.internal.json.fixture.TestComplexKeysShardingAlgorithm\"}"
+
masterSlaveRuleConfigJson
;
+
defaultKeyGenerator
+
masterSlaveRuleConfigJson
;
}
private
String
getJsonForInlineStrategy
()
{
return
commonShardingRuleConfigJson
+
"\"defaultTableShardingStrategyConfig\":{\"type\":\"INLINE\",\"shardingColumn\":\"order_id\",\"algorithmExpression\":\"order_${user_id % 2}\"}"
+
masterSlaveRuleConfigJson
;
+
defaultKeyGenerator
+
masterSlaveRuleConfigJson
;
}
private
String
getJsonForHintStrategy
()
{
return
commonShardingRuleConfigJson
+
"\"defaultTableShardingStrategyConfig\":{\"type\":\"HINT\","
+
"\"algorithmClassName\":\"io.shardingjdbc.orchestration.internal.json.fixture.TestHintShardingAlgorithm\"}"
+
masterSlaveRuleConfigJson
;
+
"\"algorithmClassName\":\"io.shardingjdbc.orchestration.internal.json.fixture.TestHintShardingAlgorithm\"}"
+
defaultKeyGenerator
+
masterSlaveRuleConfigJson
;
}
private
String
getJsonForNoneStrategy
()
{
return
commonShardingRuleConfigJson
+
"\"defaultTableShardingStrategyConfig\":{\"type\":\"NONE\"}"
+
masterSlaveRuleConfigJson
;
return
commonShardingRuleConfigJson
+
"\"defaultTableShardingStrategyConfig\":{\"type\":\"NONE\"}"
+
defaultKeyGenerator
+
masterSlaveRuleConfigJson
;
}
private
void
assertCommon
(
final
ShardingRuleConfiguration
actual
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录