Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
山不在高_有仙则灵
SkyWalking
提交
06c357da
S
SkyWalking
项目概览
山不在高_有仙则灵
/
SkyWalking
与 Fork 源项目一致
Fork自
apache / SkyWalking
通知
12
Star
0
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
SkyWalking
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
06c357da
编写于
9月 17, 2019
作者:
wu-sheng
提交者:
GitHub
9月 17, 2019
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Make sure the cluster register happens before streaming process. (#3471)
上级
c5b03ba7
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
27 addition
and
11 deletion
+27
-11
oap-server/server-core/src/main/java/org/apache/skywalking/oap/server/core/CoreModuleProvider.java
...apache/skywalking/oap/server/core/CoreModuleProvider.java
+6
-5
oap-server/server-core/src/main/java/org/apache/skywalking/oap/server/core/remote/RemoteSenderService.java
...kywalking/oap/server/core/remote/RemoteSenderService.java
+21
-6
未找到文件。
oap-server/server-core/src/main/java/org/apache/skywalking/oap/server/core/CoreModuleProvider.java
浏览文件 @
06c357da
...
...
@@ -185,6 +185,12 @@ public class CoreModuleProvider extends ModuleProvider {
}
catch
(
IOException
|
IllegalAccessException
|
InstantiationException
e
)
{
throw
new
ModuleStartException
(
e
.
getMessage
(),
e
);
}
if
(
CoreModuleConfig
.
Role
.
Mixed
.
name
().
equalsIgnoreCase
(
moduleConfig
.
getRole
())
||
CoreModuleConfig
.
Role
.
Aggregator
.
name
().
equalsIgnoreCase
(
moduleConfig
.
getRole
()))
{
RemoteInstance
gRPCServerInstance
=
new
RemoteInstance
(
new
Address
(
moduleConfig
.
getGRPCHost
(),
moduleConfig
.
getGRPCPort
(),
true
));
this
.
getManager
().
find
(
ClusterModule
.
NAME
).
provider
().
getService
(
ClusterRegister
.
class
).
registerRemote
(
gRPCServerInstance
);
}
}
@Override
public
void
notifyAfterCompleted
()
throws
ModuleStartException
{
...
...
@@ -195,11 +201,6 @@ public class CoreModuleProvider extends ModuleProvider {
throw
new
ModuleStartException
(
e
.
getMessage
(),
e
);
}
if
(
CoreModuleConfig
.
Role
.
Mixed
.
name
().
equalsIgnoreCase
(
moduleConfig
.
getRole
())
||
CoreModuleConfig
.
Role
.
Aggregator
.
name
().
equalsIgnoreCase
(
moduleConfig
.
getRole
()))
{
RemoteInstance
gRPCServerInstance
=
new
RemoteInstance
(
new
Address
(
moduleConfig
.
getGRPCHost
(),
moduleConfig
.
getGRPCPort
(),
true
));
this
.
getManager
().
find
(
ClusterModule
.
NAME
).
provider
().
getService
(
ClusterRegister
.
class
).
registerRemote
(
gRPCServerInstance
);
}
PersistenceTimer
.
INSTANCE
.
start
(
getManager
(),
moduleConfig
);
if
(
moduleConfig
.
isEnableDataKeeperExecutor
())
{
...
...
oap-server/server-core/src/main/java/org/apache/skywalking/oap/server/core/remote/RemoteSenderService.java
浏览文件 @
06c357da
...
...
@@ -18,16 +18,25 @@
package
org.apache.skywalking.oap.server.core.remote
;
import
java.util.List
;
import
org.apache.skywalking.oap.server.core.CoreModule
;
import
org.apache.skywalking.oap.server.core.remote.client.*
;
import
org.apache.skywalking.oap.server.core.remote.client.RemoteClient
;
import
org.apache.skywalking.oap.server.core.remote.client.RemoteClientManager
;
import
org.apache.skywalking.oap.server.core.remote.data.StreamData
;
import
org.apache.skywalking.oap.server.core.remote.selector.*
;
import
org.apache.skywalking.oap.server.library.module.*
;
import
org.apache.skywalking.oap.server.core.remote.selector.ForeverFirstSelector
;
import
org.apache.skywalking.oap.server.core.remote.selector.HashCodeSelector
;
import
org.apache.skywalking.oap.server.core.remote.selector.RollingSelector
;
import
org.apache.skywalking.oap.server.core.remote.selector.Selector
;
import
org.apache.skywalking.oap.server.library.module.ModuleManager
;
import
org.apache.skywalking.oap.server.library.module.Service
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
/**
* @author peng-yongsheng
*/
public
class
RemoteSenderService
implements
Service
{
private
static
final
Logger
logger
=
LoggerFactory
.
getLogger
(
RemoteSenderService
.
class
);
private
final
ModuleManager
moduleManager
;
private
final
HashCodeSelector
hashCodeSelector
;
...
...
@@ -44,18 +53,24 @@ public class RemoteSenderService implements Service {
public
void
send
(
String
nextWorkName
,
StreamData
streamData
,
Selector
selector
)
{
RemoteClientManager
clientManager
=
moduleManager
.
find
(
CoreModule
.
NAME
).
provider
().
getService
(
RemoteClientManager
.
class
);
List
<
RemoteClient
>
clientList
=
clientManager
.
getRemoteClient
();
if
(
clientList
.
size
()
==
0
)
{
logger
.
warn
(
"There is no available remote server for now, ignore the streaming data until the cluster metadata initialized."
);
return
;
}
RemoteClient
remoteClient
;
switch
(
selector
)
{
case
HashCode:
remoteClient
=
hashCodeSelector
.
select
(
client
Manager
.
getRemoteClient
()
,
streamData
);
remoteClient
=
hashCodeSelector
.
select
(
client
List
,
streamData
);
remoteClient
.
push
(
nextWorkName
,
streamData
);
break
;
case
Rolling:
remoteClient
=
rollingSelector
.
select
(
client
Manager
.
getRemoteClient
()
,
streamData
);
remoteClient
=
rollingSelector
.
select
(
client
List
,
streamData
);
remoteClient
.
push
(
nextWorkName
,
streamData
);
break
;
case
ForeverFirst:
remoteClient
=
foreverFirstSelector
.
select
(
client
Manager
.
getRemoteClient
()
,
streamData
);
remoteClient
=
foreverFirstSelector
.
select
(
client
List
,
streamData
);
remoteClient
.
push
(
nextWorkName
,
streamData
);
break
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录