Skip to content
This repository has been archived by the owner on Dec 20, 2024. It is now read-only.

Commit

Permalink
Merge pull request #896 from yunfeiyanggzq/big_bug
Browse files Browse the repository at this point in the history
bugfix:fix the bug blanklist can't work
  • Loading branch information
starnop authored Sep 12, 2019
2 parents 9f553e7 + 7f55443 commit ff32c01
Showing 1 changed file with 6 additions and 6 deletions.
12 changes: 6 additions & 6 deletions supernode/daemon/mgr/scheduler/manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -140,16 +140,16 @@ func (sm *Manager) sortExecutor(ctx context.Context, pieceNums []int, centerNum
})
}

func (sm *Manager) getPieceResults(ctx context.Context, taskID, clientID, peerID string, pieceNums []int, runningCount int) ([]*mgr.PieceResult, error) {
func (sm *Manager) getPieceResults(ctx context.Context, taskID, clientID, srcPID string, pieceNums []int, runningCount int) ([]*mgr.PieceResult, error) {
// validate ClientErrorCount
var useSupernode bool
srcPeerState, err := sm.progressMgr.GetPeerStateByPeerID(ctx, peerID)
srcPeerState, err := sm.progressMgr.GetPeerStateByPeerID(ctx, srcPID)
if err != nil {
return nil, err
}
if srcPeerState.ClientErrorCount.Get() > config.FailCountLimit {
logrus.Warnf("scheduler: peerID: %s got errors for %d times which reaches error limit: %d for taskID(%s)",
peerID, srcPeerState.ClientErrorCount.Get(), config.FailCountLimit, taskID)
srcPID, srcPeerState.ClientErrorCount.Get(), config.FailCountLimit, taskID)
useSupernode = true
}

Expand All @@ -165,7 +165,7 @@ func (sm *Manager) getPieceResults(ctx context.Context, taskID, clientID, peerID
if err != nil {
return nil, errors.Wrapf(errortypes.ErrUnknowError, "failed to get peerIDs for pieceNum: %d of taskID: %s", pieceNums[i], taskID)
}
dstPID = sm.tryGetPID(ctx, taskID, pieceNums[i], peerIDs)
dstPID = sm.tryGetPID(ctx, taskID, pieceNums[i], srcPID, peerIDs)
}

if dstPID == "" {
Expand Down Expand Up @@ -205,7 +205,7 @@ func (sm *Manager) getPieceResults(ctx context.Context, taskID, clientID, peerID
}

// tryGetPID returns an available dstPID from ps.pieceContainer.
func (sm *Manager) tryGetPID(ctx context.Context, taskID string, pieceNum int, peerIDs []string) (dstPID string) {
func (sm *Manager) tryGetPID(ctx context.Context, taskID string, pieceNum int, srcPID string, peerIDs []string) (dstPID string) {
defer func() {
if dstPID == "" {
dstPID = sm.cfg.GetSuperPID()
Expand Down Expand Up @@ -239,7 +239,7 @@ func (sm *Manager) tryGetPID(ctx context.Context, taskID string, pieceNum int, p
}

// if the v is in the blackList, try the next one.
blackInfo, err := sm.progressMgr.GetBlackInfoByPeerID(ctx, peerIDs[i])
blackInfo, err := sm.progressMgr.GetBlackInfoByPeerID(ctx, srcPID)
if err != nil && !errortypes.IsDataNotFound(err) {
logrus.Warnf("scheduler: failed to get blackInfo for peerID %s: %v", peerIDs[i], err)
continue
Expand Down

0 comments on commit ff32c01

Please sign in to comment.