當前位置: 首頁>>代碼示例>>Golang>>正文


Golang raft.ApplyFuture類代碼示例

本文整理匯總了Golang中github.com/hashicorp/raft.ApplyFuture的典型用法代碼示例。如果您正苦於以下問題:Golang ApplyFuture類的具體用法?Golang ApplyFuture怎麽用?Golang ApplyFuture使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了ApplyFuture類的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。

示例1: raftFutureErrorCheck

func raftFutureErrorCheck(future raft.ApplyFuture) {
	if err := future.Error(); err != nil {
		fmt.Printf("Apply Error 1: %v\n", err)
	}

	if !future.Response().(bool) {
		fmt.Printf("Apply Error 2:\n")
	}
}
開發者ID:nipuntalukdar,項目名稱:NipunTalukdarExamples,代碼行數:9,代碼來源:raftmodule.go

示例2: asyncPlanWait

// asyncPlanWait is used to apply and respond to a plan async
func (s *Server) asyncPlanWait(waitCh chan struct{}, future raft.ApplyFuture,
	result *structs.PlanResult, pending *pendingPlan) {
	defer metrics.MeasureSince([]string{"nomad", "plan", "apply"}, time.Now())
	defer close(waitCh)

	// Wait for the plan to apply
	if err := future.Error(); err != nil {
		s.logger.Printf("[ERR] nomad: failed to apply plan: %v", err)
		pending.respond(nil, err)
		return
	}

	// Respond to the plan
	result.AllocIndex = future.Index()
	pending.respond(result, nil)
}
開發者ID:shadabahmed,項目名稱:nomad,代碼行數:17,代碼來源:plan_apply.go

示例3: asyncPlanWait

// asyncPlanWait is used to apply and respond to a plan async
func (s *Server) asyncPlanWait(waitCh chan struct{}, future raft.ApplyFuture,
	result *structs.PlanResult, pending *pendingPlan) {
	defer metrics.MeasureSince([]string{"nomad", "plan", "apply"}, time.Now())
	defer close(waitCh)

	// Wait for the plan to apply
	if err := future.Error(); err != nil {
		s.logger.Printf("[ERR] nomad: failed to apply plan: %v", err)
		pending.respond(nil, err)
		return
	}

	// Respond to the plan
	result.AllocIndex = future.Index()

	// If this is a partial plan application, we need to ensure the scheduler
	// at least has visibility into any placements it made to avoid double placement.
	// The RefreshIndex computed by evaluatePlan may be stale due to evaluation
	// against an optimistic copy of the state.
	if result.RefreshIndex != 0 {
		result.RefreshIndex = maxUint64(result.RefreshIndex, result.AllocIndex)
	}
	pending.respond(result, nil)
}
開發者ID:PagerDuty,項目名稱:nomad,代碼行數:25,代碼來源:plan_apply.go

示例4: planWaitFuture

// planWaitFuture is used to wait for the Raft future to complete
func planWaitFuture(future raft.ApplyFuture) (uint64, error) {
	if err := future.Error(); err != nil {
		return 0, err
	}
	return future.Index(), nil
}
開發者ID:carriercomm,項目名稱:nomad,代碼行數:7,代碼來源:plan_apply_test.go


注:本文中的github.com/hashicorp/raft.ApplyFuture類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。