Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
apache
Shardingsphere
提交
c11bfff3
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,发现更多精彩内容 >>
未验证
提交
c11bfff3
编写于
10月 30, 2020
作者:
Z
Zhang Yonglun
提交者:
GitHub
10月 30, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
#7318, add governance updater (#7979)
上级
d666bbf6
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
71 addition
and
1 deletion
+71
-1
shardingsphere-governance/shardingsphere-governance-core/shardingsphere-governance-core-facade/src/main/java/org/apache/shardingsphere/governance/core/facade/GovernanceFacade.java
...ardingsphere/governance/core/facade/GovernanceFacade.java
+12
-0
shardingsphere-proxy/shardingsphere-proxy-bootstrap/src/main/java/org/apache/shardingsphere/proxy/initializer/impl/GovernanceBootstrapInitializer.java
...roxy/initializer/impl/GovernanceBootstrapInitializer.java
+2
-1
shardingsphere-proxy/shardingsphere-proxy-common/pom.xml
shardingsphere-proxy/shardingsphere-proxy-common/pom.xml
+5
-0
shardingsphere-proxy/shardingsphere-proxy-common/src/main/java/org/apache/shardingsphere/proxy/config/ProxyConfigurationUpdater.java
...hardingsphere/proxy/config/ProxyConfigurationUpdater.java
+52
-0
未找到文件。
shardingsphere-governance/shardingsphere-governance-core/shardingsphere-governance-core-facade/src/main/java/org/apache/shardingsphere/governance/core/facade/GovernanceFacade.java
浏览文件 @
c11bfff3
...
@@ -90,6 +90,18 @@ public final class GovernanceFacade implements AutoCloseable {
...
@@ -90,6 +90,18 @@ public final class GovernanceFacade implements AutoCloseable {
listenerManager
.
init
();
listenerManager
.
init
();
}
}
/**
* Update configurations.
*
* @param dataSourceConfigMap schema data source configuration map
* @param schemaRuleMap schema rule map
*/
public
void
updateConfigurations
(
final
Map
<
String
,
Map
<
String
,
DataSourceConfiguration
>>
dataSourceConfigMap
,
final
Map
<
String
,
Collection
<
RuleConfiguration
>>
schemaRuleMap
)
{
for
(
Entry
<
String
,
Map
<
String
,
DataSourceConfiguration
>>
entry
:
dataSourceConfigMap
.
entrySet
())
{
configCenter
.
persistConfigurations
(
entry
.
getKey
(),
dataSourceConfigMap
.
get
(
entry
.
getKey
()),
schemaRuleMap
.
get
(
entry
.
getKey
()),
true
);
}
}
@Override
@Override
public
void
close
()
{
public
void
close
()
{
repositoryFacade
.
close
();
repositoryFacade
.
close
();
...
...
shardingsphere-proxy/shardingsphere-proxy-bootstrap/src/main/java/org/apache/shardingsphere/proxy/initializer/impl/GovernanceBootstrapInitializer.java
浏览文件 @
c11bfff3
...
@@ -30,6 +30,7 @@ import org.apache.shardingsphere.infra.context.schema.SchemaContexts;
...
@@ -30,6 +30,7 @@ import org.apache.shardingsphere.infra.context.schema.SchemaContexts;
import
org.apache.shardingsphere.infra.config.datasource.DataSourceParameter
;
import
org.apache.shardingsphere.infra.config.datasource.DataSourceParameter
;
import
org.apache.shardingsphere.infra.yaml.swapper.YamlRuleConfigurationSwapperEngine
;
import
org.apache.shardingsphere.infra.yaml.swapper.YamlRuleConfigurationSwapperEngine
;
import
org.apache.shardingsphere.proxy.config.ProxyConfiguration
;
import
org.apache.shardingsphere.proxy.config.ProxyConfiguration
;
import
org.apache.shardingsphere.proxy.config.ProxyConfigurationUpdater
;
import
org.apache.shardingsphere.proxy.config.YamlProxyConfiguration
;
import
org.apache.shardingsphere.proxy.config.YamlProxyConfiguration
;
import
org.apache.shardingsphere.proxy.config.util.DataSourceParameterConverter
;
import
org.apache.shardingsphere.proxy.config.util.DataSourceParameterConverter
;
import
org.apache.shardingsphere.proxy.config.yaml.YamlProxyRuleConfiguration
;
import
org.apache.shardingsphere.proxy.config.yaml.YamlProxyRuleConfiguration
;
...
@@ -48,7 +49,7 @@ import java.util.stream.Collectors;
...
@@ -48,7 +49,7 @@ import java.util.stream.Collectors;
*/
*/
public
final
class
GovernanceBootstrapInitializer
extends
AbstractBootstrapInitializer
{
public
final
class
GovernanceBootstrapInitializer
extends
AbstractBootstrapInitializer
{
private
final
GovernanceFacade
governanceFacade
=
new
GovernanceFacade
();
private
final
GovernanceFacade
governanceFacade
=
ProxyConfigurationUpdater
.
get
GovernanceFacade
();
@Override
@Override
protected
ProxyConfiguration
getProxyConfiguration
(
final
YamlProxyConfiguration
yamlConfig
)
{
protected
ProxyConfiguration
getProxyConfiguration
(
final
YamlProxyConfiguration
yamlConfig
)
{
...
...
shardingsphere-proxy/shardingsphere-proxy-common/pom.xml
浏览文件 @
c11bfff3
...
@@ -37,6 +37,11 @@
...
@@ -37,6 +37,11 @@
<artifactId>
shardingsphere-governance-core-common
</artifactId>
<artifactId>
shardingsphere-governance-core-common
</artifactId>
<version>
${project.version}
</version>
<version>
${project.version}
</version>
</dependency>
</dependency>
<dependency>
<groupId>
org.apache.shardingsphere
</groupId>
<artifactId>
shardingsphere-governance-core-facade
</artifactId>
<version>
${project.version}
</version>
</dependency>
<dependency>
<dependency>
<groupId>
org.apache.shardingsphere
</groupId>
<groupId>
org.apache.shardingsphere
</groupId>
<artifactId>
shardingsphere-infra-context
</artifactId>
<artifactId>
shardingsphere-infra-context
</artifactId>
...
...
shardingsphere-proxy/shardingsphere-proxy-common/src/main/java/org/apache/shardingsphere/proxy/config/ProxyConfigurationUpdater.java
0 → 100644
浏览文件 @
c11bfff3
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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
org.apache.shardingsphere.proxy.config
;
import
org.apache.shardingsphere.governance.core.facade.GovernanceFacade
;
import
org.apache.shardingsphere.infra.config.RuleConfiguration
;
import
org.apache.shardingsphere.infra.config.datasource.DataSourceConfiguration
;
import
java.util.Collection
;
import
java.util.Map
;
/**
* Proxy configuration updater.
*/
public
final
class
ProxyConfigurationUpdater
{
private
static
final
GovernanceFacade
GOVERNANCE_FACADE
=
new
GovernanceFacade
();
/**
* Get governance facade.
*
* @return governance facade
*/
public
static
GovernanceFacade
getGovernanceFacade
()
{
return
GOVERNANCE_FACADE
;
}
/**
* Update configurations.
*
* @param dataSourceConfigMap data source config map
* @param schemaRuleMap schema rule map
*/
public
static
void
update
(
final
Map
<
String
,
Map
<
String
,
DataSourceConfiguration
>>
dataSourceConfigMap
,
final
Map
<
String
,
Collection
<
RuleConfiguration
>>
schemaRuleMap
)
{
GOVERNANCE_FACADE
.
updateConfigurations
(
dataSourceConfigMap
,
schemaRuleMap
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录