Maven 프로젝트의 표준 디렉터리 구조

  • 4 minutes to read

Maven은 자바 프로젝트를 관리하고 빌드하는 데 널리 사용되는 도구입니다. Maven 프로젝트에서는 코드와 리소스를 표준 디렉터리 구조에 맞춰 배치하여 프로젝트의 일관성을 유지하고 빌드 과정을 단순화할 수 있습니다. 이 문서에서는 Maven 프로젝트의 표준 디렉터리 구조에 대해 설명합니다.

디렉터리 구조

Maven 프로젝트의 표준 디렉터리 구조는 다음과 같습니다. JavaCampus 이름의 프로젝트로 가정합니다.

java-campus/
├── src/
│   ├── main/
│   │   ├── java/
│   │   ├── resources/
│   │   ├── filters/
│   │   └── webapp/
│   └── test/
│       ├── java/
│       ├── resources/
│       └── filters/
├── target/
├── pom.xml

디렉터리 구조 설명

  1. java-campus/: 프로젝트의 루트 디렉터리입니다. 프로젝트의 모든 파일과 서브 디렉터리가 여기에 위치합니다.

  2. src/: 소스 파일이 포함된 디렉터리입니다. 이 디렉터리 내에는 maintest 디렉터리가 있습니다.

    • main/: 애플리케이션의 주요 소스 코드가 들어가는 디렉터리입니다.

      • java/: 애플리케이션의 Java 소스 코드가 포함됩니다. 패키지 구조에 따라 서브 디렉터리가 생성됩니다.
      • resources/: 애플리케이션에서 사용하는 리소스 파일(예: application.properties, XML, 템플릿, 정적 파일 등)이 포함됩니다. 이 파일들은 빌드 시 클래스패스에 포함됩니다.
      • filters/: 리소스 필터링에 사용되는 파일이 포함됩니다.
      • webapp/: 웹 애플리케이션의 정적 자원과 JSP 파일, HTML, CSS, JS 등이 포함됩니다. 이 디렉터리는 WAR 패키지를 생성할 때 사용됩니다.
    • test/: 테스트 소스 파일이 포함된 디렉터리입니다.

      • java/: 테스트용 Java 소스 코드가 포함됩니다. 통상적으로 JUnit이나 TestNG와 같은 테스트 프레임워크를 사용하는 테스트 클래스가 이곳에 위치합니다.
      • resources/: 테스트에 필요한 리소스 파일이 포함됩니다. 이 파일들은 테스트 클래스패스에 포함됩니다.
      • filters/: 테스트 리소스 필터링에 사용되는 파일이 포함됩니다.
  3. target/: Maven이 빌드 과정을 통해 생성하는 출력물이 저장되는 디렉터리입니다. 이 디렉터리에는 컴파일된 클래스 파일, 패키징된 JAR 또는 WAR 파일, 생성된 문서 등이 포함됩니다. 일반적으로 이 디렉터리는 소스 컨트롤에 포함되지 않습니다.

  4. pom.xml: Maven 프로젝트 객체 모델(Project Object Model) 파일입니다. 프로젝트의 메타데이터, 의존성, 플러그인 설정 등을 정의하며, Maven 빌드 프로세스를 관리하는 데 사용됩니다.

추가 설명

  • 패키징 유형에 따른 구조: Maven 프로젝트는 JAR, WAR, EAR 등의 패키징 유형에 따라 구조가 조금씩 달라질 수 있습니다. 예를 들어, 웹 애플리케이션의 경우 src/main/webapp/ 디렉터리가 필요합니다.

  • 표준을 따르는 이유: 표준 디렉터리 구조를 따르는 것은 Maven이 프로젝트를 일관되게 빌드하고 관리할 수 있게 하며, 팀 내 협업과 프로젝트 유지보수에 도움이 됩니다. Maven은 기본적으로 이 구조를 기대하기 때문에 추가적인 설정 없이도 빌드를 쉽게 진행할 수 있습니다.

더 깊이 공부하고 싶다면
DevLec에서는 실무 중심의 C#, .NET, ASP.NET Core, Blazor, 데이터 액세스 강좌를 단계별로 제공합니다. 현재 수강 가능한 강좌 외에도 더 많은 과정이 준비되어 있습니다.
DevLec.com에서 자세한 커리큘럼을 확인해 보세요.
DevLec 공식 강의
C# Programming
C# 프로그래밍 입문
프로그래밍을 처음 시작하는 입문자를 위한 C# 기본기 완성 과정입니다.
ASP.NET Core 10.0
ASP.NET Core 10.0 시작하기 MVC Fundamentals Part 1 MVC Fundamentals Part 2
웹 애플리케이션의 구조와 MVC 패턴을 ASP.NET Core로 실습하며 익힐 수 있습니다.
Blazor Server
풀스택 웹개발자 과정 Part 1 풀스택 웹개발자 과정 Part 2 풀스택 웹개발자 과정 Part 3
실무에서 바로 활용 가능한 Blazor Server 기반 관리자·포털 프로젝트를 만들어 봅니다.
Data & APIs
Entity Framework Core 시작하기 ADO.NET Fundamentals Blazor Server Fundamentals Minimal APIs
데이터 액세스와 Web API를 함께 이해하면 실무 .NET 백엔드 개발에 큰 도움이 됩니다.
VisualAcademy Docs의 모든 콘텐츠, 이미지, 동영상의 저작권은 박용준에게 있습니다. 저작권법에 의해 보호를 받는 저작물이므로 무단 전재와 복제를 금합니다. 사이트의 콘텐츠를 복제하여 블로그, 웹사이트 등에 게시할 수 없습니다. 단, 링크와 SNS 공유, Youtube 동영상 공유는 허용합니다. www.VisualAcademy.com
박용준 강사의 모든 동영상 강의는 데브렉에서 독점으로 제공됩니다. www.devlec.com