摘要:今年月份我們迎來了的驚喜發(fā)布,一大波新功能讓人眼花繚亂。為了提供安全保障,集群不會強行刪除未響應節(jié)點上的,如果用戶通過強行刪除會收到警告。已知問題已知問題及限制。你不需要調整的該參數(shù)的沒有授權。
今年9月份我們迎來了Kubernetes 1.4的驚喜發(fā)布,一大波新功能讓人眼花繚亂。經過將近三個月時間的打磨,如今Kubernetes再推出新版本,翹首以盼的Kubernetes 1.5重磅發(fā)布,本次版本更新涵蓋了4個主題、12個新特性以及4個原有基礎上的重大變更。期待不如眼疾手快,翻閱文章內容,享受一場Kubernetes 1.5的饕餮大餐吧~
主題簡介:1、StatefulSets (原名PetSets)
StatefulSets 現(xiàn)在是 beta 版 (主要是修復和穩(wěn)定性)
2、改善聯(lián)邦支持
新命令:kubefed
DaemonSets
部署
Configmaps
3、簡化集群部署
改進kubeadm
Master的HA設置
4、節(jié)點魯棒性及可擴展性
支持Windows Service容器
實現(xiàn)了CRI(容器運行時接口)
添加kubelet API調用時身份驗證和授權
新特性簡介:1、API 機制
[beta] kube-apiserver支持OpenAPI從alpha移動到beta, 第一個non-go客戶端是基于此特性。
2、應用
[Stable]當replica sets不能創(chuàng)建Pods時,它們將通過API報告失敗的詳細底層原因。
[Stable] kubectl apply現(xiàn)可通過--prune刪除不再需要的資源
[beta] Deployments現(xiàn)可通過API升級到新版本,而之前是無法通過滾動來進行升級的
[beta] StatefulSets允許要求持久化identity或單實例存儲的工作負載從而在Kubernetes創(chuàng)建和管理。
[beta]為了提供安全保障,集群不會強行刪除未響應節(jié)點上的Pods,如果用戶通過CLI強行刪除Pods會收到警告。
3、認證
[Alpha]改進了基于角色的訪問控制alpha API。(包括一組默認的集群角色)
[Beta]添加了對Kubelet API訪問的認證/授權機制。
4、AWS
[stable]角色出現(xiàn)在kubectl get nodes的結果里。
5、集群生命周期
[alpha] 提升了kubeadm二進制包的交互和可用性,從而更易于新建一個運行集群。
6、集群運維
[alpha] 在GCE上使用kube-up/kube-down腳本來創(chuàng)建/移除集群高可用(復制)的主節(jié)點。
7、聯(lián)邦
[beta] 支持聯(lián)邦ConfigMaps。
[alpha] 支持聯(lián)邦Daemonsets。
[alpha] 支持聯(lián)邦Deployments。
[alpha]集群聯(lián)邦:為聯(lián)邦資源添加對于DeleteOptions.OrphanDependents的支持。
[alpha]引入新命令行工具:kubefed,簡化聯(lián)邦控制臺的部署以及集群注冊/注銷體驗。
8、網絡
[stable]服務可以通過DNS名稱被其他服務引用,而不是只有在pods里才可以。
[beta]為NodePort類型和LoadBalancer的服務保留源IP的選項。
[stable]啟用beta ConfigMap參數(shù)支持的DNS水平自動伸縮
9、節(jié)點
[alpha]支持在容器運行時啟用用戶命名空間重映射的時候,保留對宿主用戶命名空間的訪問。
[alpha]引入了v1alpha1版本的CRI(容器運行時接口) API,它允許可插拔的容器運行時;現(xiàn)有一個已經就緒的用于測試和反饋的docker-CRI集成。
[alpha]Kubelet基于QoS層在每個Pod的CGroup層級里啟動容器。
[beta]Kubelet集成了memcg提示消息API,來檢測是否超過閾值。
[beta]引入了Beta版本的容器化節(jié)點一致性測試: gcr.io/google_containers/node-test:0.2。從而讓用戶驗證node設置。
10、調度
[alpha]添加了對不透明整數(shù)資源(node級)的審計支持。
[beta] PodDisruptionBudget已經升級到Beta版,當想要應用SLO時,可以用來安全地drain節(jié)點。
11、UI
[stable]Dashboard UI如今顯示面向用戶的對象及它們的資源使用情況。
12、Windows
[alpha]添加了對Windows Server 2016節(jié)點和調度Windows Server Container的支持。
已知問題
CRI已知問題及限制。
當volume路徑包含空格時,DeviceNameFromMount()函數(shù)不能正確的返回volume路徑。
聯(lián)邦alpha版的特性不具有特征定義,因此默認啟用,在未來的版本中將修復這一問題。
聯(lián)邦控制面板可通過更新控制面板組件Deployment規(guī)格的鏡像字段來進行升級,然而在該版本中聯(lián)邦控制面板升級尚未進行測試。
重大改變1、節(jié)點控制器不再強行刪除來源于apiServer的pods
對于有狀態(tài)的應用StatefulSet(原名為 PetSet)而言,這個改動意味著創(chuàng)建替換的Pods被阻塞,直到舊的Pods確定不再運行(意味著kubelet從分區(qū)返回,Node對象的刪除,云服務商里實例的刪除,或強行刪除api-Server里的Pod)。這里通過確保不可達的Pod不會被認為已經死亡來防止集群應用出現(xiàn)“腦裂”的狀況,除非一些“包圍”操作提供了上述之一的情況。
對于其他現(xiàn)有的除StatefulSet外的控制器,這對于控制器替換Pods沒有影響,因為控制器不會重用Pods名稱(他們使用generate-name)
用戶編寫的控制器會重用Pod對象的名稱,應該考慮這個變化。
當使用kubectl delete ... --grace-period=0 刪除一個對象時,客戶端將開始進行優(yōu)雅的刪除并等待,直到資源完全被刪除。要立即強制刪除,使用--force 標志。這可以防止用戶不小心讓兩個Stateful Set共享可能導致數(shù)據損壞的相同的持久存儲。
2、允許匿名API服務器的訪問,通過授權組系統(tǒng)設置認證的用戶
kube-apiserver添加了--anonymous-auth 標志,默認為true。當它啟用時,訪問安全端口的請求不會被其他配置的認證方法所拒絕,這些請求被當做匿名請求,并且用戶名為system:anonymous,組織為system:unauthenticated。
認證的用戶被設為system:authenticated組。
3、即使路徑是用于類型的有效字段,如果路徑在json文件下不提供字段,kubectl get -o jsonpath=... 將拋出一個錯誤。這個改變從pre-1.5版本開始,即使他們目前不在 json文件下,也會返回一些字段的默認值。
4、對于VolumeMounts的strategicmerge patchMergeKey是由“名稱”到“mountPath”的改變。這是必要的,因為名稱字段引用Volume的名稱,并且不是VolumeMount的唯一鍵。如果安裝多個相同的volume,多個VolumeMounts將有同樣的 Volume名稱。“mountPath”是獨一無二的,并可以作為mergekey。
升級前注意事項1、升級前重要的安全相關改變
必須在kube-apiserver設置--anonymous-auth=false參數(shù),除非你是一個測試該功能的開發(fā)者并且了解它。如果不這樣,你會允許未經授權的用戶訪問你的apiserver。
必須在聯(lián)邦apiserver設置--anonymous-auth=false參數(shù),除非你是一個測試該功能的開發(fā)者并且了解它。如果不這樣,你會允許未經授權的用戶訪問你的聯(lián)邦apiserver。你不需要調整kublete的該參數(shù):1.4的Kubelet APIs沒有授權。
2、batch/v2alpha1.ScheduledJob被重命名為batch/v2alpha1.CronJob。
3、PetSet被重命名為StatefulSet。如果你現(xiàn)在有PetSets,你要在升級為StatefulSets前后進行一些額外的遷移操作。
4、如果你從v1.4.x升級你的集群聯(lián)邦組件,請更新你的federation-apiserver和federation-controller-manager到新版本。
5、廢棄的kubelet --configure-cbr0參數(shù)被移除。經典的網絡模式也是。如果你依賴于此模式,請調研其他的網絡插件kubenet或cni是否滿足需求。
6、新的client-go結構,參考kubernetes/client-go進行版本控制策略。
7、廢棄的kube-scheduler --bind-pods-qps和--bind-pods burst參數(shù)被移除,替換為--kube-api-qps和--kube-api-burst。
8、如果你需要使用1.4的特性:PodDisruptionBudget(例如創(chuàng)建了PodDisruptionBudget對象),那么在從1.4升級為1.5之前,你一定要刪除所有創(chuàng)建的PodDisruptionBudget對象(policy/v1alpha1/PodDisruptionBudget)。升級之后不可能刪除這些對象。它們的存在也會妨礙你使用1.5里Beta版的PodDisruptionBudget特性(policy/v1beta1/PodDisruptionBudget)。如果你已經進行了升級,那么你需要降級到1.4來刪除這些policy/v1alpha1/PodDisruptionBudget對象。
tips:查看更多精彩內容?關注公眾號:tenxcloud2(時速云訂閱號),我們后續(xù)還會發(fā)布kubernetes 1.5相關文章,大家持續(xù)關注哦~
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/32528.html
摘要:曾為美國谷歌集群管理組核心成員,主要參與開發(fā)集群管理系統(tǒng)。保證系統(tǒng)升級軟硬件錯誤等均能及時被發(fā)現(xiàn)并處理,谷歌集群能小時不間斷工作。關于集群管理經驗,首先一定要專注于持久的運維自動化工具開發(fā)。 本文僅用于學習和交流目的,不得用于商業(yè)目的。非商業(yè)轉載請注明作譯者、出處,并保留本文的原始鏈接:http://www.ituring.com.cn/art... 訪談嘉賓: 鄧德源, 才云科技CT...
摘要:曾為美國谷歌集群管理組核心成員,主要參與開發(fā)集群管理系統(tǒng)。保證系統(tǒng)升級軟硬件錯誤等均能及時被發(fā)現(xiàn)并處理,谷歌集群能小時不間斷工作。關于集群管理經驗,首先一定要專注于持久的運維自動化工具開發(fā)。 本文僅用于學習和交流目的,不得用于商業(yè)目的。非商業(yè)轉載請注明作譯者、出處,并保留本文的原始鏈接:http://www.ituring.com.cn/art... 訪談嘉賓: 鄧德源, 才云科技CT...
摘要:自推出以來,許多重大的里程碑事件都推動了容器革命。它支持廣泛的編程語言基礎設施選項,并獲得容器生態(tài)系統(tǒng)的巨大支持。結論容器生態(tài)系統(tǒng)仍然在不斷發(fā)展與改變。最值得關注的,是在這一領域中,和各個供應商是如何進步,以推動容器生態(tài)系統(tǒng)的發(fā)展的。 Docker于 2013年推出以來,給軟件開發(fā)帶來了極具傳染性的振奮和創(chuàng)新,并獲得了來自各個行業(yè)、各個領域的巨大的支持——從大企業(yè)到初創(chuàng)公司,從研發(fā)到各...
摘要:自推出以來,許多重大的里程碑事件都推動了容器革命。它支持廣泛的編程語言基礎設施選項,并獲得容器生態(tài)系統(tǒng)的巨大支持。結論容器生態(tài)系統(tǒng)仍然在不斷發(fā)展與改變。最值得關注的,是在這一領域中,和各個供應商是如何進步,以推動容器生態(tài)系統(tǒng)的發(fā)展的。 Docker于 2013年推出以來,給軟件開發(fā)帶來了極具傳染性的振奮和創(chuàng)新,并獲得了來自各個行業(yè)、各個領域的巨大的支持——從大企業(yè)到初創(chuàng)公司,從研發(fā)到各...
閱讀 1418·2021-09-23 11:21
閱讀 3117·2019-08-30 14:14
閱讀 3199·2019-08-30 13:56
閱讀 4149·2019-08-30 11:20
閱讀 1958·2019-08-29 17:23
閱讀 2772·2019-08-29 16:14
閱讀 1704·2019-08-28 18:18
閱讀 1496·2019-08-26 12:14