Kubernetes
Kubernetes (/ˌk(j)uːbərˈnɛtɪs, -ˈneɪtɪs, -ˈneɪtiːz, -ˈnɛtiːz/, genellikle K8s [2] olarak yazılır) yazılım dağıtımını, ölçeklendirmeyi ve yönetimini otomatikleştirmek için açık kaynaklı bir yerleştirme düzenleme sistemidir.[3][4] Google başlangıçta Kubernetes'i tasarladı, ancak artık Cloud Native Computing Foundation projeyi sürdürmektedir.
Orijinal yazar(lar) | |
---|---|
Geliştirici(ler) | Cloud Native Computing Foundation |
İlk yayınlanma | 7 Haziran 2014[1] | )
Programlama dili | Go |
Tür | Küme yönetim yazılımı |
Resmî sitesi | kubernetes.io |
Kod deposu |
Kubernetes, Docker, Containerd ve CRI-O ile çalışmaktadır.[5] Başlangıçta, bir "Dockershim" aracılığıyla yalnızca Docker runtime[6] ile arabirim oluşturdu; ancak, Kasım 2020'den [7] Nisan 2022'ye kadar Kubernetes, kapsayıcıyla Containerd aracılığıyla doğrudan arabirim oluşturma veya Docker'ı Container Runtime Interface (CRI) ile uyumlu bir çalışma zamanı ile değiştirme lehine "shim" kullanımdan kaldırdı.[8][9][10] Mayıs 2022'de v1.24'ün yayınlanmasıyla birlikte "Dockershim" tamamen kaldırıldı.[11]
Tarih
değiştirKubernetes (κυβερνήτης, Yunanca "dümenci", "pilot" veya "vali" ve sibernetiğin etimolojik köküdür) [4] Google tarafından 2014 yılının ortalarında duyuruldu.[12] Proje Joe Beda, Brendan Burns ve Craig McLuckie [13][14] tarafından oluşturuldu ve kısa süre sonra Brian Grant ve Tim Hockin de dahil olmak üzere diğer Google mühendisleri katıldı.[12]
Kubernetes'in tasarımı ve geliştirilmesi, Google'ın Borg küme yöneticisinden etkilenmiştir. En çok katkıda bulunanların çoğu daha önce Borg üzerinde çalışmıştı;[15][16] Kubernetes'i Star Trek eski Borg karakteri Seven of Nine [17] 'den sonra " Project 7 " olarak adlandırdılar ve logosuna yedi kollu bir tekerlek verdiler. C++ ile yazılmış Borg'dan farklı olarak [15] Kubernetes kaynak kodu Go dilindedir.
Kubernetes 1.0, 21 Temmuz 2015'te yayınlandı.[18] Google, Cloud Native Computing Foundation'ı (CNCF) [19] oluşturmak ve bir tohum teknolojisi olarak Kubernetes'i sunmak için Linux Foundation ile birlikte çalıştı. Şubat 2016'da [20] Kubernetes için Helm [21][22] paket yöneticisi yayınlandı.
Google zaten yönetilen Kubernetes hizmetleri sunarken Red Hat, 2014'te Kubernetes projesinin başlangıcından bu yana OpenShift'in bir parçası olarak Kubernetes'i destekliyordu.[23] Ancak 2017 yılında, başlıca rakipler Kubernetes etrafında toplandı ve bunun için şu yazılımlar için yerel destek eklediklerini duyurdu:
- Ağustos ayında, VMWare (Pivotal Cloud Foundry'nin savunucusu) [24]
- Eylül ayında, Mesosphere, Inc. (Marathon ve Mesos savunucusu) [25]
- Ekim ayında, Docker, Inc. (Docker savunucusu) [26]
- daha sonra aynı Ekim, Microsoft Azure [27]
- Kasım ayında AWS, Kubernetes için Elastic Container Service (EKS) aracılığıyla Kubernetes desteğini duyurdu [28]
6 Mart 2018'de Kubernetes Projesi, GitHub projeleri listesinde Linux çekirdeğinden sonra taahhüt sayısı ile dokuzuncu, yazarlar ve sayılarda ikinci sırada yer aldı.[29]
1.18 sürümüne kadar Kubernetes, bir N-2 destek politikası izledi; bu, en son üç küçük sürümün güvenlik güncellemeleri ve hata düzeltmeleri aldığı anlamına gelir.[30] 1.19 sürümünden itibaren Kubernetes, bir N-3 destek politikası izler.[31]
Kavramlar
değiştirKubernetes, açık kaynaklı bir konteyner orkestrasyon sistemi olarak tanımlanır. Bu sistem, birden fazla konteyner uygulamasını koordine etmek, dağıtmak ve yönetmek için kullanılır. Kubernetes'in temel amacı, uygulamaların yüksek kullanılabilirlik ve ölçeklenebilirlik sağlamak için dağıtım, ölçeklendirme ve yönetim işlemlerini otomatikleştirmektir.
Kubernetes'in ana kavramları arasında aşağıdakiler bulunur:
- Konteyner: Yazılım uygulamalarını bir arada tutmak için kullanılan hafif ve taşınabilir bir sanallaştırma yöntemidir. Her bir konteyner, kendi izolasyon ortamında çalışır.
- Pod: Bir veya daha fazla konteynerin bir araya gelerek oluşturduğu en küçük uygulama birimidir. Bir pod, aynı fiziksel veya sanal makinede çalışan konteynerlerin bir araya getirilmesiyle oluşur.
- ReplicaSet: Belirli bir pod sayısının çalışmasını sağlamak için kullanılan bir kontrol mekanizmasıdır. ReplicaSet, bir pod grubunun belirli bir sayıda çalışmasını sağlar.
- Deployment: Uygulama dağıtımı için kullanılan bir kontrol mekanizmasıdır. Deployment, birden fazla replica seti üzerinde çalışır ve uygulamanın istenen durumunu sağlamak için pod'ların sayısını ve durumunu yönetir.
- Service: Pod'ların birbirleriyle iletişim kurabilmesi için kullanılan bir ağ kaynağıdır. Bir servis, bir pod grubuna erişmek için bir IP adresi ve DNS adı sağlar.
- Namespace: Kubernetes kaynaklarını ve objelerini gruplamak için kullanılan bir mantıksal yapıdır. Her bir namespace, belirli bir uygulama veya kullanım durumu için kaynakları gruplandırır.
Bu kavramlar, Kubernetes kullanıcılarına uygulamalarını hızlı ve güvenli bir şekilde yönetme imkanı sağlar.[32]
Dağıtımlar
değiştirÇeşitli kurumlar Kubernetes'i dağıtan Kubernetes tabanlı platformlar veya hizmet olarak altyapı (IaaS) sunar.[33][34]
Bunlar şunları içerir:
- Alibaba Cloud ACK (Alibaba Cloud Container Service for Kubernetes)
- Amazon EKS (Elastic Kubernetes Service)
- DigitalOcean tarafından yönetilen Kubernetes Hizmeti
- Google GKE (Google Kubernetes Engine)
- IBM Cloud Kubernetes Services
- Microsoft AKS (Azure Kubernetes Services)
- Mirantis K0s
- Oracle Container Engine for Kubernetes
- Red Hat Openshift
- SUSE Rancher Kubernetes Engine (RKE)
- VMware Tanzu
Sürüm çizelgesi
değiştirDestek pencereleri
değiştirAşağıdaki tablo, her bir sürümün desteklendiği/desteklendiği dönemi görselleştirir [35]
Ayrıca bakınız
değiştir- Küme yönetimi yazılımı listesi
- Open Service Mesh
- OpenShift
- Docker
Kaynakça
değiştir- ^ "First GitHub commit for Kubernetes". github.com. 7 Haziran 2014. 1 Mart 2017 tarihinde kaynağından arşivlendi.
- ^ "Kubernetes GitHub Repository". GitHub. 22 Ocak 2021. 22 Ocak 2016 tarihinde kaynağından arşivlendi.
- ^ "kubernetes/kubernetes". GitHub (İngilizce). 21 Nisan 2017 tarihinde kaynağından arşivlendi. Erişim tarihi: 28 Mart 2017.
- ^ a b "What is Kubernetes?". Kubernetes. 1 Nisan 2017 tarihinde kaynağından arşivlendi. Erişim tarihi: 31 Mart 2017.
- ^ "Container runtimes". Kubernetes (İngilizce). 18 Temmuz 2019 tarihinde kaynağından arşivlendi. Erişim tarihi: 14 Kasım 2021.
- ^ "Kubernetes v1.12: Introducing RuntimeClass". kubernetes.io. 10 Ekim 2018. 10 Ekim 2018 tarihinde kaynağından arşivlendi.
- ^ "Deprecate Dockershim - Kubernetes Github repository - PR 94624". Github.com. 1 Aralık 2020 tarihinde kaynağından arşivlendi.
- ^ "Don't Panic: Kubernetes and Docker". Kubernetes Blog (İngilizce). 2 Aralık 2020. 3 Aralık 2020 tarihinde kaynağından arşivlendi. Erişim tarihi: 22 Aralık 2020.
- ^ "Introducing Container Runtime Interface (CRI) in Kubernetes". Kubernetes (İngilizce). 19 Aralık 2016. 27 Mayıs 2018 tarihinde kaynağından arşivlendi. Erişim tarihi: 16 Mayıs 2021.
- ^ "kubernetes/community". GitHub (İngilizce). 20 Ağustos 2016 tarihinde kaynağından arşivlendi. Erişim tarihi: 16 Mayıs 2021.
- ^ "Updated: Dockershim Removal FAQ". Kubernetes Blog. 17 Şubat 2022. 17 Şubat 2022 tarihinde kaynağından arşivlendi.
- ^ a b Metz. "Google Open Sources Its Secret Weapon in Cloud Computing". Wired. 10 Eylül 2015 tarihinde kaynağından arşivlendi. Erişim tarihi: 24 Eylül 2015.
- ^ Metz. "Google Made Its Secret Blueprint Public to Boost Its Cloud". Wired (İngilizce). 1 Temmuz 2016 tarihinde kaynağından arşivlendi. Erişim tarihi: 27 Haziran 2016.
- ^ The History of Kubernetes & the Community Behind It, 20 Temmuz 2018, 27 Şubat 2022 tarihinde kaynağından arşivlendi Yazar
|ad1=
eksik|soyadı1=
(yardım) - ^ a b Abhishek Verma (April 21–24, 2015). "Large-scale cluster management at Google with Borg". Proceedings of the European Conference on Computer Systems (EuroSys). 27 Temmuz 2017 tarihinde kaynağından arşivlendi.
- ^ "Borg, Omega, and Kubernetes - ACM Queue". queue.acm.org. 9 Temmuz 2016 tarihinde kaynağından arşivlendi. Erişim tarihi: 27 Haziran 2016.
- ^ "Early Stage Startup Heptio Aims to Make Kubernetes Friendly". 18 Temmuz 2023 tarihinde kaynağından arşivlendi. Erişim tarihi: 6 Aralık 2016.
- ^ "As Kubernetes Hits 1.0, Google Donates Technology To Newly Formed Cloud Native Computing Foundation". TechCrunch. 23 Eylül 2015 tarihinde kaynağından arşivlendi. Erişim tarihi: 24 Eylül 2015.
- ^ "Cloud Native Computing Foundation". 3 Temmuz 2017 tarihinde kaynağından arşivlendi.
- ^ "Release v1.0: Merge pull request #277 from jackgr/master · helm/helm". GitHub (İngilizce). 16 Aralık 2021 tarihinde kaynağından arşivlendi. Erişim tarihi: 16 Mayıs 2021.
- ^ "Helm (package manager) - wikieduonline". www.wikieduonline.com. 17 Kasım 2020 tarihinde kaynağından arşivlendi. Erişim tarihi: 16 Mayıs 2021.
- ^ "Helm". helm.sh (İngilizce). 27 Kasım 2015 tarihinde kaynağından arşivlendi. Erişim tarihi: 16 Mayıs 2021.
- ^ "Red Hat and Google collaborate on Kubernetes to manage Docker containers at scale". 10 Temmuz 2014. 2 Temmuz 2019 tarihinde kaynağından arşivlendi. Erişim tarihi: 6 Ağustos 2022.
- ^ "VMware and Pivotal Launch Pivotal Container Service (PKS) and Collaborate with Google Cloud to Bring Kubernetes to Enterprise Customers". 29 Ağustos 2017. 6 Ekim 2022 tarihinde kaynağından arşivlendi. Erişim tarihi: 6 Ağustos 2022.
- ^ "Mesosphere adds Kubernetes support to its data center operating system". 6 Eylül 2017. 6 Eylül 2017 tarihinde kaynağından arşivlendi. Erişim tarihi: 6 Ağustos 2022. Yazar
|ad1=
eksik|soyadı1=
(yardım) - ^ "Docker Announces Enhancements to the Docker Platform to Simplify and Advance the Management of Kubernetes for Enterprise IT". 17 Ekim 2017. 26 Eylül 2020 tarihinde kaynağından arşivlendi.
- ^ "Introducing AKS (managed Kubernetes) and Azure Container Registry improvements". 24 Ekim 2017. 7 Şubat 2018 tarihinde kaynağından arşivlendi. Erişim tarihi: 6 Ağustos 2022. Yazar
|ad1=
eksik|soyadı1=
(yardım) - ^ "Introducing Amazon Elastic Container Service for Kubernetes (Preview)". 29 Kasım 2017. 30 Kasım 2017 tarihinde kaynağından arşivlendi. Erişim tarihi: 6 Ağustos 2022.
- ^ "Kubernetes Is First CNCF Project To Graduate". Cloud Native Computing Foundation (İngilizce). 6 Mart 2018. 29 Ekim 2018 tarihinde kaynağından (html) arşivlendi. Erişim tarihi: 3 Aralık 2018.
Compared to the 1.5 million projects on GitHub, Kubernetes is No. 9 for commits and No. 2 for authors/issues, second only to Linux.
Yazar|ad1=
eksik|soyadı1=
(yardım) - ^ "Kubernetes version and version skew support policy". Kubernetes. 16 Temmuz 2019 tarihinde kaynağından arşivlendi. Erişim tarihi: 3 Mart 2020.
- ^ a b "Kubernetes 1.19 Release Announcement > Increase Kubernetes support window to one year". Kubernetes. 26 Ağustos 2020. 28 Ağustos 2020 tarihinde kaynağından arşivlendi. Erişim tarihi: 28 Ağustos 2020.
- ^ "Kubernetes Arşivleri - Can Kütahya". 2 Nisan 2023 tarihinde kaynağından arşivlendi. Erişim tarihi: 13 Nisan 2023.
- ^ "The 7 Most Popular Kubernetes Distributions" (İngilizce). 25 Temmuz 2021 tarihinde kaynağından arşivlendi. Erişim tarihi: 28 Aralık 2021.
- ^ "Why Kubernetes Developer Ecosystem Needs A PaaS". Forbes (İngilizce). 12 Nisan 2021 tarihinde kaynağından arşivlendi. Erişim tarihi: 16 Mayıs 2021. Yazar
|ad1=
eksik|soyadı1=
(yardım) - ^ a b "Kubernetes Patch Releases". GitHub. 4 Mayıs 2022. 16 Aralık 2021 tarihinde kaynağından arşivlendi. Erişim tarihi: 9 Mayıs 2022.
- ^ "Kubernetes 1.19 Release Announcement". Kubernetes. 26 Ağustos 2020. 28 Ağustos 2020 tarihinde kaynağından arşivlendi. Erişim tarihi: 28 Ağustos 2020.