内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

KubernetesCriticalPod怎么使用

本篇內(nèi)容介紹了“Kubernetes Critical Pod怎么使用”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

十載的民樂(lè)網(wǎng)站建設(shè)經(jīng)驗(yàn),針對(duì)設(shè)計(jì)、前端、開(kāi)發(fā)、售后、文案、推廣等六對(duì)一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。成都全網(wǎng)營(yíng)銷的優(yōu)勢(shì)是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整民樂(lè)建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無(wú)論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。創(chuàng)新互聯(lián)從事“民樂(lè)網(wǎng)站設(shè)計(jì)”,“民樂(lè)網(wǎng)站推廣”以來(lái),每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。

有什么方法標(biāo)識(shí)一個(gè)Pod為Critical Pod

規(guī)則1:

  • Enable Feature Gate ExperimentalCriticaPodAnnotation

  • 必須隸屬于kube-system namespace;

  • 必須加上Annotation scheduler.alpha.kubernetes.io/critical-pod=""

規(guī)則2:

  • Enable Feature Gate ExperimentalCriticaPodAnnotation, PodPriority

  • Pod的Priority不為空,且不小于2 * 10^9;

    system-node-critical priority = 10^9 + 1000;
    system-cluster-critical priority = 10^9;

滿足規(guī)則1或規(guī)則2之一,就認(rèn)為該P(yáng)od為Critical Pod;

Schedule Critical Pod

在default scheduler進(jìn)行pod調(diào)度的predicate階段,會(huì)注冊(cè)GeneralPredicates為default predicates之一,并沒(méi)有判斷critical Pod使用EssentialPredicates來(lái)對(duì)critical Pod進(jìn)行predicate process。這意味著什么呢?

我們看看GeneralPredicates和EssentialPredicates的關(guān)系就知道了。GeneralPredicates中,先調(diào)用noncriticalPredicates,再調(diào)用EssentialPredicates。因此如果你給Deployment/StatefulSet等(DeamonSet除外)標(biāo)識(shí)為Critical,那么在scheduler調(diào)度時(shí),仍然走GeneralPredicates的流程,會(huì)調(diào)用noncriticalPredicates,而你卻希望它直接走EssentialPredicates。

// GeneralPredicates checks whether noncriticalPredicates and EssentialPredicates pass. noncriticalPredicates are the predicates
// that only non-critical pods need and EssentialPredicates are the predicates that all pods, including critical pods, need
func GeneralPredicates(pod *v1.Pod, meta algorithm.PredicateMetadata, nodeInfo *schedulercache.NodeInfo) (bool, []algorithm.PredicateFailureReason, error) {
	var predicateFails []algorithm.PredicateFailureReason
	fit, reasons, err := noncriticalPredicates(pod, meta, nodeInfo)
	if err != nil {
		return false, predicateFails, err
	}
	if !fit {
		predicateFails = append(predicateFails, reasons...)
	}

	fit, reasons, err = EssentialPredicates(pod, meta, nodeInfo)
	if err != nil {
		return false, predicateFails, err
	}
	if !fit {
		predicateFails = append(predicateFails, reasons...)
	}

	return len(predicateFails) == 0, predicateFails, nil
}

noncriticalPredicates原意是想對(duì)non-critical pod做的額外predicate邏輯,這個(gè)邏輯就是PodFitsResources檢查。

pkg/scheduler/algorithm/predicates/predicates.go:1076

// noncriticalPredicates are the predicates that only non-critical pods need
func noncriticalPredicates(pod *v1.Pod, meta algorithm.PredicateMetadata, nodeInfo *schedulercache.NodeInfo) (bool, []algorithm.PredicateFailureReason, error) {
	var predicateFails []algorithm.PredicateFailureReason
	fit, reasons, err := PodFitsResources(pod, meta, nodeInfo)
	if err != nil {
		return false, predicateFails, err
	}
	if !fit {
		predicateFails = append(predicateFails, reasons...)
	}

	return len(predicateFails) == 0, predicateFails, nil
}

PodFitsResources就做以下檢查資源是否滿足要求:

  • Allowed Pod Number;

  • CPU;

  • Memory;

  • EphemeralStorage;

  • Extended Resources;

也就是說(shuō),如果你給Deployment/StatefulSet等(DeamonSet除外)標(biāo)識(shí)為Critical,那么對(duì)應(yīng)的Pod調(diào)度時(shí)仍然會(huì)檢查Allowed Pod Number, CPU, Memory, EphemeralStorage,Extended Resources是否足夠,如果不滿足則會(huì)觸發(fā)預(yù)選失敗,并且在Preempt階段也只是根據(jù)對(duì)應(yīng)的PriorityClass進(jìn)行正常的搶占邏輯,并沒(méi)有針對(duì)Critical Pod進(jìn)行特殊處理,因此最終可能會(huì)因?yàn)檎也坏綕M足資源要求的Node,導(dǎo)致該Critical Pod調(diào)度失敗,一直處于Pending狀態(tài)。

