Merge pull request #2608 from filecoin-project/feat/storage-remote-improvements
Update sector-storage, sealing sched-diag
This commit is contained in:
		
						commit
						d557c407c6
					
				| @ -63,6 +63,9 @@ type StorageMiner interface { | |||||||
| 	WorkerStats(context.Context) (map[uint64]storiface.WorkerStats, error) | 	WorkerStats(context.Context) (map[uint64]storiface.WorkerStats, error) | ||||||
| 	WorkerJobs(context.Context) (map[uint64][]storiface.WorkerJob, error) | 	WorkerJobs(context.Context) (map[uint64][]storiface.WorkerJob, error) | ||||||
| 
 | 
 | ||||||
|  | 	// SealingSchedDiag dumps internal sealing scheduler state
 | ||||||
|  | 	SealingSchedDiag(context.Context) (interface{}, error) | ||||||
|  | 
 | ||||||
| 	stores.SectorIndex | 	stores.SectorIndex | ||||||
| 
 | 
 | ||||||
| 	MarketImportDealData(ctx context.Context, propcid cid.Cid, path string) error | 	MarketImportDealData(ctx context.Context, propcid cid.Cid, path string) error | ||||||
|  | |||||||
| @ -231,6 +231,8 @@ type StorageMinerStruct struct { | |||||||
| 		WorkerStats   func(context.Context) (map[uint64]storiface.WorkerStats, error) `perm:"admin"` | 		WorkerStats   func(context.Context) (map[uint64]storiface.WorkerStats, error) `perm:"admin"` | ||||||
| 		WorkerJobs    func(context.Context) (map[uint64][]storiface.WorkerJob, error) `perm:"admin"` | 		WorkerJobs    func(context.Context) (map[uint64][]storiface.WorkerJob, error) `perm:"admin"` | ||||||
| 
 | 
 | ||||||
|  | 		SealingSchedDiag func(context.Context) (interface{}, 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"` | ||||||
| 		StorageStat          func(context.Context, stores.ID) (fsutil.FsStat, error)                                                                                       `perm:"admin"` | 		StorageStat          func(context.Context, stores.ID) (fsutil.FsStat, error)                                                                                       `perm:"admin"` | ||||||
| @ -902,6 +904,10 @@ func (c *StorageMinerStruct) WorkerJobs(ctx context.Context) (map[uint64][]stori | |||||||
| 	return c.Internal.WorkerJobs(ctx) | 	return c.Internal.WorkerJobs(ctx) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func (c *StorageMinerStruct) SealingSchedDiag(ctx context.Context) (interface{}, error) { | ||||||
|  | 	return c.Internal.SealingSchedDiag(ctx) | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func (c *StorageMinerStruct) StorageAttach(ctx context.Context, si stores.StorageInfo, st fsutil.FsStat) error { | func (c *StorageMinerStruct) StorageAttach(ctx context.Context, si stores.StorageInfo, st fsutil.FsStat) error { | ||||||
| 	return c.Internal.StorageAttach(ctx, si, st) | 	return c.Internal.StorageAttach(ctx, si, st) | ||||||
| } | } | ||||||
|  | |||||||
| @ -1,6 +1,7 @@ | |||||||
| package main | package main | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
|  | 	"encoding/json" | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"golang.org/x/xerrors" | 	"golang.org/x/xerrors" | ||||||
| 	"os" | 	"os" | ||||||
| @ -24,6 +25,7 @@ var sealingCmd = &cli.Command{ | |||||||
| 	Subcommands: []*cli.Command{ | 	Subcommands: []*cli.Command{ | ||||||
| 		sealingJobsCmd, | 		sealingJobsCmd, | ||||||
| 		sealingWorkersCmd, | 		sealingWorkersCmd, | ||||||
|  | 		sealingSchedDiagCmd, | ||||||
| 	}, | 	}, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -176,3 +178,31 @@ var sealingJobsCmd = &cli.Command{ | |||||||
| 		return tw.Flush() | 		return tw.Flush() | ||||||
| 	}, | 	}, | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | var sealingSchedDiagCmd = &cli.Command{ | ||||||
|  | 	Name:  "sched-diag", | ||||||
|  | 	Usage: "Dump internal scheduler state", | ||||||
|  | 	Action: func(cctx *cli.Context) error { | ||||||
|  | 		nodeApi, closer, err := lcli.GetStorageMinerAPI(cctx) | ||||||
|  | 		if err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 		defer closer() | ||||||
|  | 
 | ||||||
|  | 		ctx := lcli.ReqContext(cctx) | ||||||
|  | 
 | ||||||
|  | 		st, err := nodeApi.SealingSchedDiag(ctx) | ||||||
|  | 		if err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		j, err := json.MarshalIndent(&st, "", "  ") | ||||||
|  | 		if err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		fmt.Println(string(j)) | ||||||
|  | 
 | ||||||
|  | 		return nil | ||||||
|  | 	}, | ||||||
|  | } | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								go.mod
									
									
									
									
									
								
							| @ -29,7 +29,7 @@ require ( | |||||||
| 	github.com/filecoin-project/go-paramfetch v0.0.2-0.20200701152213-3e0f0afdc261 | 	github.com/filecoin-project/go-paramfetch v0.0.2-0.20200701152213-3e0f0afdc261 | ||||||
| 	github.com/filecoin-project/go-statestore v0.1.0 | 	github.com/filecoin-project/go-statestore v0.1.0 | ||||||
| 	github.com/filecoin-project/go-storedcounter v0.0.0-20200421200003-1c99c62e8a5b | 	github.com/filecoin-project/go-storedcounter v0.0.0-20200421200003-1c99c62e8a5b | ||||||
| 	github.com/filecoin-project/sector-storage v0.0.0-20200724175351-295300ff4671 | 	github.com/filecoin-project/sector-storage v0.0.0-20200727112136-9377cb376d25 | ||||||
| 	github.com/filecoin-project/specs-actors v0.8.1-0.20200724015154-3c690d9b7e1d | 	github.com/filecoin-project/specs-actors v0.8.1-0.20200724015154-3c690d9b7e1d | ||||||
| 	github.com/filecoin-project/specs-storage v0.1.1-0.20200622113353-88a9704877ea | 	github.com/filecoin-project/specs-storage v0.1.1-0.20200622113353-88a9704877ea | ||||||
| 	github.com/filecoin-project/storage-fsm v0.0.0-20200720190000-2cfe2fe3c334 | 	github.com/filecoin-project/storage-fsm v0.0.0-20200720190000-2cfe2fe3c334 | ||||||
|  | |||||||
							
								
								
									
										4
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								go.sum
									
									
									
									
									
								
							| @ -266,8 +266,8 @@ github.com/filecoin-project/go-storedcounter v0.0.0-20200421200003-1c99c62e8a5b/ | |||||||
| github.com/filecoin-project/sector-storage v0.0.0-20200615154852-728a47ab99d6/go.mod h1:M59QnAeA/oV+Z8oHFLoNpGMv0LZ8Rll+vHVXX7GirPM= | github.com/filecoin-project/sector-storage v0.0.0-20200615154852-728a47ab99d6/go.mod h1:M59QnAeA/oV+Z8oHFLoNpGMv0LZ8Rll+vHVXX7GirPM= | ||||||
| github.com/filecoin-project/sector-storage v0.0.0-20200712023225-1d67dcfa3c15 h1:miw6hiusb/MkV1ryoqUKKWnvHhPW00AYtyeCj0L8pqo= | github.com/filecoin-project/sector-storage v0.0.0-20200712023225-1d67dcfa3c15 h1:miw6hiusb/MkV1ryoqUKKWnvHhPW00AYtyeCj0L8pqo= | ||||||
| github.com/filecoin-project/sector-storage v0.0.0-20200712023225-1d67dcfa3c15/go.mod h1:salgVdX7qeXFo/xaiEQE29J4pPkjn71T0kt0n+VDBzo= | github.com/filecoin-project/sector-storage v0.0.0-20200712023225-1d67dcfa3c15/go.mod h1:salgVdX7qeXFo/xaiEQE29J4pPkjn71T0kt0n+VDBzo= | ||||||
| github.com/filecoin-project/sector-storage v0.0.0-20200724175351-295300ff4671 h1:9TqtFwy+6/Ywh3j81vFy3jQerD5DkxFY2Ul8nJPUHwg= | github.com/filecoin-project/sector-storage v0.0.0-20200727112136-9377cb376d25 h1:sTonFkDw3KrIFIJTfIevYXyk+Mu9LbjbOHn/fWoMOMc= | ||||||
| github.com/filecoin-project/sector-storage v0.0.0-20200724175351-295300ff4671/go.mod h1:f9W29dKqNFm8Su4OddGwkAQOYMKYUR5Fk2oC/JZDjCI= | github.com/filecoin-project/sector-storage v0.0.0-20200727112136-9377cb376d25/go.mod h1:f9W29dKqNFm8Su4OddGwkAQOYMKYUR5Fk2oC/JZDjCI= | ||||||
| github.com/filecoin-project/specs-actors v0.0.0-20200210130641-2d1fbd8672cf/go.mod h1:xtDZUB6pe4Pksa/bAJbJ693OilaC5Wbot9jMhLm3cZA= | github.com/filecoin-project/specs-actors v0.0.0-20200210130641-2d1fbd8672cf/go.mod h1:xtDZUB6pe4Pksa/bAJbJ693OilaC5Wbot9jMhLm3cZA= | ||||||
| github.com/filecoin-project/specs-actors v0.3.0/go.mod h1:nQYnFbQ7Y0bHZyq6HDEuVlCPR+U3z5Q3wMOQ+2aiV+Y= | github.com/filecoin-project/specs-actors v0.3.0/go.mod h1:nQYnFbQ7Y0bHZyq6HDEuVlCPR+U3z5Q3wMOQ+2aiV+Y= | ||||||
| github.com/filecoin-project/specs-actors v0.6.0/go.mod h1:dRdy3cURykh2R8O/DKqy8olScl70rmIS7GrB4hB1IDY= | github.com/filecoin-project/specs-actors v0.6.0/go.mod h1:dRdy3cURykh2R8O/DKqy8olScl70rmIS7GrB4hB1IDY= | ||||||
|  | |||||||
| @ -263,6 +263,10 @@ func (sm *StorageMinerAPI) WorkerConnect(ctx context.Context, url string) error | |||||||
| 	return sm.StorageMgr.AddWorker(ctx, w) | 	return sm.StorageMgr.AddWorker(ctx, w) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func (sm *StorageMinerAPI) SealingSchedDiag(ctx context.Context) (interface{}, error) { | ||||||
|  | 	return sm.StorageMgr.SchedDiag(ctx) | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func (sm *StorageMinerAPI) MarketImportDealData(ctx context.Context, propCid cid.Cid, path string) error { | func (sm *StorageMinerAPI) MarketImportDealData(ctx context.Context, propCid cid.Cid, path string) error { | ||||||
| 	fi, err := os.Open(path) | 	fi, err := os.Open(path) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
|  | |||||||
| @ -380,7 +380,6 @@ func mockSbBuilder(t *testing.T, nFull int, storage []test.StorageMiner) ([]test | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 	for i, def := range storage { | 	for i, def := range storage { | ||||||
| 		// TODO: support non-bootstrap miners
 | 		// TODO: support non-bootstrap miners
 | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user