Browse Source
git-svn-id: https://weed-fs.googlecode.com/svn/trunk@4 282b0af5-e82d-9cf1-ede4-77906d7719d0
pull/2/head
git-svn-id: https://weed-fs.googlecode.com/svn/trunk@4 282b0af5-e82d-9cf1-ede4-77906d7719d0
pull/2/head
chris.lu@gmail.com
13 years ago
7 changed files with 199 additions and 67 deletions
-
46weed-fs/note/weedfs.txt
-
18weed-fs/src/cmd/gdir.go
-
57weed-fs/src/cmd/gstore.go
-
18weed-fs/src/pkg/directory/volume_mapping.go
-
66weed-fs/src/pkg/store/store.go
-
22weed-fs/src/pkg/store/util.go
-
15weed-fs/src/pkg/store/volume.go
@ -0,0 +1,46 @@ |
|||
How to submit a content |
|||
1. Find physical volumes |
|||
1.c Create a hash value |
|||
1.d find a write logic volume id, and return [logic volume id, {physical volume ids}] |
|||
2. submit to physical volumes |
|||
2.c |
|||
generate the cookie |
|||
generate a unique id as key |
|||
choose the right altKey |
|||
send bytes to physical volumes |
|||
2.s each |
|||
save bytes |
|||
store map[key uint64, altKey uint32]<offset, size> |
|||
for updated entry, set old entry's offset to zero |
|||
3.c |
|||
wait for all physical volumes to finish |
|||
store the /<logic volume id>/<key>_<cookie>_<altKey>.<ext> |
|||
|
|||
How to retrieve a content |
|||
1.c |
|||
send logic volume id |
|||
1.d |
|||
find least busy volume's id |
|||
2.c |
|||
send URI /<physical volume id>/<key>_<cookie>_<altKey>.<ext> |
|||
|
|||
|
|||
How to submit a content |
|||
1. send bytes to weedfs, got <volume id, key uint64, cookie code> |
|||
store <key uint64, volume id uint32, cookie code uint32, ext>, and other information |
|||
|
|||
To read a content |
|||
2. use logic volume id to lookup a <machine id> |
|||
render url as /<machine id>/<volume id>/<key>/<cookie>.ext |
|||
|
|||
The directory server |
|||
0.init |
|||
load and collect <logic volume id, machine ids> mapping |
|||
1.on submit content |
|||
find a free logic volume id, start sending content to 3 machines |
|||
if all of them finishes, return <logic volume id, key, cookie code> |
|||
2.on read content |
|||
based on logic volume id, pick a machine with less load, |
|||
return <machine id> |
|||
|
|||
|
@ -1,18 +0,0 @@ |
|||
package main |
|||
|
|||
import ( |
|||
"directory" |
|||
// "runtime"
|
|||
"log" |
|||
) |
|||
|
|||
func main() { |
|||
m := directory.NewMapper("/tmp", "directory") |
|||
log.Println("map size", len(m.Virtual2physical)) |
|||
m.Add(10, 11,12,13) |
|||
m.Add(20, 21,22,23) |
|||
log.Println("map(10)", m.Get(10)) |
|||
log.Println("map size", len(m.Virtual2physical)) |
|||
m.Save() |
|||
defer m.Save() |
|||
} |
Write
Preview
Loading…
Cancel
Save
Reference in new issue