add buffering cache

This commit is contained in:
YouROK
2020-12-07 15:56:29 +03:00
parent a5c1d5b4de
commit eecbb3aa10

View File

@@ -1,9 +1,11 @@
package torr package torr
import ( import (
"fmt"
"io" "io"
"github.com/anacrolix/torrent" "github.com/anacrolix/torrent"
"server/log"
) )
type Reader struct { type Reader struct {
@@ -11,6 +13,12 @@ type Reader struct {
offset int64 offset int64
readahead int64 readahead int64
file *torrent.File file *torrent.File
torr *Torrent
///Preload
isPreload bool
endOffsetPreload int64
currOffsetPreload int64
} }
func NewReader(torr *Torrent, file *torrent.File, readahead int64) *Reader { func NewReader(torr *Torrent, file *torrent.File, readahead int64) *Reader {
@@ -23,6 +31,7 @@ func NewReader(torr *Torrent, file *torrent.File, readahead int64) *Reader {
} }
r.SetReadahead(readahead) r.SetReadahead(readahead)
torr.GetCache().AddReader(r) torr.GetCache().AddReader(r)
r.torr = torr
return r return r
} }
@@ -43,6 +52,7 @@ func (r *Reader) Seek(offset int64, whence int) (n int64, err error) {
func (r *Reader) Read(p []byte) (n int, err error) { func (r *Reader) Read(p []byte) (n int, err error) {
n, err = r.Reader.Read(p) n, err = r.Reader.Read(p)
r.offset += int64(n) r.offset += int64(n)
r.preload()
return return
} }
@@ -58,3 +68,39 @@ func (r *Reader) Offset() int64 {
func (r *Reader) Readahead() int64 { func (r *Reader) Readahead() int64 {
return r.readahead return r.readahead
} }
func (r *Reader) preload() {
r.currOffsetPreload = r.offset
capacity := r.torr.cache.GetCapacity()
plength := r.torr.Info().PieceLength
r.endOffsetPreload = r.offset + capacity - r.readahead - plength
if r.endOffsetPreload > r.file.Length() {
r.endOffsetPreload = r.file.Length()
}
if r.endOffsetPreload < r.readahead || r.isPreload {
return
}
r.isPreload = true
//TODO remove logs
fmt.Println("Start buffering...")
go func() {
buffReader := r.file.NewReader()
defer func() {
r.isPreload = false
buffReader.Close()
fmt.Println("End buffering...")
}()
buffReader.SetReadahead(0)
buffReader.Seek(r.currOffsetPreload, io.SeekStart)
buff5mb := make([]byte, 1024)
for r.currOffsetPreload < r.endOffsetPreload {
off, err := buffReader.Read(buff5mb)
if err != nil {
log.TLogln("Error read e head buffer", err)
return
}
r.currOffsetPreload += int64(off)
fmt.Println("buffered:", r.offset, "|", r.currOffsetPreload, "/", r.endOffsetPreload)
}
}()
}