Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
apache
SkyWalking
提交
d6f49bc9
S
SkyWalking
项目概览
apache
/
SkyWalking
上一次同步 1 年多
通知
302
Star
21345
Fork
6091
代码
文件
提交
分支
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,发现更多精彩内容 >>
提交
d6f49bc9
编写于
12月 24, 2015
作者:
Z
zhangxin10
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
修复offset文件中的无用文件没有被删除
上级
e22111d5
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
19 addition
and
4 deletion
+19
-4
skywalking-server/src/main/java/com/ai/cloud/skywalking/reciever/persistance/MemoryRegister.java
...cloud/skywalking/reciever/persistance/MemoryRegister.java
+19
-4
未找到文件。
skywalking-server/src/main/java/com/ai/cloud/skywalking/reciever/persistance/MemoryRegister.java
浏览文件 @
d6f49bc9
package
com.ai.cloud.skywalking.reciever.persistance
;
import
com.ai.cloud.skywalking.reciever.conf.Config
;
import
org.apache.logging.log4j.LogManager
;
import
org.apache.logging.log4j.Logger
;
import
java.io.*
;
import
java.util.Arrays
;
import
java.util.Collection
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.concurrent.ConcurrentHashMap
;
...
...
@@ -24,7 +27,7 @@ public class MemoryRegister {
if
(
logger
.
isDebugEnabled
())
{
logger
.
debug
(
"Register entry[{}] into the memory register"
,
fileName
);
}
if
(
entries
.
containsKey
(
fileName
)){
if
(
entries
.
containsKey
(
fileName
))
{
entries
.
get
(
fileName
).
setOffset
(
offset
);
}
}
...
...
@@ -39,7 +42,7 @@ public class MemoryRegister {
}
public
void
removeEntry
(
String
fileName
)
{
public
void
removeEntry
(
String
fileName
)
{
entries
.
remove
(
fileName
);
}
...
...
@@ -96,6 +99,12 @@ public class MemoryRegister {
private
MemoryRegister
()
{
BufferedReader
reader
;
// 在处理数据之前需要初始化处理文件的处理状态
//去掉entries中无法与缓存数据文件匹配的文件
File
parentDir
=
new
File
(
Config
.
Buffer
.
DATA_BUFFER_FILE_PARENT_DIRECTORY
);
//上次未处理的缓存数据文件,entries内的数据主要以缓存
List
<
String
>
bufferFileNameList
=
Arrays
.
asList
(
parentDir
.
list
());
try
{
// 读取offset文件
file
=
new
File
(
REGISTER_FILE_PARENT_DIRECTORY
,
REGISTER_FILE_NAME
);
...
...
@@ -108,7 +117,9 @@ public class MemoryRegister {
String
offsetData
;
while
((
offsetData
=
reader
.
readLine
())
!=
null
&&
!
"EOF"
.
equals
(
offsetData
))
{
String
[]
ss
=
offsetData
.
split
(
"\t"
);
entries
.
put
(
ss
[
0
],
new
FileRegisterEntry
(
ss
[
0
],
Integer
.
valueOf
(
ss
[
1
]),
FileRegisterEntry
.
FileRegisterEntryStatus
.
UNREGISTER
));
if
(
bufferFileNameList
.
contains
(
ss
[
0
]))
{
entries
.
put
(
ss
[
0
],
new
FileRegisterEntry
(
ss
[
0
],
Integer
.
valueOf
(
ss
[
1
]),
FileRegisterEntry
.
FileRegisterEntryStatus
.
UNREGISTER
));
}
}
}
// 创建offset文件
...
...
@@ -120,12 +131,16 @@ public class MemoryRegister {
while
((
offsetData
=
reader
.
readLine
())
!=
null
&&
!
"EOF"
.
equals
(
offsetData
))
{
try
{
String
[]
ss
=
offsetData
.
split
(
"\t"
);
entries
.
put
(
ss
[
0
],
new
FileRegisterEntry
(
ss
[
0
],
Integer
.
valueOf
(
ss
[
1
]),
FileRegisterEntry
.
FileRegisterEntryStatus
.
UNREGISTER
));
if
(
bufferFileNameList
.
contains
(
ss
[
0
]))
{
entries
.
put
(
ss
[
0
],
new
FileRegisterEntry
(
ss
[
0
],
Integer
.
valueOf
(
ss
[
1
]),
FileRegisterEntry
.
FileRegisterEntryStatus
.
UNREGISTER
));
}
}
catch
(
Exception
e
)
{
continue
;
}
}
}
}
catch
(
FileNotFoundException
e
)
{
logger
.
error
(
"The offset file does not exist."
,
e
);
checkOffSetExists
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录