可以在官方文檔中找到對于scheduler的大致描述:
https://kubernetes.io/docs/concepts/scheduling-eviction/kube-scheduler/
大意就是,kube-schedulor是默認的scheduler并且是控制平面的一部分,如果需要的話,可以自己編寫
替換。對于每一個需要被分配的pod,調度器都會為他們選擇一個最優的容器去運行,但是每一個容器對于資源有不同的約束條件,所以需要在現有的node上通過調度器的指定條件去賽選出符合條件的node。滿足條件的pod就稱為可行節點(feasible node),如果沒有合適的節點,pod會一直不可調度直到調度器找到合適的位置時。
確實,首先要做的就是大致瀏覽下三個主要文件。
調度器找到可行的節點然后運行一些列的方法去給可行的節點評分,然后選擇一個分數最高的節點去放置pod,然后schedulor在稱為bind的過程中給API server發送信息。
調度的決策包括個人和集體資源需求,硬件/軟件/策略約束,親和力和反親和力規范等等。
schedulor對于節點的選擇主要進行兩個步驟:
1.賽選
2.評分
賽選是為了找到合適的節點,比如PodFitsResources候選節點是否有足夠的可用資源去滿足pod指定的需求,這一部完成之后,node list 就會包含所有合適的節點,通常情況下,這里不只一個,如果為空,則pod為unschedulable,
接著是score step,調度器為每一個node rank,然后選擇一個最好的節點。然后將pod放置到score最高的節點上,如果有節點分數相同,那么解隨機選擇一個。
并切還有兩種額外的方法去配置賽選與評分的規則
1 [Scheduling Policies](https://kubernetes.io/docs/reference/scheduling/policies) 通過調度策略,您可以配置謂詞進行過濾,配置優先級進行評分。
2: [Scheduling Profiles](https://kubernetes.io/docs/reference/scheduling/config/#profiles) 調度配置文件允許您配置實現不同調度階段的插件,包括:QueueSort、Filter、Score、Bind、Reserve、Permit等。您還可以配置kube調度器以運行不同的配置文件
這道這個大致的描述之后,就可以繼續看代碼啦。
- 文章翻譯
- Large-scale cluster management at Google with Borg
- Borg Omega and kubernetes
- scaling kubernetes to 7500 nodes
- bpf 的過去,未來與現在
- Demystifying Istio Circuit Breaking
- 知識圖譜
- skill level up graph
- 一、運維常用技能
- 1.0 Vim (編輯器)
- 1.1 Nginx & Tengine(Web服務)
- 基礎
- 1.2 zabbix
- 定義
- 登錄和配置用戶
- 1.3 RabbitMQ(消息隊列)
- 原理
- RabbitMQ(安裝)
- 1.4虛擬化技術
- KVM
- 1.5 Tomcat(Web中間件)
- 1.6Jenkins
- pipline
- 1.7 Docker
- network
- 1.8 Keepalived(負載均衡高可用)
- 1.9 Memcache(分布式緩存)
- 1.10 Zookeeper(分布式協調系統)
- 1.11 GitLab(版本控制)
- 1.12 Jenkins(運維自動化)
- 1.13 WAF(Web防火墻)
- 1.14 HAproxy負載均衡
- 1.15 NFS(文件傳輸)
- 1.16 Vim(編輯器)
- 1.17 Cobbler(自動化部署)
- 二、常用數據庫
- 2.1 MySQL(關系型數據庫)
- mysql主從復制
- 2.2 Mongodb(數據分析)
- 2.3 Redis(非關系數據庫)
- 三、自動化運維工具
- 3.1 Cobbler(系統自動化部署)
- 3.2 Ansible(自動化部署)
- 3.3 Puppet(自動化部署)
- 3.4 SaltStack(自動化運維)
- 四、存儲
- 4.1 GFS(文件型存儲)
- 4.2 Ceph(后端存儲)
- 五、運維監控工具
- 5.1 云鏡
- 5.2 ELK
- 六、運維云平臺
- 6.1 Kubernetes
- 6.2 OpenStack
- 介紹
- 安裝
- 七、Devops運維
- 7.1 理念
- 7.2 Devops運維實戰
- 八、編程語言
- 8.1 Shell
- 書籍《Wicked Cool Shell Scripts》
- 8.2 Python
- 8.3 C
- 8.4 Java
- leecode算法與數據結構
- 九、雜記
- 高優先級技能
- 知識點
- JD搜集
- 明顯的短板
- 1.0 Python
- 1.1 Kubernetes
- 1.18.2 《kubernetes in action》
- 遺漏知識點
- 1.18.3 GCP、azure、aliyun
- Azure文檔
- 1.18.5 《program with kubernetes》
- Istio
- HELM
- 《Kubernetes best practice》
- Kubernetes源碼學習
- Scheduler源碼
- 調度器入口
- 調度器框架
- Node篩選算法
- Node優先級算法
- pod搶占調度
- 入口
- 主要代碼結構
- new
- 文章翻譯
- Flannel
- 從二進制集群搭建
- 信息收集
- docker優化
- 1.2 shell
- 面試題
- grep awk sed 常見用法
- shell實踐
- 1.3 Data structure(數據結構)
- Calico
- Aliyun文檔以及重點模塊
- git
- 大數據組件
- 前端,后端,web框架
- cgroup,namespace
- 內核
- Linux搜集
- crontab
- centos7常用優化配置
- centos Mariadb
- eBPF
- ebpf的前世今生
- Linux性能問題排查與分析
- 性能分析搜集
- 性能分析常用10條
- 網絡性能優化
- 文本處理命令
- sql
- Iptables
- python面試題
- iptables
- iptables詳細
- zabbix面試題,proj
- prometheus
- web中間件
- nginx
- Haproxy
- grep sed awk
- Linux常用命令
- 云平臺
- 書籍Linux應用技巧
- kafka
- kafka面試題
- ETCD
- Jenkins
- 3天補充的點
- K8s源碼
- K8s
- k8s實操
- etcd
- test
- BPF
- PSFTP使用
- StackOverflow問答精選
- 問題
- 我對于學習思考
- 修改ssh超時時間
- 課程目錄
- 運維與運維開發
- The Person
- 個人雜談
- mysql主從復制
- 對于工作的認識與思考