而用戶設(shè)置Critical Pod是不想因?yàn)橘Y源不足導(dǎo)致調(diào)度失敗的。那如果我就是想使用Deployment/StatefulSet等(DeamonSet除外)標(biāo)識(shí)為Critical Pod來(lái)部署關(guān)鍵服務(wù)呢?有以下兩個(gè)辦法:

  1. 按照前面提到的規(guī)則2,給Pod設(shè)置system-cluster-criticalsystem-node-critical Priority Class,這樣就會(huì)在scheduler正常的Preempt流程中搶占到資源完成調(diào)度。

  2. 按照前面提到的規(guī)則1,并且修改GeneralPredicates 的代碼如下,檢測(cè)是否為Critical Pod,如果是,則不執(zhí)行noncriticalPredicates邏輯,也就是說(shuō)predicate階段不對(duì)Allowed Pod Number, CPU, Memory, EphemeralStorage,Extended Resources資源進(jìn)行檢查。

func GeneralPredicates(pod *v1.Pod, meta algorithm.PredicateMetadata, nodeInfo *schedulercache.NodeInfo) (bool, []algorithm.PredicateFailureReason, error) {
	var predicateFails, resons []algorithm.PredicateFailureReason
	var fit bool
	var err error
	
	// **Modify**: check whether the pod is a Critical Pod, don't invoke noncriticalPredicates if false.
	isCriticalPod := utilfeature.DefaultFeatureGate.Enabled(features.ExperimentalCriticalPodAnnotation) &&
		kubelettypes.IsCriticalPod(newPod)
	
	if !isCriticalPod {
	   fit, reasons, err = noncriticalPredicates(pod, meta, nodeInfo)
    	if err != nil {
    		return false, predicateFails, err
    	}
	}
	
	if !fit {
		predicateFails = append(predicateFails, reasons...)
	}

	fit, reasons, err = EssentialPredicates(pod, meta, nodeInfo)
	if err != nil {
		return false, predicateFails, err
	}
	if !fit {
		predicateFails = append(predicateFails, reasons...)
	}

	return len(predicateFails) == 0, predicateFails, nil
}

方法1,其實(shí)Kubernetes在Admission Priority檢查時(shí)已經(jīng)幫你做了。

// admitPod makes sure a new pod does not set spec.Priority field. It also makes sure that the PriorityClassName exists if it is provided and resolves the pod priority from the PriorityClassName.
func (p *priorityPlugin) admitPod(a admission.Attributes) error {
	...
	if utilfeature.DefaultFeatureGate.Enabled(features.PodPriority) {
		var priority int32
		if len(pod.Spec.PriorityClassName) == 0 &&
			utilfeature.DefaultFeatureGate.Enabled(features.ExperimentalCriticalPodAnnotation) &&
			kubelettypes.IsCritical(a.GetNamespace(), pod.Annotations) {
			pod.Spec.PriorityClassName = scheduling.SystemClusterCritical
		}
            ...
}

在Admission時(shí)候會(huì)對(duì)Pod的Priority進(jìn)行檢查,如果發(fā)現(xiàn)您已經(jīng):

  • Enable PriorityClass Feature Gate;

  • Enable ExperimentalCriticalPodAnnotation Feature Gate;

  • 給Pod添加了ExperimentalCriticalPodAnnotation;

  • 部署在kube-system namespace;

  • 沒(méi)有手動(dòng)設(shè)置自定義PriorityClass;

那么,Admisson Priority階段會(huì)自動(dòng)給Pod添加SystemClusterCritical(system-cluster-critical) PriorityClass;

最佳實(shí)踐

通過(guò)上面的分析,給出如下最佳實(shí)踐:在Kubernetes集群中,通過(guò)非DeamonSet方式(比如Deployment、RS等)部署關(guān)鍵服務(wù)時(shí),為了在集群資源不足時(shí)仍能保證搶占調(diào)度成功,請(qǐng)確保如下事宜:

  • Enable PriorityClass Feature Gate;

  • Enable ExperimentalCriticalPodAnnotation Feature Gate;

  • 給Pod添加了ExperimentalCriticalPodAnnotation;

  • 部署在kube-system namespace;

  • 千萬(wàn)不要手動(dòng)設(shè)置自定義PriorityClass;

“Kubernetes Critical Pod怎么使用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

分享名稱:KubernetesCriticalPod怎么使用
文章路徑:http://m.rwnh.cn/article4/gdicoe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁(yè)設(shè)計(jì)公司域名注冊(cè)、網(wǎng)站內(nèi)鏈、網(wǎng)站排名、商城網(wǎng)站面包屑導(dǎo)航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)
东港市| 旬邑县| 鄂托克旗| 绍兴市| 隆子县| 岱山县| 醴陵市| 临泽县| 黔西| 苏州市| 延长县| 千阳县| 宿迁市| 土默特左旗| 德保县| 黑河市| 洪雅县| 郑州市| 澄迈县| 湘潭市| 右玉县| 冷水江市| 三门县| 佳木斯市| 积石山| 乡宁县| 如皋市| 北辰区| 浙江省| 高要市| 城口县| 长乐市| 博乐市| 凌云县| 新竹县| 南投市| 盈江县| 成安县| 饶阳县| 明溪县| 东台市|