Patterns of multi-container composition for service orchestration with Docker Compose


연구 분야: Software Development



학회: Empirical Software Engineering


초록

Software design patterns present general code solutions to common software design problems. Modern software systems rely heavily on containers for running their constituent service components. Yet, despite the prevalence of ready-to-use Docker service images ready to participate in multi-container service compositions of applications, developers do not have much guidance on how to compose their own Docker service orchestrations. Thus in this work, we curate a dataset of successful projects that employ Docker Compose as an orchestration tool to run multiple service containers; then, we engage in qualitative and quantitative analysis of Docker Compose configurations. The collection of data and analysis enables the identification and naming of repeating multi-container composition patterns that are used in numerous successful open-source projects, much like software design patterns. These patterns highlight how software systems are orchestrated in the real-world and can give examples to anybody wishing to compose their own service orchestrations. These contributions also advance empirical research in software engineering patterns as evidence is provided about how Docker Compose is used.


Author Profile
Kalvin Eng

University of Alberta Edmonton Alberta Canada

Canada
Author Profile
Abram Hindle

University of Alberta Edmonton Alberta Canada

Canada
Author Profile
Eleni Stroulia

University of Alberta Edmonton Alberta Canada

Canada

📄 논문 정보

발행 연도 2024년
인용수 3
출판 국가 Canada
사이트 Springer
좋아요 수 0

연관 논문 목록 (328건)