Merge pull request #1468 from filecoin-project/feat/untangle-secstorage
sectorstorage: Untangle from lotus deps
This commit is contained in:
commit
eb6bc0399a
@ -4,8 +4,6 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/chain/vm"
|
|
||||||
|
|
||||||
"github.com/filecoin-project/go-address"
|
"github.com/filecoin-project/go-address"
|
||||||
"github.com/filecoin-project/go-fil-markets/storagemarket"
|
"github.com/filecoin-project/go-fil-markets/storagemarket"
|
||||||
"github.com/filecoin-project/specs-actors/actors/abi"
|
"github.com/filecoin-project/specs-actors/actors/abi"
|
||||||
@ -18,10 +16,10 @@ import (
|
|||||||
"github.com/ipfs/go-cid"
|
"github.com/ipfs/go-cid"
|
||||||
"github.com/ipfs/go-filestore"
|
"github.com/ipfs/go-filestore"
|
||||||
"github.com/libp2p/go-libp2p-core/peer"
|
"github.com/libp2p/go-libp2p-core/peer"
|
||||||
xerrors "golang.org/x/xerrors"
|
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/chain/store"
|
"github.com/filecoin-project/lotus/chain/store"
|
||||||
"github.com/filecoin-project/lotus/chain/types"
|
"github.com/filecoin-project/lotus/chain/types"
|
||||||
|
"github.com/filecoin-project/lotus/chain/vm"
|
||||||
)
|
)
|
||||||
|
|
||||||
// FullNode API is a low-level interface to the Filecoin network full node
|
// FullNode API is a low-level interface to the Filecoin network full node
|
||||||
@ -374,18 +372,3 @@ type ComputeStateOutput struct {
|
|||||||
Root cid.Cid
|
Root cid.Cid
|
||||||
Trace []*InvocResult
|
Trace []*InvocResult
|
||||||
}
|
}
|
||||||
|
|
||||||
func ProofTypeFromSectorSize(ssize abi.SectorSize) (abi.RegisteredProof, abi.RegisteredProof, error) {
|
|
||||||
switch ssize {
|
|
||||||
case 2 << 10:
|
|
||||||
return abi.RegisteredProof_StackedDRG2KiBPoSt, abi.RegisteredProof_StackedDRG2KiBSeal, nil
|
|
||||||
case 8 << 20:
|
|
||||||
return abi.RegisteredProof_StackedDRG8MiBPoSt, abi.RegisteredProof_StackedDRG8MiBSeal, nil
|
|
||||||
case 512 << 20:
|
|
||||||
return abi.RegisteredProof_StackedDRG512MiBPoSt, abi.RegisteredProof_StackedDRG512MiBSeal, nil
|
|
||||||
case 32 << 30:
|
|
||||||
return abi.RegisteredProof_StackedDRG32GiBPoSt, abi.RegisteredProof_StackedDRG32GiBSeal, nil
|
|
||||||
default:
|
|
||||||
return 0, 0, xerrors.Errorf("unsupported sector size for miner: %v", ssize)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
@ -11,6 +11,7 @@ import (
|
|||||||
"github.com/filecoin-project/specs-actors/actors/abi"
|
"github.com/filecoin-project/specs-actors/actors/abi"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/chain/types"
|
"github.com/filecoin-project/lotus/chain/types"
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage"
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -114,7 +115,7 @@ type StorageMiner interface {
|
|||||||
|
|
||||||
// WorkerConnect tells the node to connect to workers RPC
|
// WorkerConnect tells the node to connect to workers RPC
|
||||||
WorkerConnect(context.Context, string) error
|
WorkerConnect(context.Context, string) error
|
||||||
WorkerStats(context.Context) (map[uint64]WorkerStats, error)
|
WorkerStats(context.Context) (map[uint64]sectorstorage.WorkerStats, error)
|
||||||
|
|
||||||
stores.SectorIndex
|
stores.SectorIndex
|
||||||
|
|
||||||
|
@ -6,6 +6,7 @@ import (
|
|||||||
"github.com/filecoin-project/specs-storage/storage"
|
"github.com/filecoin-project/specs-storage/storage"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/build"
|
"github.com/filecoin-project/lotus/build"
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage"
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/sealtasks"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/sealtasks"
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
||||||
)
|
)
|
||||||
@ -16,31 +17,7 @@ type WorkerApi interface {
|
|||||||
|
|
||||||
TaskTypes(context.Context) (map[sealtasks.TaskType]struct{}, error) // TaskType -> Weight
|
TaskTypes(context.Context) (map[sealtasks.TaskType]struct{}, error) // TaskType -> Weight
|
||||||
Paths(context.Context) ([]stores.StoragePath, error)
|
Paths(context.Context) ([]stores.StoragePath, error)
|
||||||
Info(context.Context) (WorkerInfo, error)
|
Info(context.Context) (sectorstorage.WorkerInfo, error)
|
||||||
|
|
||||||
storage.Sealer
|
storage.Sealer
|
||||||
}
|
}
|
||||||
|
|
||||||
type WorkerResources struct {
|
|
||||||
MemPhysical uint64
|
|
||||||
MemSwap uint64
|
|
||||||
|
|
||||||
MemReserved uint64 // Used by system / other processes
|
|
||||||
|
|
||||||
GPUs []string
|
|
||||||
}
|
|
||||||
|
|
||||||
type WorkerInfo struct {
|
|
||||||
Hostname string
|
|
||||||
|
|
||||||
Resources WorkerResources
|
|
||||||
}
|
|
||||||
|
|
||||||
type WorkerStats struct {
|
|
||||||
Info WorkerInfo
|
|
||||||
|
|
||||||
MemUsedMin uint64
|
|
||||||
MemUsedMax uint64
|
|
||||||
GpuUsed bool
|
|
||||||
CpuUse int
|
|
||||||
}
|
|
||||||
|
@ -21,6 +21,7 @@ import (
|
|||||||
"github.com/filecoin-project/lotus/build"
|
"github.com/filecoin-project/lotus/build"
|
||||||
"github.com/filecoin-project/lotus/chain/store"
|
"github.com/filecoin-project/lotus/chain/store"
|
||||||
"github.com/filecoin-project/lotus/chain/types"
|
"github.com/filecoin-project/lotus/chain/types"
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage"
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/sealtasks"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/sealtasks"
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
||||||
)
|
)
|
||||||
@ -181,8 +182,8 @@ type StorageMinerStruct struct {
|
|||||||
SectorsRefs func(context.Context) (map[string][]api.SealedRef, error) `perm:"read"`
|
SectorsRefs func(context.Context) (map[string][]api.SealedRef, error) `perm:"read"`
|
||||||
SectorsUpdate func(context.Context, abi.SectorNumber, api.SectorState) error `perm:"write"`
|
SectorsUpdate func(context.Context, abi.SectorNumber, api.SectorState) error `perm:"write"`
|
||||||
|
|
||||||
WorkerConnect func(context.Context, string) error `perm:"admin"` // TODO: worker perm
|
WorkerConnect func(context.Context, string) error `perm:"admin"` // TODO: worker perm
|
||||||
WorkerStats func(context.Context) (map[uint64]api.WorkerStats, error) `perm:"admin"`
|
WorkerStats func(context.Context) (map[uint64]sectorstorage.WorkerStats, error) `perm:"admin"`
|
||||||
|
|
||||||
StorageList func(context.Context) (map[stores.ID][]stores.Decl, error) `perm:"admin"`
|
StorageList func(context.Context) (map[stores.ID][]stores.Decl, error) `perm:"admin"`
|
||||||
StorageLocal func(context.Context) (map[stores.ID]string, error) `perm:"admin"`
|
StorageLocal func(context.Context) (map[stores.ID]string, error) `perm:"admin"`
|
||||||
@ -209,7 +210,7 @@ type WorkerStruct struct {
|
|||||||
|
|
||||||
TaskTypes func(context.Context) (map[sealtasks.TaskType]struct{}, error) `perm:"admin"`
|
TaskTypes func(context.Context) (map[sealtasks.TaskType]struct{}, error) `perm:"admin"`
|
||||||
Paths func(context.Context) ([]stores.StoragePath, error) `perm:"admin"`
|
Paths func(context.Context) ([]stores.StoragePath, error) `perm:"admin"`
|
||||||
Info func(context.Context) (api.WorkerInfo, error) `perm:"admin"`
|
Info func(context.Context) (sectorstorage.WorkerInfo, error) `perm:"admin"`
|
||||||
|
|
||||||
SealPreCommit1 func(ctx context.Context, sector abi.SectorID, ticket abi.SealRandomness, pieces []abi.PieceInfo) (storage.PreCommit1Out, error) `perm:"admin"`
|
SealPreCommit1 func(ctx context.Context, sector abi.SectorID, ticket abi.SealRandomness, pieces []abi.PieceInfo) (storage.PreCommit1Out, error) `perm:"admin"`
|
||||||
SealPreCommit2 func(context.Context, abi.SectorID, storage.PreCommit1Out) (cids storage.SectorCids, err error) `perm:"admin"`
|
SealPreCommit2 func(context.Context, abi.SectorID, storage.PreCommit1Out) (cids storage.SectorCids, err error) `perm:"admin"`
|
||||||
@ -666,7 +667,7 @@ func (c *StorageMinerStruct) WorkerConnect(ctx context.Context, url string) erro
|
|||||||
return c.Internal.WorkerConnect(ctx, url)
|
return c.Internal.WorkerConnect(ctx, url)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *StorageMinerStruct) WorkerStats(ctx context.Context) (map[uint64]api.WorkerStats, error) {
|
func (c *StorageMinerStruct) WorkerStats(ctx context.Context) (map[uint64]sectorstorage.WorkerStats, error) {
|
||||||
return c.Internal.WorkerStats(ctx)
|
return c.Internal.WorkerStats(ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -746,7 +747,7 @@ func (w *WorkerStruct) Paths(ctx context.Context) ([]stores.StoragePath, error)
|
|||||||
return w.Internal.Paths(ctx)
|
return w.Internal.Paths(ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w *WorkerStruct) Info(ctx context.Context) (api.WorkerInfo, error) {
|
func (w *WorkerStruct) Info(ctx context.Context) (sectorstorage.WorkerInfo, error) {
|
||||||
return w.Internal.Info(ctx)
|
return w.Internal.Info(ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -732,7 +732,7 @@ func (syncer *Syncer) VerifyElectionPoStProof(ctx context.Context, h *types.Bloc
|
|||||||
return xerrors.Errorf("[TESTING] election post was invalid")
|
return xerrors.Errorf("[TESTING] election post was invalid")
|
||||||
}
|
}
|
||||||
|
|
||||||
rt, _, err := api.ProofTypeFromSectorSize(ssize)
|
rt, _, err := ffiwrapper.ProofTypeFromSectorSize(ssize)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -162,7 +162,7 @@ func main() {
|
|||||||
}
|
}
|
||||||
sectorSize := abi.SectorSize(sectorSizeInt)
|
sectorSize := abi.SectorSize(sectorSizeInt)
|
||||||
|
|
||||||
ppt, spt, err := lapi.ProofTypeFromSectorSize(sectorSize)
|
ppt, spt, err := ffiwrapper.ProofTypeFromSectorSize(sectorSize)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -536,7 +536,7 @@ var proveCmd = &cli.Command{
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
ppt, spt, err := lapi.ProofTypeFromSectorSize(abi.SectorSize(c2in.SectorSize))
|
ppt, spt, err := ffiwrapper.ProofTypeFromSectorSize(abi.SectorSize(c2in.SectorSize))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@ package main
|
|||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage/ffiwrapper"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"net"
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
@ -24,7 +25,6 @@ import (
|
|||||||
"github.com/filecoin-project/lotus/lib/auth"
|
"github.com/filecoin-project/lotus/lib/auth"
|
||||||
"github.com/filecoin-project/lotus/lib/jsonrpc"
|
"github.com/filecoin-project/lotus/lib/jsonrpc"
|
||||||
"github.com/filecoin-project/lotus/lib/lotuslog"
|
"github.com/filecoin-project/lotus/lib/lotuslog"
|
||||||
"github.com/filecoin-project/lotus/node/config"
|
|
||||||
"github.com/filecoin-project/lotus/node/repo"
|
"github.com/filecoin-project/lotus/node/repo"
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage"
|
"github.com/filecoin-project/lotus/storage/sectorstorage"
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/sealtasks"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/sealtasks"
|
||||||
@ -189,7 +189,7 @@ var runCmd = &cli.Command{
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
var localPaths []config.LocalPath
|
var localPaths []stores.LocalPath
|
||||||
|
|
||||||
if !cctx.Bool("no-local-storage") {
|
if !cctx.Bool("no-local-storage") {
|
||||||
b, err := json.MarshalIndent(&stores.LocalStorageMeta{
|
b, err := json.MarshalIndent(&stores.LocalStorageMeta{
|
||||||
@ -206,12 +206,12 @@ var runCmd = &cli.Command{
|
|||||||
return xerrors.Errorf("persisting storage metadata (%s): %w", filepath.Join(lr.Path(), "sectorstore.json"), err)
|
return xerrors.Errorf("persisting storage metadata (%s): %w", filepath.Join(lr.Path(), "sectorstore.json"), err)
|
||||||
}
|
}
|
||||||
|
|
||||||
localPaths = append(localPaths, config.LocalPath{
|
localPaths = append(localPaths, stores.LocalPath{
|
||||||
Path: lr.Path(),
|
Path: lr.Path(),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := lr.SetStorage(func(sc *config.StorageConfig) {
|
if err := lr.SetStorage(func(sc *stores.StorageConfig) {
|
||||||
sc.StoragePaths = append(sc.StoragePaths, localPaths...)
|
sc.StoragePaths = append(sc.StoragePaths, localPaths...)
|
||||||
}); err != nil {
|
}); err != nil {
|
||||||
return xerrors.Errorf("set storage config: %w", err)
|
return xerrors.Errorf("set storage config: %w", err)
|
||||||
@ -242,7 +242,7 @@ var runCmd = &cli.Command{
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Setup remote sector store
|
// Setup remote sector store
|
||||||
_, spt, err := api.ProofTypeFromSectorSize(ssize)
|
_, spt, err := ffiwrapper.ProofTypeFromSectorSize(ssize)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("getting proof type: %w", err)
|
return xerrors.Errorf("getting proof type: %w", err)
|
||||||
}
|
}
|
||||||
|
@ -5,6 +5,7 @@ import (
|
|||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/docker/go-units"
|
"github.com/docker/go-units"
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage/ffiwrapper"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
@ -16,7 +17,6 @@ import (
|
|||||||
"github.com/filecoin-project/specs-actors/actors/abi"
|
"github.com/filecoin-project/specs-actors/actors/abi"
|
||||||
"github.com/filecoin-project/specs-actors/actors/abi/big"
|
"github.com/filecoin-project/specs-actors/actors/abi/big"
|
||||||
|
|
||||||
lapi "github.com/filecoin-project/lotus/api"
|
|
||||||
"github.com/filecoin-project/lotus/build"
|
"github.com/filecoin-project/lotus/build"
|
||||||
"github.com/filecoin-project/lotus/chain/types"
|
"github.com/filecoin-project/lotus/chain/types"
|
||||||
"github.com/filecoin-project/lotus/cmd/lotus-seed/seed"
|
"github.com/filecoin-project/lotus/cmd/lotus-seed/seed"
|
||||||
@ -120,7 +120,7 @@ var preSealCmd = &cli.Command{
|
|||||||
}
|
}
|
||||||
sectorSize := abi.SectorSize(sectorSizeInt)
|
sectorSize := abi.SectorSize(sectorSizeInt)
|
||||||
|
|
||||||
rp, _, err := lapi.ProofTypeFromSectorSize(sectorSize)
|
rp, _, err := ffiwrapper.ProofTypeFromSectorSize(sectorSize)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -7,6 +7,7 @@ import (
|
|||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"github.com/filecoin-project/lotus/node/modules"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
@ -37,7 +38,6 @@ import (
|
|||||||
lcli "github.com/filecoin-project/lotus/cli"
|
lcli "github.com/filecoin-project/lotus/cli"
|
||||||
"github.com/filecoin-project/lotus/genesis"
|
"github.com/filecoin-project/lotus/genesis"
|
||||||
"github.com/filecoin-project/lotus/miner"
|
"github.com/filecoin-project/lotus/miner"
|
||||||
"github.com/filecoin-project/lotus/node/config"
|
|
||||||
"github.com/filecoin-project/lotus/node/modules/dtypes"
|
"github.com/filecoin-project/lotus/node/modules/dtypes"
|
||||||
"github.com/filecoin-project/lotus/node/repo"
|
"github.com/filecoin-project/lotus/node/repo"
|
||||||
"github.com/filecoin-project/lotus/storage"
|
"github.com/filecoin-project/lotus/storage"
|
||||||
@ -171,7 +171,7 @@ var initCmd = &cli.Command{
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
var localPaths []config.LocalPath
|
var localPaths []stores.LocalPath
|
||||||
|
|
||||||
if pssb := cctx.StringSlice("pre-sealed-sectors"); len(pssb) != 0 {
|
if pssb := cctx.StringSlice("pre-sealed-sectors"); len(pssb) != 0 {
|
||||||
log.Infof("Setting up storage config with presealed sectors: %v", pssb)
|
log.Infof("Setting up storage config with presealed sectors: %v", pssb)
|
||||||
@ -181,7 +181,7 @@ var initCmd = &cli.Command{
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
localPaths = append(localPaths, config.LocalPath{
|
localPaths = append(localPaths, stores.LocalPath{
|
||||||
Path: psp,
|
Path: psp,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -202,12 +202,12 @@ var initCmd = &cli.Command{
|
|||||||
return xerrors.Errorf("persisting storage metadata (%s): %w", filepath.Join(lr.Path(), "sectorstore.json"), err)
|
return xerrors.Errorf("persisting storage metadata (%s): %w", filepath.Join(lr.Path(), "sectorstore.json"), err)
|
||||||
}
|
}
|
||||||
|
|
||||||
localPaths = append(localPaths, config.LocalPath{
|
localPaths = append(localPaths, stores.LocalPath{
|
||||||
Path: lr.Path(),
|
Path: lr.Path(),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := lr.SetStorage(func(sc *config.StorageConfig) {
|
if err := lr.SetStorage(func(sc *stores.StorageConfig) {
|
||||||
sc.StoragePaths = append(sc.StoragePaths, localPaths...)
|
sc.StoragePaths = append(sc.StoragePaths, localPaths...)
|
||||||
}); err != nil {
|
}); err != nil {
|
||||||
return xerrors.Errorf("set storage config: %w", err)
|
return xerrors.Errorf("set storage config: %w", err)
|
||||||
@ -394,7 +394,7 @@ func storageMinerInit(ctx context.Context, cctx *cli.Context, api lapi.FullNode,
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
ppt, spt, err := lapi.ProofTypeFromSectorSize(ssize)
|
ppt, spt, err := ffiwrapper.ProofTypeFromSectorSize(ssize)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -404,10 +404,15 @@ func storageMinerInit(ctx context.Context, cctx *cli.Context, api lapi.FullNode,
|
|||||||
return xerrors.Errorf("getting id address: %w", err)
|
return xerrors.Errorf("getting id address: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sa, err := modules.StorageAuth(ctx, api)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
smgr, err := sectorstorage.New(ctx, lr, stores.NewIndex(), &ffiwrapper.Config{
|
smgr, err := sectorstorage.New(ctx, lr, stores.NewIndex(), &ffiwrapper.Config{
|
||||||
SealProofType: spt,
|
SealProofType: spt,
|
||||||
PoStProofType: ppt,
|
PoStProofType: ppt,
|
||||||
}, config.Storage{true, true, true}, nil, api)
|
}, sectorstorage.SealerConfig{true, true, true}, nil, sa)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -2,8 +2,8 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/filecoin-project/lotus/api"
|
|
||||||
"github.com/filecoin-project/lotus/chain/types"
|
"github.com/filecoin-project/lotus/chain/types"
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage"
|
||||||
"gopkg.in/urfave/cli.v2"
|
"gopkg.in/urfave/cli.v2"
|
||||||
"sort"
|
"sort"
|
||||||
|
|
||||||
@ -37,7 +37,7 @@ var workersListCmd = &cli.Command{
|
|||||||
|
|
||||||
type sortableStat struct {
|
type sortableStat struct {
|
||||||
id uint64
|
id uint64
|
||||||
api.WorkerStats
|
sectorstorage.WorkerStats
|
||||||
}
|
}
|
||||||
|
|
||||||
st := make([]sortableStat, 0, len(stats))
|
st := make([]sortableStat, 0, len(stats))
|
||||||
|
@ -263,6 +263,7 @@ func Online() Option {
|
|||||||
// Storage miner
|
// Storage miner
|
||||||
ApplyIf(func(s *Settings) bool { return s.nodeType == repo.StorageMiner },
|
ApplyIf(func(s *Settings) bool { return s.nodeType == repo.StorageMiner },
|
||||||
Override(new(api.Common), From(new(common.CommonAPI))),
|
Override(new(api.Common), From(new(common.CommonAPI))),
|
||||||
|
Override(new(sectorstorage.StorageAuth), modules.StorageAuth),
|
||||||
|
|
||||||
Override(new(*stores.Index), stores.NewIndex),
|
Override(new(*stores.Index), stores.NewIndex),
|
||||||
Override(new(stores.SectorIndex), From(new(*stores.Index))),
|
Override(new(stores.SectorIndex), From(new(*stores.Index))),
|
||||||
@ -384,7 +385,7 @@ func ConfigStorageMiner(c interface{}) Option {
|
|||||||
return Options(
|
return Options(
|
||||||
ConfigCommon(&cfg.Common),
|
ConfigCommon(&cfg.Common),
|
||||||
|
|
||||||
Override(new(config.Storage), cfg.Storage),
|
Override(new(sectorstorage.SealerConfig), cfg.Storage),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,6 +2,7 @@ package config
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding"
|
"encoding"
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -23,7 +24,7 @@ type FullNode struct {
|
|||||||
type StorageMiner struct {
|
type StorageMiner struct {
|
||||||
Common
|
Common
|
||||||
|
|
||||||
Storage Storage
|
Storage sectorstorage.SealerConfig
|
||||||
}
|
}
|
||||||
|
|
||||||
// API contains configs for API endpoint
|
// API contains configs for API endpoint
|
||||||
@ -51,14 +52,6 @@ type Metrics struct {
|
|||||||
PubsubTracing bool
|
PubsubTracing bool
|
||||||
}
|
}
|
||||||
|
|
||||||
// // Storage Miner
|
|
||||||
type Storage struct {
|
|
||||||
// Local worker config
|
|
||||||
AllowPreCommit1 bool
|
|
||||||
AllowPreCommit2 bool
|
|
||||||
AllowCommit bool
|
|
||||||
}
|
|
||||||
|
|
||||||
func defCommon() Common {
|
func defCommon() Common {
|
||||||
return Common{
|
return Common{
|
||||||
API: API{
|
API: API{
|
||||||
@ -90,7 +83,7 @@ func DefaultStorageMiner() *StorageMiner {
|
|||||||
cfg := &StorageMiner{
|
cfg := &StorageMiner{
|
||||||
Common: defCommon(),
|
Common: defCommon(),
|
||||||
|
|
||||||
Storage: Storage{
|
Storage: sectorstorage.SealerConfig{
|
||||||
AllowPreCommit1: true,
|
AllowPreCommit1: true,
|
||||||
AllowPreCommit2: true,
|
AllowPreCommit2: true,
|
||||||
AllowCommit: true,
|
AllowCommit: true,
|
||||||
|
@ -2,6 +2,7 @@ package config
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
@ -9,16 +10,7 @@ import (
|
|||||||
"golang.org/x/xerrors"
|
"golang.org/x/xerrors"
|
||||||
)
|
)
|
||||||
|
|
||||||
type LocalPath struct {
|
func StorageFromFile(path string, def *stores.StorageConfig) (*stores.StorageConfig, error) {
|
||||||
Path string
|
|
||||||
}
|
|
||||||
|
|
||||||
// .lotusstorage/storage.json
|
|
||||||
type StorageConfig struct {
|
|
||||||
StoragePaths []LocalPath
|
|
||||||
}
|
|
||||||
|
|
||||||
func StorageFromFile(path string, def *StorageConfig) (*StorageConfig, error) {
|
|
||||||
file, err := os.Open(path)
|
file, err := os.Open(path)
|
||||||
switch {
|
switch {
|
||||||
case os.IsNotExist(err):
|
case os.IsNotExist(err):
|
||||||
@ -34,8 +26,8 @@ func StorageFromFile(path string, def *StorageConfig) (*StorageConfig, error) {
|
|||||||
return StorageFromReader(file)
|
return StorageFromReader(file)
|
||||||
}
|
}
|
||||||
|
|
||||||
func StorageFromReader(reader io.Reader) (*StorageConfig, error) {
|
func StorageFromReader(reader io.Reader) (*stores.StorageConfig, error) {
|
||||||
var cfg StorageConfig
|
var cfg stores.StorageConfig
|
||||||
err := json.NewDecoder(reader).Decode(&cfg)
|
err := json.NewDecoder(reader).Decode(&cfg)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -44,7 +36,7 @@ func StorageFromReader(reader io.Reader) (*StorageConfig, error) {
|
|||||||
return &cfg, nil
|
return &cfg, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func WriteStorageFile(path string, config StorageConfig) error {
|
func WriteStorageFile(path string, config stores.StorageConfig) error {
|
||||||
b, err := json.MarshalIndent(config, "", " ")
|
b, err := json.MarshalIndent(config, "", " ")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("marshaling storage config: %w", err)
|
return xerrors.Errorf("marshaling storage config: %w", err)
|
||||||
|
@ -3,6 +3,7 @@ package client
|
|||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"errors"
|
"errors"
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage/ffiwrapper"
|
||||||
"io"
|
"io"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
@ -83,7 +84,7 @@ func (a *API) ClientStartDeal(ctx context.Context, params *api.StartDealParams)
|
|||||||
return nil, xerrors.Errorf("failed checking miners sector size: %w", err)
|
return nil, xerrors.Errorf("failed checking miners sector size: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
rt, _, err := api.ProofTypeFromSectorSize(ssize)
|
rt, _, err := ffiwrapper.ProofTypeFromSectorSize(ssize)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, xerrors.Errorf("bad sector size: %w", err)
|
return nil, xerrors.Errorf("bad sector size: %w", err)
|
||||||
}
|
}
|
||||||
|
@ -1,32 +1,34 @@
|
|||||||
package sectorstorage
|
package impl
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
||||||
|
"golang.org/x/xerrors"
|
||||||
|
|
||||||
"github.com/filecoin-project/specs-actors/actors/abi"
|
"github.com/filecoin-project/specs-actors/actors/abi"
|
||||||
storage2 "github.com/filecoin-project/specs-storage/storage"
|
storage2 "github.com/filecoin-project/specs-storage/storage"
|
||||||
"golang.org/x/xerrors"
|
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/api"
|
"github.com/filecoin-project/lotus/api"
|
||||||
"github.com/filecoin-project/lotus/api/client"
|
"github.com/filecoin-project/lotus/api/client"
|
||||||
"github.com/filecoin-project/lotus/lib/jsonrpc"
|
"github.com/filecoin-project/lotus/lib/jsonrpc"
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage"
|
||||||
)
|
)
|
||||||
|
|
||||||
type remote struct {
|
type remoteWorker struct {
|
||||||
api.WorkerApi
|
api.WorkerApi
|
||||||
closer jsonrpc.ClientCloser
|
closer jsonrpc.ClientCloser
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *remote) NewSector(ctx context.Context, sector abi.SectorID) error {
|
func (r *remoteWorker) NewSector(ctx context.Context, sector abi.SectorID) error {
|
||||||
return xerrors.New("unsupported")
|
return xerrors.New("unsupported")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *remote) AddPiece(ctx context.Context, sector abi.SectorID, pieceSizes []abi.UnpaddedPieceSize, newPieceSize abi.UnpaddedPieceSize, pieceData storage2.Data) (abi.PieceInfo, error) {
|
func (r *remoteWorker) AddPiece(ctx context.Context, sector abi.SectorID, pieceSizes []abi.UnpaddedPieceSize, newPieceSize abi.UnpaddedPieceSize, pieceData storage2.Data) (abi.PieceInfo, error) {
|
||||||
return abi.PieceInfo{}, xerrors.New("unsupported")
|
return abi.PieceInfo{}, xerrors.New("unsupported")
|
||||||
}
|
}
|
||||||
|
|
||||||
func ConnectRemote(ctx context.Context, fa api.Common, url string) (*remote, error) {
|
func connectRemoteWorker(ctx context.Context, fa api.Common, url string) (*remoteWorker, error) {
|
||||||
token, err := fa.AuthNew(ctx, []api.Permission{"admin"})
|
token, err := fa.AuthNew(ctx, []api.Permission{"admin"})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, xerrors.Errorf("creating auth token for remote connection: %w", err)
|
return nil, xerrors.Errorf("creating auth token for remote connection: %w", err)
|
||||||
@ -40,12 +42,12 @@ func ConnectRemote(ctx context.Context, fa api.Common, url string) (*remote, err
|
|||||||
return nil, xerrors.Errorf("creating jsonrpc client: %w", err)
|
return nil, xerrors.Errorf("creating jsonrpc client: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
return &remote{wapi, closer}, nil
|
return &remoteWorker{wapi, closer}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *remote) Close() error {
|
func (r *remoteWorker) Close() error {
|
||||||
r.closer()
|
r.closer()
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ Worker = &remote{}
|
var _ sectorstorage.Worker = &remoteWorker{}
|
@ -50,7 +50,7 @@ func (sm *StorageMinerAPI) ServeRemote(w http.ResponseWriter, r *http.Request) {
|
|||||||
sm.StorageMgr.ServeHTTP(w, r)
|
sm.StorageMgr.ServeHTTP(w, r)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (sm *StorageMinerAPI) WorkerStats(context.Context) (map[uint64]api.WorkerStats, error) {
|
func (sm *StorageMinerAPI) WorkerStats(context.Context) (map[uint64]sectorstorage.WorkerStats, error) {
|
||||||
return sm.StorageMgr.WorkerStats(), nil
|
return sm.StorageMgr.WorkerStats(), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -149,7 +149,7 @@ func (sm *StorageMinerAPI) SectorsUpdate(ctx context.Context, id abi.SectorNumbe
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (sm *StorageMinerAPI) WorkerConnect(ctx context.Context, url string) error {
|
func (sm *StorageMinerAPI) WorkerConnect(ctx context.Context, url string) error {
|
||||||
w, err := sectorstorage.ConnectRemote(ctx, sm, url)
|
w, err := connectRemoteWorker(ctx, sm, url)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("connecting remote storage failed: %w", err)
|
return xerrors.Errorf("connecting remote storage failed: %w", err)
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,7 @@ package modules
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"net/http"
|
||||||
"reflect"
|
"reflect"
|
||||||
|
|
||||||
"github.com/ipfs/go-bitswap"
|
"github.com/ipfs/go-bitswap"
|
||||||
@ -43,7 +44,6 @@ import (
|
|||||||
"github.com/filecoin-project/lotus/chain/types"
|
"github.com/filecoin-project/lotus/chain/types"
|
||||||
"github.com/filecoin-project/lotus/markets/retrievaladapter"
|
"github.com/filecoin-project/lotus/markets/retrievaladapter"
|
||||||
"github.com/filecoin-project/lotus/miner"
|
"github.com/filecoin-project/lotus/miner"
|
||||||
"github.com/filecoin-project/lotus/node/config"
|
|
||||||
"github.com/filecoin-project/lotus/node/modules/dtypes"
|
"github.com/filecoin-project/lotus/node/modules/dtypes"
|
||||||
"github.com/filecoin-project/lotus/node/modules/helpers"
|
"github.com/filecoin-project/lotus/node/modules/helpers"
|
||||||
"github.com/filecoin-project/lotus/node/repo"
|
"github.com/filecoin-project/lotus/node/repo"
|
||||||
@ -92,7 +92,7 @@ func ProofsConfig(maddr dtypes.MinerAddress, fnapi lapi.FullNode) (*ffiwrapper.C
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
ppt, spt, err := lapi.ProofTypeFromSectorSize(ssize)
|
ppt, spt, err := ffiwrapper.ProofTypeFromSectorSize(ssize)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, xerrors.Errorf("bad sector size: %w", err)
|
return nil, xerrors.Errorf("bad sector size: %w", err)
|
||||||
}
|
}
|
||||||
@ -132,7 +132,7 @@ func StorageMiner(mctx helpers.MetricsCtx, lc fx.Lifecycle, api lapi.FullNode, h
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
ppt, _, err := lapi.ProofTypeFromSectorSize(sealer.SectorSize())
|
ppt, _, err := ffiwrapper.ProofTypeFromSectorSize(sealer.SectorSize())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, xerrors.Errorf("bad sector size: %w", err)
|
return nil, xerrors.Errorf("bad sector size: %w", err)
|
||||||
}
|
}
|
||||||
@ -320,7 +320,7 @@ func StorageProvider(ctx helpers.MetricsCtx, fapi lapi.FullNode, h host.Host, ds
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
rt, _, err := lapi.ProofTypeFromSectorSize(ssize)
|
rt, _, err := ffiwrapper.ProofTypeFromSectorSize(ssize)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@ -339,10 +339,10 @@ func RetrievalProvider(h host.Host, miner *storage.Miner, sealer sectorstorage.S
|
|||||||
return retrievalimpl.NewProvider(address, adapter, network, pieceStore, ibs, ds)
|
return retrievalimpl.NewProvider(address, adapter, network, pieceStore, ibs, ds)
|
||||||
}
|
}
|
||||||
|
|
||||||
func SectorStorage(mctx helpers.MetricsCtx, lc fx.Lifecycle, ls stores.LocalStorage, si stores.SectorIndex, cfg *ffiwrapper.Config, sc config.Storage, urls sectorstorage.URLs, ca lapi.Common) (*sectorstorage.Manager, error) {
|
func SectorStorage(mctx helpers.MetricsCtx, lc fx.Lifecycle, ls stores.LocalStorage, si stores.SectorIndex, cfg *ffiwrapper.Config, sc sectorstorage.SealerConfig, urls sectorstorage.URLs, sa sectorstorage.StorageAuth) (*sectorstorage.Manager, error) {
|
||||||
ctx := helpers.LifecycleCtx(mctx, lc)
|
ctx := helpers.LifecycleCtx(mctx, lc)
|
||||||
|
|
||||||
sst, err := sectorstorage.New(ctx, ls, si, cfg, sc, urls, ca)
|
sst, err := sectorstorage.New(ctx, ls, si, cfg, sc, urls, sa)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@ -359,3 +359,14 @@ func SectorStorage(mctx helpers.MetricsCtx, lc fx.Lifecycle, ls stores.LocalStor
|
|||||||
|
|
||||||
return sst, nil
|
return sst, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func StorageAuth(ctx helpers.MetricsCtx, ca lapi.Common) (sectorstorage.StorageAuth, error) {
|
||||||
|
token, err := ca.AuthNew(ctx, []lapi.Permission{"admin"})
|
||||||
|
if err != nil {
|
||||||
|
return nil, xerrors.Errorf("creating storage auth header: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
headers := http.Header{}
|
||||||
|
headers.Add("Authorization", "Bearer "+string(token))
|
||||||
|
return sectorstorage.StorageAuth(headers), nil
|
||||||
|
}
|
||||||
|
@ -5,6 +5,7 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
"crypto/rand"
|
"crypto/rand"
|
||||||
"github.com/filecoin-project/lotus/lib/lotuslog"
|
"github.com/filecoin-project/lotus/lib/lotuslog"
|
||||||
|
"github.com/filecoin-project/lotus/storage/mockstorage"
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/ffiwrapper"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/ffiwrapper"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
@ -310,7 +311,7 @@ func mockSbBuilder(t *testing.T, nFull int, storage []int) ([]test.TestNode, []t
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
genm, k, err := mock.PreSeal(2048, maddr, nPreseal)
|
genm, k, err := mockstorage.PreSeal(2048, maddr, nPreseal)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@ package repo
|
|||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
@ -282,26 +283,26 @@ func (fsr *fsLockedRepo) Config() (interface{}, error) {
|
|||||||
return config.FromFile(fsr.join(fsConfig), defConfForType(fsr.repoType))
|
return config.FromFile(fsr.join(fsConfig), defConfForType(fsr.repoType))
|
||||||
}
|
}
|
||||||
|
|
||||||
func (fsr *fsLockedRepo) GetStorage() (config.StorageConfig, error) {
|
func (fsr *fsLockedRepo) GetStorage() (stores.StorageConfig, error) {
|
||||||
fsr.storageLk.Lock()
|
fsr.storageLk.Lock()
|
||||||
defer fsr.storageLk.Unlock()
|
defer fsr.storageLk.Unlock()
|
||||||
|
|
||||||
return fsr.getStorage(nil)
|
return fsr.getStorage(nil)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (fsr *fsLockedRepo) getStorage(def *config.StorageConfig) (config.StorageConfig, error) {
|
func (fsr *fsLockedRepo) getStorage(def *stores.StorageConfig) (stores.StorageConfig, error) {
|
||||||
c, err := config.StorageFromFile(fsr.join(fsStorageConfig), def)
|
c, err := config.StorageFromFile(fsr.join(fsStorageConfig), def)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return config.StorageConfig{}, err
|
return stores.StorageConfig{}, err
|
||||||
}
|
}
|
||||||
return *c, nil
|
return *c, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (fsr *fsLockedRepo) SetStorage(c func(*config.StorageConfig)) error {
|
func (fsr *fsLockedRepo) SetStorage(c func(*stores.StorageConfig)) error {
|
||||||
fsr.storageLk.Lock()
|
fsr.storageLk.Lock()
|
||||||
defer fsr.storageLk.Unlock()
|
defer fsr.storageLk.Unlock()
|
||||||
|
|
||||||
sc, err := fsr.getStorage(&config.StorageConfig{})
|
sc, err := fsr.getStorage(&stores.StorageConfig{})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("get storage: %w", err)
|
return xerrors.Errorf("get storage: %w", err)
|
||||||
}
|
}
|
||||||
|
@ -2,12 +2,12 @@ package repo
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
||||||
|
|
||||||
"github.com/ipfs/go-datastore"
|
"github.com/ipfs/go-datastore"
|
||||||
"github.com/multiformats/go-multiaddr"
|
"github.com/multiformats/go-multiaddr"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/chain/types"
|
"github.com/filecoin-project/lotus/chain/types"
|
||||||
"github.com/filecoin-project/lotus/node/config"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -38,8 +38,8 @@ type LockedRepo interface {
|
|||||||
// Returns config in this repo
|
// Returns config in this repo
|
||||||
Config() (interface{}, error)
|
Config() (interface{}, error)
|
||||||
|
|
||||||
GetStorage() (config.StorageConfig, error)
|
GetStorage() (stores.StorageConfig, error)
|
||||||
SetStorage(func(*config.StorageConfig)) error
|
SetStorage(func(*stores.StorageConfig)) error
|
||||||
|
|
||||||
// SetAPIEndpoint sets the endpoint of the current API
|
// SetAPIEndpoint sets the endpoint of the current API
|
||||||
// so it can be read by API clients
|
// so it can be read by API clients
|
||||||
|
@ -41,12 +41,12 @@ type lockedMemRepo struct {
|
|||||||
|
|
||||||
tempDir string
|
tempDir string
|
||||||
token *byte
|
token *byte
|
||||||
sc *config.StorageConfig
|
sc *stores.StorageConfig
|
||||||
}
|
}
|
||||||
|
|
||||||
func (lmem *lockedMemRepo) GetStorage() (config.StorageConfig, error) {
|
func (lmem *lockedMemRepo) GetStorage() (stores.StorageConfig, error) {
|
||||||
if lmem.sc == nil {
|
if lmem.sc == nil {
|
||||||
lmem.sc = &config.StorageConfig{StoragePaths: []config.LocalPath{
|
lmem.sc = &stores.StorageConfig{StoragePaths: []stores.LocalPath{
|
||||||
{Path: lmem.Path()},
|
{Path: lmem.Path()},
|
||||||
}}
|
}}
|
||||||
}
|
}
|
||||||
@ -54,7 +54,7 @@ func (lmem *lockedMemRepo) GetStorage() (config.StorageConfig, error) {
|
|||||||
return *lmem.sc, nil
|
return *lmem.sc, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (lmem *lockedMemRepo) SetStorage(c func(*config.StorageConfig)) error {
|
func (lmem *lockedMemRepo) SetStorage(c func(*stores.StorageConfig)) error {
|
||||||
_, _ = lmem.GetStorage()
|
_, _ = lmem.GetStorage()
|
||||||
|
|
||||||
c(lmem.sc)
|
c(lmem.sc)
|
||||||
@ -75,8 +75,8 @@ func (lmem *lockedMemRepo) Path() string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if lmem.t == StorageMiner {
|
if lmem.t == StorageMiner {
|
||||||
if err := config.WriteStorageFile(filepath.Join(t, fsStorageConfig), config.StorageConfig{
|
if err := config.WriteStorageFile(filepath.Join(t, fsStorageConfig), stores.StorageConfig{
|
||||||
StoragePaths: []config.LocalPath{
|
StoragePaths: []stores.LocalPath{
|
||||||
{Path: t},
|
{Path: t},
|
||||||
}}); err != nil {
|
}}); err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
@ -220,7 +220,7 @@ func (lmem *lockedMemRepo) Config() (interface{}, error) {
|
|||||||
return lmem.mem.configF(lmem.t), nil
|
return lmem.mem.configF(lmem.t), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (lmem *lockedMemRepo) Storage() (config.StorageConfig, error) {
|
func (lmem *lockedMemRepo) Storage() (stores.StorageConfig, error) {
|
||||||
panic("implement me")
|
panic("implement me")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,18 +1,19 @@
|
|||||||
package mock
|
package mockstorage
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/filecoin-project/go-address"
|
"github.com/filecoin-project/go-address"
|
||||||
commcid "github.com/filecoin-project/go-fil-commcid"
|
commcid "github.com/filecoin-project/go-fil-commcid"
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/zerocomm"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/mock"
|
||||||
"github.com/filecoin-project/specs-actors/actors/abi"
|
"github.com/filecoin-project/specs-actors/actors/abi"
|
||||||
"github.com/filecoin-project/specs-actors/actors/abi/big"
|
"github.com/filecoin-project/specs-actors/actors/abi/big"
|
||||||
"github.com/filecoin-project/specs-actors/actors/builtin/market"
|
"github.com/filecoin-project/specs-actors/actors/builtin/market"
|
||||||
"github.com/filecoin-project/specs-actors/actors/crypto"
|
"github.com/filecoin-project/specs-actors/actors/crypto"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/api"
|
|
||||||
"github.com/filecoin-project/lotus/chain/types"
|
"github.com/filecoin-project/lotus/chain/types"
|
||||||
"github.com/filecoin-project/lotus/chain/wallet"
|
"github.com/filecoin-project/lotus/chain/wallet"
|
||||||
"github.com/filecoin-project/lotus/genesis"
|
"github.com/filecoin-project/lotus/genesis"
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage/ffiwrapper"
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage/zerocomm"
|
||||||
)
|
)
|
||||||
|
|
||||||
func PreSeal(ssize abi.SectorSize, maddr address.Address, sectors int) (*genesis.Miner, *types.KeyInfo, error) {
|
func PreSeal(ssize abi.SectorSize, maddr address.Address, sectors int) (*genesis.Miner, *types.KeyInfo, error) {
|
||||||
@ -30,7 +31,7 @@ func PreSeal(ssize abi.SectorSize, maddr address.Address, sectors int) (*genesis
|
|||||||
Sectors: make([]*genesis.PreSeal, sectors),
|
Sectors: make([]*genesis.PreSeal, sectors),
|
||||||
}
|
}
|
||||||
|
|
||||||
_, st, err := api.ProofTypeFromSectorSize(ssize)
|
_, st, err := ffiwrapper.ProofTypeFromSectorSize(ssize)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, nil, err
|
return nil, nil, err
|
||||||
}
|
}
|
||||||
@ -41,7 +42,7 @@ func PreSeal(ssize abi.SectorSize, maddr address.Address, sectors int) (*genesis
|
|||||||
preseal.ProofType = st
|
preseal.ProofType = st
|
||||||
preseal.CommD = zerocomm.ZeroPieceCommitment(abi.PaddedPieceSize(ssize).Unpadded())
|
preseal.CommD = zerocomm.ZeroPieceCommitment(abi.PaddedPieceSize(ssize).Unpadded())
|
||||||
d, _ := commcid.CIDToPieceCommitmentV1(preseal.CommD)
|
d, _ := commcid.CIDToPieceCommitmentV1(preseal.CommD)
|
||||||
r := commDR(d)
|
r := mock.CommDR(d)
|
||||||
preseal.CommR = commcid.ReplicaCommitmentV1ToCID(r[:])
|
preseal.CommR = commcid.ReplicaCommitmentV1ToCID(r[:])
|
||||||
preseal.SectorID = abi.SectorNumber(i + 1)
|
preseal.SectorID = abi.SectorNumber(i + 1)
|
||||||
preseal.Deal = market.DealProposal{
|
preseal.Deal = market.DealProposal{
|
@ -2,13 +2,13 @@ package sealing
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage/ffiwrapper"
|
||||||
"io"
|
"io"
|
||||||
|
|
||||||
"golang.org/x/xerrors"
|
"golang.org/x/xerrors"
|
||||||
|
|
||||||
"github.com/filecoin-project/specs-actors/actors/abi"
|
"github.com/filecoin-project/specs-actors/actors/abi"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/api"
|
|
||||||
"github.com/filecoin-project/lotus/lib/nullreader"
|
"github.com/filecoin-project/lotus/lib/nullreader"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -49,7 +49,7 @@ func (m *Sealing) PledgeSector() error {
|
|||||||
|
|
||||||
size := abi.PaddedPieceSize(m.sealer.SectorSize()).Unpadded()
|
size := abi.PaddedPieceSize(m.sealer.SectorSize()).Unpadded()
|
||||||
|
|
||||||
_, rt, err := api.ProofTypeFromSectorSize(m.sealer.SectorSize())
|
_, rt, err := ffiwrapper.ProofTypeFromSectorSize(m.sealer.SectorSize())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error(err)
|
log.Error(err)
|
||||||
return
|
return
|
||||||
|
@ -2,6 +2,7 @@ package sealing
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage/ffiwrapper"
|
||||||
"io"
|
"io"
|
||||||
|
|
||||||
"github.com/filecoin-project/go-address"
|
"github.com/filecoin-project/go-address"
|
||||||
@ -132,7 +133,7 @@ func (m *Sealing) SealPiece(ctx context.Context, size abi.UnpaddedPieceSize, r i
|
|||||||
return xerrors.Errorf("adding piece to sector: %w", err)
|
return xerrors.Errorf("adding piece to sector: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
_, rt, err := api.ProofTypeFromSectorSize(m.sealer.SectorSize())
|
_, rt, err := ffiwrapper.ProofTypeFromSectorSize(m.sealer.SectorSize())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("bad sector size: %w", err)
|
return xerrors.Errorf("bad sector size: %w", err)
|
||||||
}
|
}
|
||||||
|
@ -55,3 +55,18 @@ func SectorSizeForRegisteredProof(p abi.RegisteredProof) (abi.SectorSize, error)
|
|||||||
return 0, fmt.Errorf("unsupported registered proof %d", p)
|
return 0, fmt.Errorf("unsupported registered proof %d", p)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func ProofTypeFromSectorSize(ssize abi.SectorSize) (abi.RegisteredProof, abi.RegisteredProof, error) {
|
||||||
|
switch ssize {
|
||||||
|
case 2 << 10:
|
||||||
|
return abi.RegisteredProof_StackedDRG2KiBPoSt, abi.RegisteredProof_StackedDRG2KiBSeal, nil
|
||||||
|
case 8 << 20:
|
||||||
|
return abi.RegisteredProof_StackedDRG8MiBPoSt, abi.RegisteredProof_StackedDRG8MiBSeal, nil
|
||||||
|
case 512 << 20:
|
||||||
|
return abi.RegisteredProof_StackedDRG512MiBPoSt, abi.RegisteredProof_StackedDRG512MiBSeal, nil
|
||||||
|
case 32 << 30:
|
||||||
|
return abi.RegisteredProof_StackedDRG32GiBPoSt, abi.RegisteredProof_StackedDRG32GiBSeal, nil
|
||||||
|
default:
|
||||||
|
return 0, 0, xerrors.Errorf("unsupported sector size for miner: %v", ssize)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -9,9 +9,10 @@ import (
|
|||||||
"go.opencensus.io/trace"
|
"go.opencensus.io/trace"
|
||||||
|
|
||||||
ffi "github.com/filecoin-project/filecoin-ffi"
|
ffi "github.com/filecoin-project/filecoin-ffi"
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
|
||||||
"github.com/filecoin-project/specs-actors/actors/abi"
|
"github.com/filecoin-project/specs-actors/actors/abi"
|
||||||
"github.com/filecoin-project/specs-storage/storage"
|
"github.com/filecoin-project/specs-storage/storage"
|
||||||
|
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (sb *Sealer) ComputeElectionPoSt(ctx context.Context, miner abi.ActorID, sectorInfo []abi.SectorInfo, challengeSeed abi.PoStRandomness, winners []abi.PoStCandidate) ([]abi.PoStProof, error) {
|
func (sb *Sealer) ComputeElectionPoSt(ctx context.Context, miner abi.ActorID, sectorInfo []abi.SectorInfo, challengeSeed abi.PoStRandomness, winners []abi.PoStCandidate) ([]abi.PoStProof, error) {
|
||||||
|
@ -12,7 +12,6 @@ import (
|
|||||||
"github.com/filecoin-project/specs-actors/actors/abi"
|
"github.com/filecoin-project/specs-actors/actors/abi"
|
||||||
storage2 "github.com/filecoin-project/specs-storage/storage"
|
storage2 "github.com/filecoin-project/specs-storage/storage"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/api"
|
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/ffiwrapper"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/ffiwrapper"
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/sealtasks"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/sealtasks"
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
||||||
@ -174,7 +173,7 @@ func (l *LocalWorker) Paths(ctx context.Context) ([]stores.StoragePath, error) {
|
|||||||
return l.localStore.Local(ctx)
|
return l.localStore.Local(ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l *LocalWorker) Info(context.Context) (api.WorkerInfo, error) {
|
func (l *LocalWorker) Info(context.Context) (WorkerInfo, error) {
|
||||||
hostname, err := os.Hostname() // TODO: allow overriding from config
|
hostname, err := os.Hostname() // TODO: allow overriding from config
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
@ -187,17 +186,17 @@ func (l *LocalWorker) Info(context.Context) (api.WorkerInfo, error) {
|
|||||||
|
|
||||||
h, err := sysinfo.Host()
|
h, err := sysinfo.Host()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return api.WorkerInfo{}, xerrors.Errorf("getting host info: %w", err)
|
return WorkerInfo{}, xerrors.Errorf("getting host info: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
mem, err := h.Memory()
|
mem, err := h.Memory()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return api.WorkerInfo{}, xerrors.Errorf("getting memory info: %w", err)
|
return WorkerInfo{}, xerrors.Errorf("getting memory info: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
return api.WorkerInfo{
|
return WorkerInfo{
|
||||||
Hostname: hostname,
|
Hostname: hostname,
|
||||||
Resources: api.WorkerResources{
|
Resources: WorkerResources{
|
||||||
MemPhysical: mem.Total,
|
MemPhysical: mem.Total,
|
||||||
MemSwap: mem.VirtualTotal,
|
MemSwap: mem.VirtualTotal,
|
||||||
MemReserved: mem.VirtualUsed + mem.Total - mem.Available, // TODO: sub this process
|
MemReserved: mem.VirtualUsed + mem.Total - mem.Available, // TODO: sub this process
|
@ -16,8 +16,6 @@ import (
|
|||||||
"github.com/filecoin-project/specs-actors/actors/abi"
|
"github.com/filecoin-project/specs-actors/actors/abi"
|
||||||
"github.com/filecoin-project/specs-storage/storage"
|
"github.com/filecoin-project/specs-storage/storage"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/api"
|
|
||||||
"github.com/filecoin-project/lotus/node/config"
|
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/ffiwrapper"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/ffiwrapper"
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/sealtasks"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/sealtasks"
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
||||||
@ -37,11 +35,26 @@ type Worker interface {
|
|||||||
// Returns paths accessible to the worker
|
// Returns paths accessible to the worker
|
||||||
Paths(context.Context) ([]stores.StoragePath, error)
|
Paths(context.Context) ([]stores.StoragePath, error)
|
||||||
|
|
||||||
Info(context.Context) (api.WorkerInfo, error)
|
Info(context.Context) (WorkerInfo, error)
|
||||||
|
|
||||||
Close() error
|
Close() error
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type WorkerInfo struct {
|
||||||
|
Hostname string
|
||||||
|
|
||||||
|
Resources WorkerResources
|
||||||
|
}
|
||||||
|
|
||||||
|
type WorkerResources struct {
|
||||||
|
MemPhysical uint64
|
||||||
|
MemSwap uint64
|
||||||
|
|
||||||
|
MemReserved uint64 // Used by system / other processes
|
||||||
|
|
||||||
|
GPUs []string
|
||||||
|
}
|
||||||
|
|
||||||
type SectorManager interface {
|
type SectorManager interface {
|
||||||
SectorSize() abi.SectorSize
|
SectorSize() abi.SectorSize
|
||||||
|
|
||||||
@ -76,7 +89,16 @@ type Manager struct {
|
|||||||
schedQueue *list.List // List[*workerRequest]
|
schedQueue *list.List // List[*workerRequest]
|
||||||
}
|
}
|
||||||
|
|
||||||
func New(ctx context.Context, ls stores.LocalStorage, si stores.SectorIndex, cfg *ffiwrapper.Config, sc config.Storage, urls URLs, ca api.Common) (*Manager, error) {
|
type SealerConfig struct {
|
||||||
|
// Local worker config
|
||||||
|
AllowPreCommit1 bool
|
||||||
|
AllowPreCommit2 bool
|
||||||
|
AllowCommit bool
|
||||||
|
}
|
||||||
|
|
||||||
|
type StorageAuth http.Header
|
||||||
|
|
||||||
|
func New(ctx context.Context, ls stores.LocalStorage, si stores.SectorIndex, cfg *ffiwrapper.Config, sc SealerConfig, urls URLs, sa StorageAuth) (*Manager, error) {
|
||||||
lstor, err := stores.NewLocal(ctx, ls, si, urls)
|
lstor, err := stores.NewLocal(ctx, ls, si, urls)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -87,10 +109,7 @@ func New(ctx context.Context, ls stores.LocalStorage, si stores.SectorIndex, cfg
|
|||||||
return nil, xerrors.Errorf("creating prover instance: %w", err)
|
return nil, xerrors.Errorf("creating prover instance: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
token, err := ca.AuthNew(ctx, []api.Permission{"admin"})
|
stor := stores.NewRemote(lstor, si, http.Header(sa))
|
||||||
headers := http.Header{}
|
|
||||||
headers.Add("Authorization", "Bearer "+string(token))
|
|
||||||
stor := stores.NewRemote(lstor, si, headers)
|
|
||||||
|
|
||||||
m := &Manager{
|
m := &Manager{
|
||||||
scfg: cfg,
|
scfg: cfg,
|
||||||
@ -150,8 +169,8 @@ func (m *Manager) AddLocalStorage(ctx context.Context, path string) error {
|
|||||||
return xerrors.Errorf("opening local path: %w", err)
|
return xerrors.Errorf("opening local path: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := m.ls.SetStorage(func(sc *config.StorageConfig) {
|
if err := m.ls.SetStorage(func(sc *stores.StorageConfig) {
|
||||||
sc.StoragePaths = append(sc.StoragePaths, config.LocalPath{Path: path})
|
sc.StoragePaths = append(sc.StoragePaths, stores.LocalPath{Path: path})
|
||||||
}); err != nil {
|
}); err != nil {
|
||||||
return xerrors.Errorf("get storage config: %w", err)
|
return xerrors.Errorf("get storage config: %w", err)
|
||||||
}
|
}
|
||||||
|
@ -17,7 +17,6 @@ import (
|
|||||||
logging "github.com/ipfs/go-log"
|
logging "github.com/ipfs/go-log"
|
||||||
"golang.org/x/xerrors"
|
"golang.org/x/xerrors"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/api"
|
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage"
|
"github.com/filecoin-project/lotus/storage/sectorstorage"
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/ffiwrapper"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/ffiwrapper"
|
||||||
)
|
)
|
||||||
@ -37,7 +36,7 @@ type SectorMgr struct {
|
|||||||
type mockVerif struct{}
|
type mockVerif struct{}
|
||||||
|
|
||||||
func NewMockSectorMgr(threads int, ssize abi.SectorSize) *SectorMgr {
|
func NewMockSectorMgr(threads int, ssize abi.SectorSize) *SectorMgr {
|
||||||
rt, _, err := api.ProofTypeFromSectorSize(ssize)
|
rt, _, err := ffiwrapper.ProofTypeFromSectorSize(ssize)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
@ -1,20 +1,6 @@
|
|||||||
package mock
|
package mock
|
||||||
|
|
||||||
import (
|
func CommDR(in []byte) (out [32]byte) {
|
||||||
"crypto/rand"
|
|
||||||
"io"
|
|
||||||
"io/ioutil"
|
|
||||||
)
|
|
||||||
|
|
||||||
func randB(n uint64) []byte {
|
|
||||||
b, err := ioutil.ReadAll(io.LimitReader(rand.Reader, int64(n)))
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
return b
|
|
||||||
}
|
|
||||||
|
|
||||||
func commDR(in []byte) (out [32]byte) {
|
|
||||||
for i, b := range in {
|
for i, b := range in {
|
||||||
out[i] = ^b
|
out[i] = ^b
|
||||||
}
|
}
|
||||||
|
@ -1,9 +1,10 @@
|
|||||||
package sectorstorage
|
package sectorstorage
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/filecoin-project/specs-actors/actors/abi"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/sealtasks"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/sealtasks"
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
||||||
"github.com/filecoin-project/specs-actors/actors/abi"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var FSOverheadSeal = map[stores.SectorFileType]int{ // 10x overheads
|
var FSOverheadSeal = map[stores.SectorFileType]int{ // 10x overheads
|
||||||
|
@ -3,10 +3,11 @@ package sectorstorage
|
|||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
"golang.org/x/xerrors"
|
||||||
|
|
||||||
"github.com/filecoin-project/specs-actors/actors/abi"
|
"github.com/filecoin-project/specs-actors/actors/abi"
|
||||||
"golang.org/x/xerrors"
|
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage/stores"
|
||||||
)
|
)
|
||||||
|
|
||||||
type readonlyProvider struct {
|
type readonlyProvider struct {
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
package sectorstorage
|
package sectorstorage
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/filecoin-project/lotus/storage/sectorstorage/sealtasks"
|
|
||||||
"github.com/filecoin-project/specs-actors/actors/abi"
|
|
||||||
"golang.org/x/xerrors"
|
"golang.org/x/xerrors"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/api"
|
"github.com/filecoin-project/specs-actors/actors/abi"
|
||||||
|
|
||||||
|
"github.com/filecoin-project/lotus/storage/sectorstorage/sealtasks"
|
||||||
)
|
)
|
||||||
|
|
||||||
const mib = 1 << 20
|
const mib = 1 << 20
|
||||||
@ -39,7 +39,7 @@ func (r *workerRequest) respond(resp workerResponse) {
|
|||||||
type workerHandle struct {
|
type workerHandle struct {
|
||||||
w Worker
|
w Worker
|
||||||
|
|
||||||
info api.WorkerInfo
|
info WorkerInfo
|
||||||
|
|
||||||
memUsedMin uint64
|
memUsedMin uint64
|
||||||
memUsedMax uint64
|
memUsedMax uint64
|
||||||
|
@ -1,15 +1,22 @@
|
|||||||
package sectorstorage
|
package sectorstorage
|
||||||
|
|
||||||
import "github.com/filecoin-project/lotus/api"
|
type WorkerStats struct {
|
||||||
|
Info WorkerInfo
|
||||||
|
|
||||||
func (m *Manager) WorkerStats() map[uint64]api.WorkerStats {
|
MemUsedMin uint64
|
||||||
|
MemUsedMax uint64
|
||||||
|
GpuUsed bool
|
||||||
|
CpuUse int
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *Manager) WorkerStats() map[uint64]WorkerStats {
|
||||||
m.workersLk.Lock()
|
m.workersLk.Lock()
|
||||||
defer m.workersLk.Unlock()
|
defer m.workersLk.Unlock()
|
||||||
|
|
||||||
out := map[uint64]api.WorkerStats{}
|
out := map[uint64]WorkerStats{}
|
||||||
|
|
||||||
for id, handle := range m.workers {
|
for id, handle := range m.workers {
|
||||||
out[uint64(id)] = api.WorkerStats{
|
out[uint64(id)] = WorkerStats{
|
||||||
Info: handle.info,
|
Info: handle.info,
|
||||||
MemUsedMin: handle.memUsedMin,
|
MemUsedMin: handle.memUsedMin,
|
||||||
MemUsedMax: handle.memUsedMax,
|
MemUsedMax: handle.memUsedMax,
|
||||||
|
@ -10,7 +10,7 @@ import (
|
|||||||
logging "github.com/ipfs/go-log/v2"
|
logging "github.com/ipfs/go-log/v2"
|
||||||
"golang.org/x/xerrors"
|
"golang.org/x/xerrors"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/lib/tarutil"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/tarutil"
|
||||||
)
|
)
|
||||||
|
|
||||||
var log = logging.Logger("stores")
|
var log = logging.Logger("stores")
|
||||||
|
@ -9,10 +9,9 @@ import (
|
|||||||
"path/filepath"
|
"path/filepath"
|
||||||
"sync"
|
"sync"
|
||||||
|
|
||||||
"github.com/filecoin-project/specs-actors/actors/abi"
|
|
||||||
"golang.org/x/xerrors"
|
"golang.org/x/xerrors"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/node/config"
|
"github.com/filecoin-project/specs-actors/actors/abi"
|
||||||
)
|
)
|
||||||
|
|
||||||
type StoragePath struct {
|
type StoragePath struct {
|
||||||
@ -34,9 +33,18 @@ type LocalStorageMeta struct {
|
|||||||
CanStore bool
|
CanStore bool
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// .lotusstorage/storage.json
|
||||||
|
type StorageConfig struct {
|
||||||
|
StoragePaths []LocalPath
|
||||||
|
}
|
||||||
|
|
||||||
|
type LocalPath struct {
|
||||||
|
Path string
|
||||||
|
}
|
||||||
|
|
||||||
type LocalStorage interface {
|
type LocalStorage interface {
|
||||||
GetStorage() (config.StorageConfig, error)
|
GetStorage() (StorageConfig, error)
|
||||||
SetStorage(func(*config.StorageConfig)) error
|
SetStorage(func(*StorageConfig)) error
|
||||||
}
|
}
|
||||||
|
|
||||||
const MetaFile = "sectorstore.json"
|
const MetaFile = "sectorstore.json"
|
||||||
|
@ -19,7 +19,7 @@ import (
|
|||||||
|
|
||||||
"github.com/filecoin-project/specs-actors/actors/abi"
|
"github.com/filecoin-project/specs-actors/actors/abi"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/lib/tarutil"
|
"github.com/filecoin-project/lotus/storage/sectorstorage/tarutil"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Remote struct {
|
type Remote struct {
|
||||||
|
Loading…
Reference in New Issue
Block a user