Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
为 GitLab 提交贡献
登录/注册
切换导航
H
h2database
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
Administrator
h2database
Commits
8497c759
提交
8497c759
authored
10 年前
作者:
Thomas Mueller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
MVStore: deal with the case that data was moved to a new chunk (work in progress)
上级
d476faca
master
noel-pr1
plus33-master
pr/267
stumc-Issue#576
version-1.4.198
version-1.4.197
version-1.4.196
version-1.4.195
version-1.4.194
version-1.4.193
version-1.4.192
version-1.4.191
version-1.4.190
version-1.4.188
version-1.4.187
version-1.4.186
version-1.4.185
version-1.4.184
version-1.4.183
version-1.4.182
version-1.4.181
无相关合并请求
隐藏空白字符变更
内嵌
并排
正在显示
9 个修改的文件
包含
150 行增加
和
16 行删除
+150
-16
DataUtils.java
h2/src/main/org/h2/mvstore/DataUtils.java
+6
-0
MVMap.java
h2/src/main/org/h2/mvstore/MVMap.java
+10
-2
MVStore.java
h2/src/main/org/h2/mvstore/MVStore.java
+8
-1
MVTableEngine.java
h2/src/main/org/h2/mvstore/db/MVTableEngine.java
+4
-4
TransactionStore.java
h2/src/main/org/h2/mvstore/db/TransactionStore.java
+88
-6
TestAll.java
h2/src/test/org/h2/test/TestAll.java
+2
-2
TestBase.java
h2/src/test/org/h2/test/TestBase.java
+5
-0
TestMVTableEngine.java
h2/src/test/org/h2/test/store/TestMVTableEngine.java
+26
-0
TestRandomMapOps.java
h2/src/test/org/h2/test/store/TestRandomMapOps.java
+1
-1
没有找到文件。
h2/src/main/org/h2/mvstore/DataUtils.java
浏览文件 @
8497c759
...
...
@@ -67,6 +67,12 @@ public class DataUtils {
*/
public
static
final
int
ERROR_SERIALIZATION
=
8
;
/**
* The application was trying to read data from a chunk that is no longer
* available.
*/
public
static
final
int
ERROR_CHUNK_NOT_FOUND
=
9
;
/**
* The transaction store is corrupt.
*/
...
...
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/mvstore/MVMap.java
浏览文件 @
8497c759
...
...
@@ -793,8 +793,16 @@ public class MVMap<K, V> extends AbstractMap<K, V>
*
* @param set the set of chunk ids
*/
public
void
rewrite
(
Set
<
Integer
>
set
)
{
rewrite
(
root
,
set
);
void
rewrite
(
Set
<
Integer
>
set
)
{
try
{
rewrite
(
root
,
set
);
}
catch
(
IllegalStateException
e
)
{
if
(
DataUtils
.
getErrorCode
(
e
.
getMessage
())
==
DataUtils
.
ERROR_CHUNK_NOT_FOUND
)
{
// ignore
}
else
{
throw
e
;
}
}
}
private
int
rewrite
(
Page
p
,
Set
<
Integer
>
set
)
{
...
...
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/mvstore/MVStore.java
浏览文件 @
8497c759
...
...
@@ -105,6 +105,13 @@ MVStore:
- compact: copy whole pages (without having to open all maps)
- maybe change the length code to have lower gaps
- test with very low limits (such as: short chunks, small pages)
- maybe allow to read beyond the retention time:
when compacting, move live pages in old chunks
to a map (possibly the metadata map) -
this requires a change in the compaction code, plus
a map lookup when reading old data; also, this
old data map needs to be cleaned up somehow;
maybe using an additional timeout
*/
...
...
@@ -849,7 +856,7 @@ public class MVStore {
// it could also be unsynchronized metadata
// access (if synchronization on this was forgotten)
throw
DataUtils
.
newIllegalStateException
(
DataUtils
.
ERROR_
INTERNAL
,
DataUtils
.
ERROR_
CHUNK_NOT_FOUND
,
"Chunk {0} no longer exists"
,
chunkId
);
}
...
...
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/mvstore/db/MVTableEngine.java
浏览文件 @
8497c759
...
...
@@ -55,7 +55,7 @@ public class MVTableEngine implements TableEngine {
String
dbPath
=
db
.
getDatabasePath
();
MVStore
.
Builder
builder
=
new
MVStore
.
Builder
();
if
(
dbPath
==
null
)
{
store
=
new
Store
(
db
,
builder
.
open
()
);
store
=
new
Store
(
db
,
builder
);
}
else
{
String
fileName
=
dbPath
+
Constants
.
SUFFIX_MV_FILE
;
MVStoreTool
.
compactCleanUp
(
fileName
);
...
...
@@ -94,7 +94,7 @@ public class MVTableEngine implements TableEngine {
});
try
{
store
=
new
Store
(
db
,
builder
.
open
()
);
store
=
new
Store
(
db
,
builder
);
}
catch
(
IllegalStateException
e
)
{
int
errorCode
=
DataUtils
.
getErrorCode
(
e
.
getMessage
());
if
(
errorCode
==
DataUtils
.
ERROR_FILE_CORRUPT
)
{
...
...
@@ -157,8 +157,8 @@ public class MVTableEngine implements TableEngine {
private
int
temporaryMapId
;
public
Store
(
Database
db
,
MVStore
store
)
{
this
.
store
=
store
;
public
Store
(
Database
db
,
MVStore
.
Builder
builder
)
{
this
.
store
=
builder
.
open
()
;
this
.
transactionStore
=
new
TransactionStore
(
store
,
new
ValueDataType
(
null
,
db
,
null
),
...
...
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/mvstore/db/TransactionStore.java
浏览文件 @
8497c759
...
...
@@ -1383,9 +1383,67 @@ public class TransactionStore {
* included
* @return the iterator
*/
public
Iterator
<
K
>
keyIterator
(
K
from
,
boolean
includeUncommitted
)
{
Iterator
<
K
>
it
=
map
.
keyIterator
(
from
);
return
wrapIterator
(
it
,
includeUncommitted
);
public
Iterator
<
K
>
keyIterator
(
final
K
from
,
final
boolean
includeUncommitted
)
{
return
new
Iterator
<
K
>()
{
private
K
currentKey
=
from
;
private
Cursor
<
K
,
VersionedValue
>
cursor
=
map
.
cursor
(
currentKey
);
{
fetchNext
();
}
private
void
fetchNext
()
{
while
(
cursor
.
hasNext
())
{
K
k
;
try
{
k
=
cursor
.
next
();
}
catch
(
IllegalStateException
e
)
{
// TODO this is a bit ugly
if
(
DataUtils
.
getErrorCode
(
e
.
getMessage
())
==
DataUtils
.
ERROR_CHUNK_NOT_FOUND
)
{
cursor
=
map
.
cursor
(
currentKey
);
// we (should) get the current key again,
// we need to ignore that one
if
(!
cursor
.
hasNext
())
{
break
;
}
cursor
.
next
();
if
(!
cursor
.
hasNext
())
{
break
;
}
k
=
cursor
.
next
();
}
else
{
throw
e
;
}
}
currentKey
=
k
;
if
(
includeUncommitted
)
{
return
;
}
if
(
containsKey
(
k
))
{
return
;
}
}
currentKey
=
null
;
}
@Override
public
boolean
hasNext
()
{
return
currentKey
!=
null
;
}
@Override
public
K
next
()
{
K
result
=
currentKey
;
fetchNext
();
return
result
;
}
@Override
public
void
remove
()
{
throw
DataUtils
.
newUnsupportedOperationException
(
"Removing is not supported"
);
}
};
}
/**
...
...
@@ -1394,10 +1452,11 @@ public class TransactionStore {
* @param from the first key to return
* @return the iterator
*/
public
Iterator
<
Entry
<
K
,
V
>>
entryIterator
(
K
from
)
{
final
Cursor
<
K
,
VersionedValue
>
cursor
=
map
.
cursor
(
from
);
public
Iterator
<
Entry
<
K
,
V
>>
entryIterator
(
final
K
from
)
{
return
new
Iterator
<
Entry
<
K
,
V
>>()
{
private
Entry
<
K
,
V
>
current
;
private
K
currentKey
=
from
;
private
Cursor
<
K
,
VersionedValue
>
cursor
=
map
.
cursor
(
currentKey
);
{
fetchNext
();
...
...
@@ -1405,17 +1464,40 @@ public class TransactionStore {
private
void
fetchNext
()
{
while
(
cursor
.
hasNext
())
{
final
K
key
=
cursor
.
next
();
K
k
;
try
{
k
=
cursor
.
next
();
}
catch
(
IllegalStateException
e
)
{
// TODO this is a bit ugly
if
(
DataUtils
.
getErrorCode
(
e
.
getMessage
())
==
DataUtils
.
ERROR_CHUNK_NOT_FOUND
)
{
cursor
=
map
.
cursor
(
currentKey
);
// we (should) get the current key again,
// we need to ignore that one
if
(!
cursor
.
hasNext
())
{
break
;
}
cursor
.
next
();
if
(!
cursor
.
hasNext
())
{
break
;
}
k
=
cursor
.
next
();
}
else
{
throw
e
;
}
}
final
K
key
=
k
;
VersionedValue
data
=
cursor
.
getValue
();
data
=
getValue
(
key
,
readLogId
,
data
);
if
(
data
!=
null
&&
data
.
value
!=
null
)
{
@SuppressWarnings
(
"unchecked"
)
final
V
value
=
(
V
)
data
.
value
;
current
=
new
DataUtils
.
MapEntry
<
K
,
V
>(
key
,
value
);
currentKey
=
key
;
return
;
}
}
current
=
null
;
currentKey
=
null
;
}
@Override
...
...
This diff is collapsed.
Click to expand it.
h2/src/test/org/h2/test/TestAll.java
浏览文件 @
8497c759
...
...
@@ -625,7 +625,7 @@ kill -9 `jps -l | grep "org.h2.test." | cut -d " " -f 1`
new
TestCompatibility
().
runTest
(
this
);
new
TestCompatibilityOracle
().
runTest
(
this
);
new
TestCsv
().
runTest
(
this
);
new
TestDateStorage
().
runTest
(
this
);
// TODO test
new
TestDateStorage
().
runTest
(
this
);
new
TestDeadlock
().
runTest
(
this
);
new
TestDrop
().
runTest
(
this
);
new
TestDuplicateKeyUpdate
().
runTest
(
this
);
...
...
@@ -721,7 +721,7 @@ kill -9 `jps -l | grep "org.h2.test." | cut -d " " -f 1`
// synth
new
TestBtreeIndex
().
runTest
(
this
);
new
TestConcurrentUpdate
().
runTest
(
this
);
new
TestDiskFull
().
runTest
(
this
);
// TODO test
new
TestDiskFull
().
runTest
(
this
);
new
TestCrashAPI
().
runTest
(
this
);
new
TestFuzzOptimizations
().
runTest
(
this
);
new
TestLimit
().
runTest
(
this
);
...
...
This diff is collapsed.
Click to expand it.
h2/src/test/org/h2/test/TestBase.java
浏览文件 @
8497c759
...
...
@@ -259,6 +259,11 @@ public abstract class TestBase {
}
return
name
;
}
if
(
admin
)
{
;
// TODO testing
// name = addOption(name, "RETENTION_TIME", "10");
// name = addOption(name, "WRITE_DELAY", "10");
}
if
(
config
.
memory
)
{
name
=
"mem:"
+
name
;
}
else
{
...
...
This diff is collapsed.
Click to expand it.
h2/src/test/org/h2/test/store/TestMVTableEngine.java
浏览文件 @
8497c759
...
...
@@ -48,6 +48,7 @@ public class TestMVTableEngine extends TestBase {
@Override
public
void
test
()
throws
Exception
{
testLowRetentionTime
();
testOldAndNew
();
testTemporaryTables
();
testUniqueIndex
();
...
...
@@ -78,6 +79,31 @@ public class TestMVTableEngine extends TestBase {
testLocking
();
testSimple
();
}
private
void
testLowRetentionTime
()
throws
SQLException
{
deleteDb
(
"mvstore"
);
Connection
conn
=
getConnection
(
"mvstore;RETENTION_TIME=10;WRITE_DELAY=10"
);
Statement
stat
=
conn
.
createStatement
();
Connection
conn2
=
getConnection
(
"mvstore"
);
Statement
stat2
=
conn2
.
createStatement
();
stat
.
execute
(
"create alias sleep as $$void sleep(int ms) throws Exception { Thread.sleep(ms); }$$"
);
stat
.
execute
(
"create table test(id identity, name varchar) as select x, 'Init' from system_range(0, 1999)"
);
for
(
int
i
=
0
;
i
<
10
;
i
++)
{
stat
.
execute
(
"insert into test values(null, 'Hello')"
);
// create and delete a large table: this will force compaction
stat
.
execute
(
"create table temp(id identity, name varchar) as "
+
"select x, space(1000000) from system_range(0, 10)"
);
stat
.
execute
(
"drop table temp"
);
}
ResultSet
rs
=
stat2
.
executeQuery
(
"select *, sleep(1) from test order by id"
);
for
(
int
i
=
0
;
i
<
2000
+
10
;
i
++)
{
assertTrue
(
rs
.
next
());
assertEquals
(
i
,
rs
.
getInt
(
1
));
}
assertFalse
(
rs
.
next
());
conn
.
close
();
}
private
void
testOldAndNew
()
throws
SQLException
{
FileUtils
.
deleteRecursive
(
getBaseDir
(),
true
);
...
...
This diff is collapsed.
Click to expand it.
h2/src/test/org/h2/test/store/TestRandomMapOps.java
浏览文件 @
8497c759
...
...
@@ -168,7 +168,7 @@ public class TestRandomMapOps extends TestBase {
private
static
MVStore
openStore
(
String
fileName
)
{
MVStore
s
=
new
MVStore
.
Builder
().
fileName
(
fileName
).
pageSplitSize
(
50
).
autoCommitDisabled
().
open
();
s
.
setRetentionTime
(
0
);
s
.
setRetentionTime
(
100
0
);
return
s
;
}
...
...
This diff is collapsed.
Click to expand it.
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论