Tez No İndirme Tez Künye Durumu
694092
Mikroservisler için verimli yerleştirme alternatiflerinin türetilmesi / Deriving efficient deployment alternatives for microservices
Yazar:IŞIL KARABEY AKSAKALLI
Danışman: DOÇ. DR. AHMET BURAK CAN ; DR. TURGAY ÇELİK
Yer Bilgisi: Hacettepe Üniversitesi / Fen Bilimleri Enstitüsü / Bilgisayar Mühendisliği Ana Bilim Dalı / Bilgisayar Mühendisliği Bilim Dalı
Konu:Bilgisayar Mühendisliği Bilimleri-Bilgisayar ve Kontrol = Computer Engineering and Computer Science and Control
Dizin:
Onaylandı
Doktora
Türkçe
2021
160 s.
Mikroservis mimarileri gev¸sek ba˘glanmı¸s, tek bir fonksiyonellik ile çalı¸sarak ba˘gımsız olarak konu¸slandırılabilen ve birbirleri ile belirli bir arayüz üzerinden ileti¸simde olan modüler yazılım bile¸senlerine dayalı popüler bir yakla¸sımdır. Ba˘gımsız yazılım bile¸senleri sayesinde servislerin ölçeklenebilirli˘gi, güncellenmesi ve bakımı oldukça kolayla¸smaktadır. Öte yandan mikroservis tabanlı uygulamaların bulut kaynaklarına yerle¸stirilmesi, tek parçalı (monolithic) uygulamalara göre daha karma¸sık bir süreçtir. Tek parçalı bir uygulama, bir yük dengeleyici arkasında yer alan bir grup sunucuya tek seferde da˘gıtılabilirken, farklı servislerden olu¸san bir mikroservis tabanlı uygulamada her servisin genellikle birden fazla çalı¸sma zamanı örne˘gi oldu˘gu varsayıldı˘gında, binlerce servisin yapılandırılması ve performanslı bir ¸sekilde da˘gıtılması zorlu bir süreçtir. Az sayıda mikroservisin bulundu˘gu bir uygulama, sistemi iyi bilen bir uzman tarafından manuel bir ¸sekilde da˘gıtılabilirken pratikte genellikle çok sayıda mikroservisin yer aldı˘gı uygulamalar görülmektedir. Artan servis sayısının bulut ortamındaki kaynaklara optimale yakın bir ¸sekilde manuel olarak da˘gıtılması hem zaman alıcı bir hale gelmekte hem de kaynakların verimli kullanımını neredeyse imkansızla¸stırmaktadır. Özellikle mikroservis tabanlı uygulamaların kaynak kullanımı ve performansı mikroservislerin mevcut kaynaklara uygun bir ¸sekilde yerle¸stirilmesine ba˘glıdır. Mikroservislerin yerle¸stirilmesi için var olan Kubernetes, Docker, Apache Mesos gibi yönetim araçları, mikroservislerin çalı¸sma zamanı verilerini dikkate almayıp minimum yetenek ile da˘gıtım yapmaktadır. Bununla birlikte literatürde mikroservisler için geli¸stirilen mevcut da˘gıtım yöntemleri üzerinden ek yakla¸sımlar kullanılarak veya araç deste˘gi geli¸stirilerek CPU i¸s yükü, G/Ç, ortalama yanıt süresi gibi kriterler açısından performans elde etmek amaçlanmaktadır. Fakat literatürde önerilen ve endüstride kullanılan mevcut da˘gıtım yöntemlerinde mikroservislerin sunuculara da˘gıtılması i¸slemi kullanıcıya bırakılmaktadır. Bu da çok sayıda servisten olu¸san bir sistemde kullanıcının i¸sini zorla¸stırmakla birlikte, kabaca bir da˘gıtım yapılmasına sebep olarak, servislerin kısıtlı kaynaklara performanslı ve verimli bir ¸sekilde da˘gıtılmasını engellemektedir. Bu tez çalı¸smasında mikroservis mimarilerinin bulut ortamında verimli kullanılabilmesi için servislerin mevcut kaynaklar üzerine uygun yerle¸stirilmesi sorunu ele alınarak servislerin bulut sunucularına otomatik yerle¸stirilmesini sa˘glayan model güdümlü mimari ile geli¸stirilen bir yakla¸sım önerilmektedir. Ayrıca bu yakla¸sımı destekleyen bir araç ailesi geli¸stirilerek mikroservislerin minimum maliyet ile da˘gıtımı gerçekle¸stirilmektedir. Mikroservislerin etkin olarak kaynaklara da˘gıtımı, bulut kaynaklarının verimli ve daha yüksek performans ile kullanımını sa˘glayacaktır. Önerilen otomatik da˘gıtım yakla¸sımının gelecekteki akademik çalı¸smalar için bir altyapı sa˘glamasının yanısıra, geli¸stirilen mikroservis da˘gıtım aracının endüstriyel uygulamalara önemli bir katkıda bulunaca˘gı öngörülmektedir.
Microservice architecture is a popular approach that relies on modular software components that are loosely coupled, operate with a single functionality that can be independently deployed and communicate with each other via a well-defined interface. Thanks to independent software components, the scalability, update and maintenance of the services are easier. However, the deployment of microservice-based applications is more complicated than monolith applications. A monolith application can be deployed at one time on a group of services behind a load balancer. In a microservice-based application consisting of different services that have more than one runtime instance of each service, thousands of services need to be configured and deployed efficiently. While an application system with a small number of microservices can be manually deployed by an expert who knows the system well, a large number of microservices are often used for the applications in practice. Efficient deployment of the increasing number of services to resources manually in the cloud environment becomes both time consuming and makes the efficient use of resources almost impossible. In particular, resource usage and performance of microservice-based applications depend on the efficient deployment of microservices to the available resources. Existing tools such as Kubernetes, Docker, Apache Mesos don't consider the runtime data of a microservices and deploy them with minimum ability. Also, in literature, it is foreseed to achieve performance in terms of criteria such as CPU workload, I/O, average response time by developing additional approaches or tool support over existing deployment tools. However, the configuration process for deploying microservices is left to a user in these methods. This situation makes it difficult for the user to work in a system consisting of many services, hence, it prevents the deployment of services to limited resources in an efficient manner. In this thesis, an approach an approach developed using model driven architecture that provides automatic deployment of services to cloud servers is proposed. Furthermore, deployment of microservices at minimum cost has been performed by developing a tool that supports this approach. The approach and the tool support have been tested using an industrial case study. By effectively deploying microservices to resources, it will be possible to use the resources of the cloud environment efficiently and with higher performance. With the proposed automated deployment approach, it is foreseed to enable an infrastructure for the future academic studies, as well as a contribution to industrial applications with the developed microservice deployment tool.