Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
apache
Shardingsphere
提交
7e64fa1c
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 搜索 >>
未验证
提交
7e64fa1c
编写于
8月 10, 2020
作者:
J
Juan Pan(Trista)
提交者:
GitHub
8月 10, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Orchestration support add new schema (#6754)
上级
b3e95295
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
18 addition
and
13 deletion
+18
-13
shardingsphere-control-panel/shardingsphere-orchestration/shardingsphere-orchestration-core/shardingsphere-orchestration-core-config/src/main/java/org/apache/shardingsphere/orchestration/core/config/ConfigCenter.java
...hardingsphere/orchestration/core/config/ConfigCenter.java
+3
-2
shardingsphere-control-panel/shardingsphere-orchestration/shardingsphere-orchestration-core/shardingsphere-orchestration-core-config/src/main/java/org/apache/shardingsphere/orchestration/core/config/listener/ConfigurationListenerManager.java
...on/core/config/listener/ConfigurationListenerManager.java
+1
-1
shardingsphere-control-panel/shardingsphere-orchestration/shardingsphere-orchestration-core/shardingsphere-orchestration-core-config/src/main/java/org/apache/shardingsphere/orchestration/core/config/listener/SchemaChangedListener.java
...estration/core/config/listener/SchemaChangedListener.java
+14
-10
未找到文件。
shardingsphere-control-panel/shardingsphere-orchestration/shardingsphere-orchestration-core/shardingsphere-orchestration-core-config/src/main/java/org/apache/shardingsphere/orchestration/core/config/ConfigCenter.java
浏览文件 @
7e64fa1c
...
...
@@ -103,9 +103,10 @@ public final class ConfigCenter {
}
private
void
persistDataSourceConfiguration
(
final
String
schemaName
,
final
Map
<
String
,
DataSourceConfiguration
>
dataSourceConfigurations
,
final
boolean
isOverwrite
)
{
if
(
isOverwrite
)
{
persistDataSourceConfiguration
(
schemaName
,
dataSourceConfigurations
)
;
if
(
dataSourceConfigurations
.
isEmpty
()
||
!
isOverwrite
)
{
return
;
}
persistDataSourceConfiguration
(
schemaName
,
dataSourceConfigurations
);
}
private
void
persistDataSourceConfiguration
(
final
String
schemaName
,
final
Map
<
String
,
DataSourceConfiguration
>
dataSourceConfigurations
)
{
...
...
shardingsphere-control-panel/shardingsphere-orchestration/shardingsphere-orchestration-core/shardingsphere-orchestration-core-config/src/main/java/org/apache/shardingsphere/orchestration/core/config/listener/ConfigurationListenerManager.java
浏览文件 @
7e64fa1c
...
...
@@ -49,7 +49,7 @@ public final class ConfigurationListenerManager {
* Initialize all configuration changed listeners.
*/
public
void
initListeners
()
{
schemaChangedListener
.
watch
(
ChangedType
.
UPDATED
,
ChangedType
.
DELETED
);
schemaChangedListener
.
watch
(
ChangedType
.
UPDATED
,
ChangedType
.
DELETED
,
ChangedType
.
ADDED
);
propertiesChangedListener
.
watch
(
ChangedType
.
UPDATED
);
authenticationChangedListener
.
watch
(
ChangedType
.
UPDATED
);
metricsConfigurationChangedListener
.
watch
(
ChangedType
.
UPDATED
);
...
...
shardingsphere-control-panel/shardingsphere-orchestration/shardingsphere-orchestration-core/shardingsphere-orchestration-core-config/src/main/java/org/apache/shardingsphere/orchestration/core/config/listener/SchemaChangedListener.java
浏览文件 @
7e64fa1c
...
...
@@ -75,6 +75,9 @@ public final class SchemaChangedListener extends PostOrchestrationRepositoryEven
if
(
Strings
.
isNullOrEmpty
(
shardingSchemaName
)
||
!
isValidNodeChangedEvent
(
shardingSchemaName
,
event
.
getKey
()))
{
return
new
IgnoredOrchestrationEvent
();
}
if
(
ChangedType
.
ADDED
==
event
.
getChangedType
())
{
return
createAddedEvent
(
shardingSchemaName
);
}
if
(
ChangedType
.
UPDATED
==
event
.
getChangedType
())
{
return
createUpdatedEvent
(
shardingSchemaName
,
event
);
}
...
...
@@ -88,7 +91,7 @@ public final class SchemaChangedListener extends PostOrchestrationRepositoryEven
Collection
<
String
>
persistShardingSchemaNames
=
configurationNode
.
splitSchemaName
(
shardingSchemaNames
);
Set
<
String
>
addedSchemaNames
=
SetUtils
.
difference
(
new
HashSet
<>(
persistShardingSchemaNames
),
new
HashSet
<>(
existedSchemaNames
));
if
(!
addedSchemaNames
.
isEmpty
())
{
return
create
UpdatedEventForNewSchema
(
addedSchemaNames
.
iterator
().
next
());
return
create
AddedEvent
(
addedSchemaNames
.
iterator
().
next
());
}
Set
<
String
>
deletedSchemaNames
=
SetUtils
.
difference
(
new
HashSet
<>(
existedSchemaNames
),
new
HashSet
<>(
persistShardingSchemaNames
));
if
(!
deletedSchemaNames
.
isEmpty
())
{
...
...
@@ -101,8 +104,17 @@ public final class SchemaChangedListener extends PostOrchestrationRepositoryEven
return
configurationNode
.
getDataSourcePath
(
shardingSchemaName
).
equals
(
nodeFullPath
)
||
configurationNode
.
getRulePath
(
shardingSchemaName
).
equals
(
nodeFullPath
);
}
private
OrchestrationEvent
createAddedEvent
(
final
String
shardingSchemaName
)
{
existedSchemaNames
.
add
(
shardingSchemaName
);
if
(!
isOwnCompleteConfigurations
(
shardingSchemaName
))
{
return
new
SchemaAddedEvent
(
shardingSchemaName
,
Collections
.
emptyMap
(),
Collections
.
emptyList
());
}
return
new
SchemaAddedEvent
(
shardingSchemaName
,
configurationService
.
loadDataSourceConfigurations
(
shardingSchemaName
),
createRuleConfigurations
(
shardingSchemaName
));
}
private
OrchestrationEvent
createUpdatedEvent
(
final
String
shardingSchemaName
,
final
DataChangedEvent
event
)
{
return
existedSchemaNames
.
contains
(
shardingSchemaName
)
?
createUpdatedEventForExistedSchema
(
event
,
shardingSchemaName
)
:
createUpdatedEventForNewSchema
(
shardingSchemaName
);
// TODO Consider remove judgement.
return
existedSchemaNames
.
contains
(
shardingSchemaName
)
?
createUpdatedEventForExistedSchema
(
event
,
shardingSchemaName
)
:
createAddedEvent
(
shardingSchemaName
);
}
private
OrchestrationEvent
createUpdatedEventForExistedSchema
(
final
DataChangedEvent
event
,
final
String
shardingSchemaName
)
{
...
...
@@ -125,14 +137,6 @@ public final class SchemaChangedListener extends PostOrchestrationRepositoryEven
shardingSchemaName
,
new
YamlRuleConfigurationSwapperEngine
().
swapToRuleConfigurations
(
configurations
.
getRules
()));
}
private
OrchestrationEvent
createUpdatedEventForNewSchema
(
final
String
shardingSchemaName
)
{
existedSchemaNames
.
add
(
shardingSchemaName
);
if
(!
isOwnCompleteConfigurations
(
shardingSchemaName
))
{
return
new
SchemaAddedEvent
(
shardingSchemaName
,
Collections
.
emptyMap
(),
Collections
.
emptyList
());
}
return
new
SchemaAddedEvent
(
shardingSchemaName
,
configurationService
.
loadDataSourceConfigurations
(
shardingSchemaName
),
createRuleConfigurations
(
shardingSchemaName
));
}
private
boolean
isOwnCompleteConfigurations
(
final
String
shardingSchemaName
)
{
return
configurationService
.
hasDataSourceConfiguration
(
shardingSchemaName
)
&&
configurationService
.
hasRuleConfiguration
(
shardingSchemaName
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录