mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2024-01-19 02:48:24 +00:00
needle priting format
This commit is contained in:
parent
6f30a78a6c
commit
852af28f91
|
@ -9,8 +9,8 @@ import (
|
||||||
"github.com/chrislusf/seaweedfs/weed/operation"
|
"github.com/chrislusf/seaweedfs/weed/operation"
|
||||||
"github.com/chrislusf/seaweedfs/weed/storage"
|
"github.com/chrislusf/seaweedfs/weed/storage"
|
||||||
"github.com/chrislusf/seaweedfs/weed/topology"
|
"github.com/chrislusf/seaweedfs/weed/topology"
|
||||||
"time"
|
|
||||||
"strconv"
|
"strconv"
|
||||||
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (vs *VolumeServer) PostHandler(w http.ResponseWriter, r *http.Request) {
|
func (vs *VolumeServer) PostHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
|
@ -55,7 +55,7 @@ func (vs *VolumeServer) DeleteHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
volumeId, _ := storage.NewVolumeId(vid)
|
volumeId, _ := storage.NewVolumeId(vid)
|
||||||
n.ParsePath(fid)
|
n.ParsePath(fid)
|
||||||
|
|
||||||
glog.V(2).Infoln("deleting", n)
|
glog.V(2).Infof("volume %d deleting %s", vid, n)
|
||||||
|
|
||||||
cookie := n.Cookie
|
cookie := n.Cookie
|
||||||
|
|
||||||
|
|
|
@ -20,11 +20,15 @@ func NewFileId(VolumeId VolumeId, key uint64, cookie uint32) *FileId {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (n *FileId) String() string {
|
func (n *FileId) String() string {
|
||||||
|
return n.VolumeId.String() + "," + formatNeedleIdCookie(n.Key, n.Cookie)
|
||||||
|
}
|
||||||
|
|
||||||
|
func formatNeedleIdCookie(key NeedleId, cookie Cookie) string {
|
||||||
bytes := make([]byte, NeedleIdSize+CookieSize)
|
bytes := make([]byte, NeedleIdSize+CookieSize)
|
||||||
NeedleIdToBytes(bytes[0:NeedleIdSize], n.Key)
|
NeedleIdToBytes(bytes[0:NeedleIdSize], key)
|
||||||
CookieToBytes(bytes[NeedleIdSize:NeedleIdSize+CookieSize], n.Cookie)
|
CookieToBytes(bytes[NeedleIdSize:NeedleIdSize+CookieSize], cookie)
|
||||||
nonzero_index := 0
|
nonzero_index := 0
|
||||||
for ; bytes[nonzero_index] == 0; nonzero_index++ {
|
for ; bytes[nonzero_index] == 0; nonzero_index++ {
|
||||||
}
|
}
|
||||||
return n.VolumeId.String() + "," + hex.EncodeToString(bytes[nonzero_index:])
|
return hex.EncodeToString(bytes[nonzero_index:])
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,12 +29,12 @@ type Needle struct {
|
||||||
|
|
||||||
DataSize uint32 `comment:"Data size"` //version2
|
DataSize uint32 `comment:"Data size"` //version2
|
||||||
Data []byte `comment:"The actual file data"`
|
Data []byte `comment:"The actual file data"`
|
||||||
Flags byte `comment:"boolean flags"` //version2
|
Flags byte `comment:"boolean flags"` //version2
|
||||||
NameSize uint8 //version2
|
NameSize uint8 //version2
|
||||||
Name []byte `comment:"maximum 256 characters"` //version2
|
Name []byte `comment:"maximum 256 characters"` //version2
|
||||||
MimeSize uint8 //version2
|
MimeSize uint8 //version2
|
||||||
Mime []byte `comment:"maximum 256 characters"` //version2
|
Mime []byte `comment:"maximum 256 characters"` //version2
|
||||||
PairsSize uint16 //version2
|
PairsSize uint16 //version2
|
||||||
Pairs []byte `comment:"additional name value pairs, json format, maximum 64kB"`
|
Pairs []byte `comment:"additional name value pairs, json format, maximum 64kB"`
|
||||||
LastModified uint64 //only store LastModifiedBytesLength bytes, which is 5 bytes to disk
|
LastModified uint64 //only store LastModifiedBytesLength bytes, which is 5 bytes to disk
|
||||||
Ttl *TTL
|
Ttl *TTL
|
||||||
|
@ -44,7 +44,7 @@ type Needle struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (n *Needle) String() (str string) {
|
func (n *Needle) String() (str string) {
|
||||||
str = fmt.Sprintf("Cookie:%d, Id:%d, Size:%d, DataSize:%d, Name: %s, Mime: %s", n.Cookie, n.Id, n.Size, n.DataSize, n.Name, n.Mime)
|
str = fmt.Sprintf("%s Size:%d, DataSize:%d, Name:%s, Mime:%s", formatNeedleIdCookie(n.Id, n.Cookie), n.Size, n.DataSize, n.Name, n.Mime)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -134,7 +134,7 @@ func NewNeedle(r *http.Request, fixJpgOrientation bool) (n *Needle, e error) {
|
||||||
dotSep := strings.LastIndex(r.URL.Path, ".")
|
dotSep := strings.LastIndex(r.URL.Path, ".")
|
||||||
fid := r.URL.Path[commaSep+1:]
|
fid := r.URL.Path[commaSep+1:]
|
||||||
if dotSep > 0 {
|
if dotSep > 0 {
|
||||||
fid = r.URL.Path[commaSep+1: dotSep]
|
fid = r.URL.Path[commaSep+1 : dotSep]
|
||||||
}
|
}
|
||||||
|
|
||||||
e = n.ParsePath(fid)
|
e = n.ParsePath(fid)
|
||||||
|
|
Loading…
Reference in a new issue