Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
W
wendelin.core
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Labels
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Commits
Open sidebar
Kirill Smelkov
wendelin.core
Commits
55fdc2c1
Commit
55fdc2c1
authored
Oct 12, 2021
by
Kirill Smelkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
.
parent
54b623ba
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
52 additions
and
25 deletions
+52
-25
wcfs/internal/xbtree/δbtail.go
wcfs/internal/xbtree/δbtail.go
+2
-2
wcfs/internal/zdata/δftail.go
wcfs/internal/zdata/δftail.go
+50
-23
No files found.
wcfs/internal/xbtree/δbtail.go
View file @
55fdc2c1
...
...
@@ -247,9 +247,9 @@ type _ΔTtail struct {
vδT
[]
ΔTree
// set of keys that were requested to be tracked in this tree,
// but for which vδT rebuild was not yet started
// but for which vδT rebuild was not yet started
as of @head
ktrackNew
blib
.
RangedKeySet
// {keycov}
// set of nodes corresponding to ktrackNew
// set of nodes corresponding to ktrackNew
as of @head
trackNew
blib
.
PPTreeSubSet
// PP{nodes}
// set of keys(nodes) for which rebuild is in progress
...
...
wcfs/internal/zdata/δftail.go
View file @
55fdc2c1
...
...
@@ -58,7 +58,10 @@ package zdata
// tracked and is thus easy to maintain. It also can be maintained only in
// ΔFtail because ΔBtail and ΔZtail does not "know" anything about ZBigFile.
//
// XXX concurrency
//
// Concurrency
//
// XXX
import
(
"context"
...
...
@@ -116,12 +119,26 @@ type setOid = set.Oid
// .rev↑
// {}blk | EPOCH
//
// XXX concurrent use.
//
// See also zodb.ΔTail and xbtree.ΔBtail
//
//
// Concurrency
//
// ΔFtail is safe to use in single-writer / multiple-readers mode. That is at
// any time there should be either only sole writer, or, potentially several
// simultaneous readers. The table below classifies operations:
//
// Writers: Update, ForgetPast
// Readers: Track + all queries (SliceByRev, SliceByFileRev, BlkRevAt)
//
// Note that, in particular, it is correct to run multiple Track and queries
// requests simultaneously.
type
ΔFtail
struct
{
// ΔFtail merges ΔBtail with history of ZBlk
δBtail
*
xbtree
.
ΔBtail
// XXX mu sync.Mutex + comment
byFile
map
[
zodb
.
Oid
]
*
_ΔFileTail
// file -> vδf tail
filesByRoot
map
[
zodb
.
Oid
]
setOid
// tree-root -> {} ZBigFile<oid> as of @head
...
...
@@ -205,8 +222,6 @@ func (δFtail *ΔFtail) Tail() zodb.Tid { return δFtail.δBtail.Tail() }
//
// Objects in path and zblk must be with .PJar().At() == .head
func
(
δFtail
*
ΔFtail
)
Track
(
file
*
ZBigFile
,
blk
int64
,
path
[]
btree
.
LONode
,
blkcov
btree
.
LKeyRange
,
zblk
ZBlk
)
{
// XXX locking
head
:=
δFtail
.
Head
()
fileAt
:=
file
.
PJar
()
.
At
()
...
...
@@ -226,6 +241,10 @@ func (δFtail *ΔFtail) Track(file *ZBigFile, blk int64, path []btree.LONode, bl
rootObj
:=
path
[
0
]
.
(
*
btree
.
LOBTree
)
root
:=
rootObj
.
POid
()
δFtail
.
mu
.
Lock
()
defer
δFtail
.
mu
.
Unlock
()
files
,
ok
:=
δFtail
.
filesByRoot
[
root
]
if
!
ok
{
files
=
setOid
{}
...
...
@@ -266,6 +285,8 @@ func (δFtail *ΔFtail) Track(file *ZBigFile, blk int64, path []btree.LONode, bl
}
}
// XXX vδESnapForFile
// rebuildAll rebuilds vδE for all files from trackNew requests.
func
(
δFtail
*
ΔFtail
)
rebuildAll
()
(
err
error
)
{
defer
xerr
.
Contextf
(
&
err
,
"ΔFtail rebuildAll"
)
...
...
@@ -277,7 +298,7 @@ func (δFtail *ΔFtail) rebuildAll() (err error) {
for
foid
:=
range
δFtail
.
trackNew
{
δFtail
.
trackNew
.
Del
(
foid
)
δftail
:=
δFtail
.
byFile
[
foid
]
err
:=
δftail
.
rebuild1
(
foid
,
δZtail
,
db
)
err
:=
δftail
.
_
rebuild1
(
foid
,
δZtail
,
db
)
if
err
!=
nil
{
return
err
}
...
...
@@ -288,27 +309,32 @@ func (δFtail *ΔFtail) rebuildAll() (err error) {
// rebuild1IfNeeded rebuilds vδE if there is such need.
//
// it returns corresponding δftail for convenience.
// it returns corresponding δftail for convenience.
XXX
// the only case when vδE actually needs to be rebuilt is when the file just started to be tracked.
func
(
δFtail
*
ΔFtail
)
rebuild1IfNeeded
(
foid
zodb
.
Oid
)
(
_
*
_ΔFileTail
,
err
error
)
{
// XXX locking
func
(
δFtail
*
ΔFtail
)
rebuild1IfNeeded
(
foid
zodb
.
Oid
)
(
vδE
[]
_ΔFileEpoch
,
headRoot
zodb
.
Oid
,
err
error
)
{
δFtail
.
mu
.
Lock
()
// TODO verify that there is no in-progress writers
defer
δFtail
.
mu
.
Unlock
()
δftail
:=
δFtail
.
byFile
[
foid
]
if
δftail
.
vδE
!=
nil
{
err
=
nil
}
else
{
//
δFtail
.
trackNew
.
Del
(
foid
)
δBtail
:=
δFtail
.
δBtail
err
=
δftail
.
rebuild1
(
foid
,
δBtail
.
ΔZtail
(),
δBtail
.
DB
())
err
=
δftail
.
_
rebuild1
(
foid
,
δBtail
.
ΔZtail
(),
δBtail
.
DB
())
}
return
δftail
,
err
}
// rebuild1 rebuilds vδE.
func
(
δftail
*
_ΔFileTail
)
rebuild1
(
foid
zodb
.
Oid
,
δZtail
*
zodb
.
ΔTail
,
db
*
zodb
.
DB
)
(
err
error
)
{
// _rebuild1 rebuilds vδE.
//
// XXX -> redo to just return built vδE (vδEBuild)
// XXX must be called with δftail.mu locked.
func
(
δftail
*
_ΔFileTail
)
_rebuild1
(
foid
zodb
.
Oid
,
δZtail
*
zodb
.
ΔTail
,
db
*
zodb
.
DB
)
(
err
error
)
{
defer
xerr
.
Contextf
(
&
err
,
"file<%s>: rebuild"
,
foid
)
// XXX locking
//
// XXX locking
if
δftail
.
vδE
!=
nil
{
panic
(
"rebuild1: vδE != nil"
)
}
...
...
@@ -363,6 +389,9 @@ func (δFtail *ΔFtail) Update(δZ *zodb.EventCommit) (_ ΔF, err error) {
defer
xerr
.
Contextf
(
&
err
,
"ΔFtail update %s -> %s"
,
δFtail
.
Head
(),
δZ
.
Tid
)
// XXX locking
//δFtail.mu.Lock()
//defer δFtail.mu.Unlock()
//// TODO verify that there is no in-progress readers/writers
// rebuild vδE for newly tracked files
err
=
δFtail
.
rebuildAll
()
...
...
@@ -411,7 +440,7 @@ func (δFtail *ΔFtail) Update(δZ *zodb.EventCommit) (_ ΔF, err error) {
}
δftail
.
root
=
δE
.
newRoot
δftail
.
vδE
=
append
(
δftail
.
vδE
,
δE
)
δftail
.
vδE
=
append
(
δftail
.
vδE
,
δE
)
// XXX note that we do not change older snapshots
}
}
...
...
@@ -536,9 +565,11 @@ func (δFtail *ΔFtail) Update(δZ *zodb.EventCommit) (_ ΔF, err error) {
// ForgetPast discards all δFtail entries with rev ≤ revCut.
func
(
δFtail
*
ΔFtail
)
ForgetPast
(
revCut
zodb
.
Tid
)
{
δFtail
.
δBtail
.
ForgetPast
(
revCut
)
δFtail
.
mu
.
Lock
()
defer
δFtail
.
mu
.
Unlock
()
// TODO verify that there is no in-progress readers/writers
// XXX locking
δFtail
.
δBtail
.
ForgetPast
(
revCut
)
// TODO keep index which file changed epoch where (similarly to ΔBtail),
// and, instead of scanning all files, trim vδE only on files that is really necessary.
...
...
@@ -547,8 +578,7 @@ func (δFtail *ΔFtail) ForgetPast(revCut zodb.Tid) {
}
}
func
(
δftail
*
_ΔFileTail
)
forgetPast
(
revCut
zodb
.
Tid
)
{
// XXX locking
func
(
δftail
*
_ΔFileTail
)
_forgetPast
(
revCut
zodb
.
Tid
)
{
icut
:=
0
for
;
icut
<
len
(
δftail
.
vδE
);
icut
++
{
if
δftail
.
vδE
[
icut
]
.
Rev
>
revCut
{
...
...
@@ -583,8 +613,6 @@ func (δFtail *ΔFtail) SliceByFileRev(zfile *ZBigFile, lo, hi zodb.Tid) /*reado
//fmt.Printf("\nslice f<%s> (@%s,@%s]\n", foid, lo, hi)
xtail
.
AssertSlice
(
δFtail
,
lo
,
hi
)
// XXX locking
// query .δBtail.SliceByRootRev(file.blktab, lo, hi) +
// merge δZBlk history with that.
...
...
@@ -602,7 +630,7 @@ func (δFtail *ΔFtail) SliceByFileRev(zfile *ZBigFile, lo, hi zodb.Tid) /*reado
// δFile ────────o───────o──────x─────x────────────────────────
δftail
,
err
:=
δFtail
.
rebuild1IfNeeded
(
foid
)
vδE
,
headRoot
,
err
:=
δFtail
.
rebuild1IfNeeded
(
foid
)
if
err
!=
nil
{
panic
(
err
)
// XXX
}
...
...
@@ -630,7 +658,6 @@ func (δFtail *ΔFtail) SliceByFileRev(zfile *ZBigFile, lo, hi zodb.Tid) /*reado
iz
:=
len
(
vδZ
)
-
1
// find epoch that covers hi
vδE
:=
δftail
.
vδE
le
:=
len
(
vδE
)
ie
:=
sort
.
Search
(
le
,
func
(
i
int
)
bool
{
return
hi
<
vδE
[
i
]
.
Rev
...
...
@@ -662,7 +689,7 @@ func (δFtail *ΔFtail) SliceByFileRev(zfile *ZBigFile, lo, hi zodb.Tid) /*reado
var
ZinblkAt
zodb
.
Tid
// Zinblk covers [ZinblkAt,<next δT>)
if
ie
+
1
==
le
{
// head
root
=
δftail
.
r
oot
root
=
headR
oot
head
=
δFtail
.
Head
()
for
zblk
,
zt
:=
range
δFtail
.
trackSetZBlk
{
inblk
,
ok
:=
zt
.
inroot
[
root
]
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment