Skip navigation
  • Home
  • Browse
    • Communities
      & Collections
    • Browse Items by:
    • Publication Date
    • Author
    • Title
    • Subject
    • Department
  • Sign on to:
    • My MacSphere
    • Receive email
      updates
    • Edit Profile


McMaster University Home Page
  1. MacSphere
  2. Open Access Dissertations and Theses Community
  3. Open Access Dissertations and Theses
Please use this identifier to cite or link to this item: http://hdl.handle.net/11375/30255
Full metadata record
DC FieldValueLanguage
dc.contributor.advisorPaige, Richard-
dc.contributor.advisorPantelic, Vera-
dc.contributor.advisorMosser, Sebastien-
dc.contributor.authorZakerZavardehi, Hassan-
dc.date.accessioned2024-09-30T15:50:53Z-
dc.date.available2024-09-30T15:50:53Z-
dc.date.issued2024-
dc.identifier.urihttp://hdl.handle.net/11375/30255-
dc.description.abstractAs software applications grow in size and complexity, maintaining and scaling them becomes increasingly difficult. Traditional monolithic architectures, where all components are combined into a single unit, often face issues such as limited scalability, cumbersome maintenance, and problematic deployment. The microservices architecture has emerged as a solution, breaking down applications into smaller, loosely coupled services, each responsible for a specific business function. This transition process, known as migration, is challenging due to the difficulty in determining the optimal decomposition of the monolithic system. This thesis presents a novel framework designed to facilitate the migration from monolithic to microservices architecture using the Strangler Fig Pattern. Unlike existing approaches that typically attempt to decompose the monolith in a single iteration, our framework supports a gradual, iterative migration process. This allows for smoother transitions, reduced risk, and better management of complexity. Key contributions of this work include the development of a tool that leverages both static and dynamic analysis to identify microservice candidates. The tool integrates these heterogeneous data sources using the Single Source of Truth (SST) paradigm, ensuring consistency and reliability. The performance of the tool is evaluated on two well-known Java Spring projects, demonstrating its effectiveness in creating well-modularized, cohesive, and loosely coupled microservices. The results show that our approach not only meets the desired principles of microservice architectures but also compares favorably with other state-of-the-art methods. By providing a practical and systematic solution for gradual migration, this thesis addresses a significant gap in the existing literature and offers valuable insights for practitioners seeking to modernize large-scale software systems.en_US
dc.language.isoenen_US
dc.subjectMigrationen_US
dc.subjectMicroservicesen_US
dc.subjectMonolithen_US
dc.subjectDecompositionen_US
dc.titleA Semi-Automated Approach for Incremental Migration from Monolithic to Microservices Architectureen_US
dc.typeThesisen_US
dc.contributor.departmentSoftware Engineeringen_US
dc.description.degreetypeThesisen_US
dc.description.degreeMaster of Applied Science (MASc)en_US
dc.description.layabstractAs software applications grow, maintaining and updating them becomes challenging. Traditionally, software is built using a monolithic architecture, where all parts are combined into a single unit. This can lead to problems as the software gets bigger. A newer approach, called Microservice Architecture, breaks down the application into smaller, independent services, each handling a specific function. This makes the software easier to manage and scale. This thesis introduces a tool to help transition from monolithic to microservices architecture gradually, using the Strangler Fig Pattern. This approach involves incrementally creating microservices from the monolith, ensuring the system remains functional throughout the process. By combining different types of analysis, the tool accurately identifies potential microservices. It was tested on well-known projects and showed promising results in creating efficient and well-organized microservices. This work offers a practical solution for modernizing large software systems, making them easier to maintain and scale.en_US
Appears in Collections:Open Access Dissertations and Theses

Files in This Item:
File Description SizeFormat 
Hassan_zaker_thesis 1.pdf
Open Access
1.19 MBAdobe PDFView/Open
Show simple item record Statistics


Items in MacSphere are protected by copyright, with all rights reserved, unless otherwise indicated.

Sherman Centre for Digital Scholarship     McMaster University Libraries
©2022 McMaster University, 1280 Main Street West, Hamilton, Ontario L8S 4L8 | 905-525-9140 | Contact Us | Terms of Use & Privacy Policy | Feedback

Report Accessibility Issue