Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Apache RocketMQ
Rocketmq
提交
b30bd870
R
Rocketmq
项目概览
Apache RocketMQ
/
Rocketmq
上一次同步 大约 3 年
通知
266
Star
16139
Fork
68
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
Rocketmq
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
未验证
提交
b30bd870
编写于
9月 27, 2021
作者:
G
Git_Yang
提交者:
GitHub
9月 27, 2021
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[ISSUE #2667] Repair 'file doesn't exist on this path'
Signed-off-by:
N
zhangyang
<
Git_Yang@163.com
>
上级
d429aa24
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
25 addition
and
5 deletion
+25
-5
store/src/main/java/org/apache/rocketmq/store/DefaultMessageStore.java
...n/java/org/apache/rocketmq/store/DefaultMessageStore.java
+9
-5
store/src/test/java/org/apache/rocketmq/store/DefaultMessageStoreTest.java
...va/org/apache/rocketmq/store/DefaultMessageStoreTest.java
+16
-0
未找到文件。
store/src/main/java/org/apache/rocketmq/store/DefaultMessageStore.java
浏览文件 @
b30bd870
...
...
@@ -164,6 +164,8 @@ public class DefaultMessageStore implements MessageStore {
File
file
=
new
File
(
StorePathConfigHelper
.
getLockFile
(
messageStoreConfig
.
getStorePathRootDir
()));
MappedFile
.
ensureDirOK
(
file
.
getParent
());
MappedFile
.
ensureDirOK
(
getStorePathPhysic
());
MappedFile
.
ensureDirOK
(
getStorePathLogic
());
lockFile
=
new
RandomAccessFile
(
file
,
"rw"
);
}
...
...
@@ -779,8 +781,8 @@ public class DefaultMessageStore implements MessageStore {
return
this
.
storeStatsService
.
toString
();
}
p
rivate
String
getStorePathPhysic
()
{
String
storePathPhysic
=
""
;
p
ublic
String
getStorePathPhysic
()
{
String
storePathPhysic
;
if
(
DefaultMessageStore
.
this
.
getMessageStoreConfig
().
isEnableDLegerCommitLog
())
{
storePathPhysic
=
((
DLedgerCommitLog
)
DefaultMessageStore
.
this
.
getCommitLog
()).
getdLedgerServer
().
getdLedgerConfig
().
getDataStorePath
();
}
else
{
...
...
@@ -789,6 +791,10 @@ public class DefaultMessageStore implements MessageStore {
return
storePathPhysic
;
}
public
String
getStorePathLogic
()
{
return
StorePathConfigHelper
.
getStorePathConsumeQueue
(
this
.
messageStoreConfig
.
getStorePathRootDir
());
}
@Override
public
HashMap
<
String
,
String
>
getRuntimeInfo
()
{
HashMap
<
String
,
String
>
result
=
this
.
storeStatsService
.
getRuntimeInfo
();
...
...
@@ -807,9 +813,7 @@ public class DefaultMessageStore implements MessageStore {
}
{
String
storePathLogics
=
StorePathConfigHelper
.
getStorePathConsumeQueue
(
this
.
messageStoreConfig
.
getStorePathRootDir
());
double
logicsRatio
=
UtilAll
.
isPathExists
(
storePathLogics
)
?
UtilAll
.
getDiskPartitionSpaceUsedPercent
(
storePathLogics
)
:
-
1
;
double
logicsRatio
=
UtilAll
.
getDiskPartitionSpaceUsedPercent
(
getStorePathLogic
());
result
.
put
(
RunningStats
.
consumeQueueDiskRatio
.
name
(),
String
.
valueOf
(
logicsRatio
));
}
...
...
store/src/test/java/org/apache/rocketmq/store/DefaultMessageStoreTest.java
浏览文件 @
b30bd870
...
...
@@ -605,6 +605,22 @@ public class DefaultMessageStoreTest {
}
}
@Test
public
void
testStorePathOK
()
{
if
(
messageStore
instanceof
DefaultMessageStore
)
{
assertTrue
(
fileExists
(((
DefaultMessageStore
)
messageStore
).
getStorePathPhysic
()));
assertTrue
(
fileExists
(((
DefaultMessageStore
)
messageStore
).
getStorePathLogic
()));
}
}
private
boolean
fileExists
(
String
path
)
{
if
(
path
!=
null
)
{
File
f
=
new
File
(
path
);
return
f
.
exists
();
}
return
false
;
}
private
void
damageCommitlog
(
long
offset
)
throws
Exception
{
MessageStoreConfig
messageStoreConfig
=
new
MessageStoreConfig
();
File
file
=
new
File
(
messageStoreConfig
.
getStorePathCommitLog
()
+
File
.
separator
+
"00000000000000000000"
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录