찾다
Javajava지도 시간자바 3티어 아키텍처의 원리와 기능 요약(그림)

이 글에서는 주로 Java 3-tier 아키텍처의 개념과 기능을 소개합니다. 도움이 필요한 친구들은

3-tier 아키텍처


3계층 애플리케이션(3-tier 애플리케이션) 일반적인 의미에서 3계층 아키텍처는 전체 비즈니스 애플리케이션을 다음과 같이 나눕니다.

프레젠테이션 계층(UI), 비즈니스 로직 계층(BLL), 데이터 액세스 계층(DAL). 레벨을 구분하는 목적은 "고 응집력, 저 결합도"라는 아이디어입니다.

개념소개

1. 프리젠테이션 레이어(UI): 일반 용어로 표시되는 인터페이스입니다. 사용자, 즉 사용자가 시스템을 사용할 때 보고 얻는 것입니다.

2. 비즈니스 로직 계층(BLL): 특정 문제에 대한 작업은 데이터 계층 및 데이터의 비즈니스 로직 처리에 대한 작업이라고도 할 수 있습니다. ​

3. 데이터 액세스 계층(DAL): 이 계층에서 수행되는 트랜잭션은 데이터 추가, 삭제, 수정, 검색 등을 위해 데이터베이스를 직접 운영합니다.

개요

소프트웨어 아키텍처 설계에서 계층 구조는 가장 일반적이고 중요한 구조입니다. Microsoft에서 권장하는 계층 구조는 일반적으로 아래에서 위로 데이터 액세스 계층, 비즈니스 논리 계층(도메인 계층이라고도 함), 프레젠테이션 계층의 세 가지 계층으로 나뉩니다.

3계층 구조 원칙:

3계층에서는 시스템의 주요 기능과 비즈니스 로직이 비즈니스 로직 계층에서 처리됩니다.

소위 3계층 아키텍처는 클라이언트와 데이터베이스 사이에

구성 요소 계층이라고도 하는 "중간 계층"을 추가합니다. 여기서 언급된 3계층 시스템은 단순히 3개의 물리적 계층을 의미하는 것이 아니며, 이는 3계층 아키텍처인 B/S 애플리케이션뿐만이 아닙니다. 3계층 시스템은 세 개의 계층이 하나의 시스템에 배치되어 있는 경우에도 논리적 시스템을 의미합니다.

3계층 시스템 애플리케이션은 비즈니스 규칙, 데이터 액세스, 합법성 확인 및 기타 작업을 중간 계층에 배치하여 처리합니다. 일반적으로 클라이언트는 데이터베이스와 직접 상호 작용하지 않고 COM/DCOM 통신을 통해 중간 계층과 연결을 설정한 후 중간 계층을 통해 데이터베이스와 상호 작용합니다.

각 계층의 기능

1:

데이터 데이터 액세스 계층: 주로 원시 데이터(데이터베이스 또는 텍스트 파일 등)용 ) , 원본 데이터가 아닌, 즉 데이터베이스가 아닌 데이터의 운영으로, 구체적으로 비즈니스 로직 레이어 또는 프리젠테이션 레이어에 대한 데이터 서비스를 제공합니다.

2:

비즈니스 로직 레이어. : 주로 특정 문제의 작동을 위한 것입니다. 데이터 계층의 작동 및 데이터 비즈니스 로직의 처리로 이해될 수도 있습니다. 데이터 계층이 구성 요소라면 논리 계층은 구성입니다. 이 빌딩 블록 중.

3:

프레젠테이션 레이어: 는 주로 WEB 모드를 나타내며, WINFORWEB 모드로도 표현할 수 있습니다. aspx, 로직 레이어가 상당히 강력하고 완전하다면 프리젠테이션 레이어가 어떻게 정의되고 변경되더라도 로직 레이어는 완벽하게 서비스를 제공할 수 있습니다.

구별하는 구체적인 방법

1: 데이터 데이터 액세스 계층: 주로 데이터 계층에 논리적 처리가 포함되어 있는지 여부에 따라 다릅니다.

함수는 주로 데이터 파일에 대한 다양한 작업을 완료합니다. 다른 작업에 대해서는 걱정하지 마세요.

2: 비즈니스 로직 계층: 주로 데이터 계층의 운영을 담당합니다. 즉, 일부 데이터 영역 작업을 결합합니다.

3: 프리젠테이션 계층: 주로 사용자 요청을 수락하고 데이터를 반환하여 클라이언트에 애플리케이션 액세스를 제공합니다.

프리젠테이션 레이어

는 사용자에게 가장 가까운 가장 바깥쪽 레이어(상위 레이어)에 위치합니다. 데이터를 표시하고 사용자가 입력한 데이터를 수신하는 데 사용되며 사용자에게 대화형 인터페이스를 제공합니다.

비즈니스 로직 레이어

비즈니스 로직 레이어는 의심할 여지없이 시스템 아키텍처의 핵심 가치를 반영하는 부분입니다. 주로 비즈니스 규칙의 공식화, 비즈니스 프로세스의 구현 및 비즈니스 요구와 관련된 기타 시스템 설계에 중점을 두고 있습니다. 시스템이 다루는 비즈니스 로직 계층은 도메인 계층이라고도 합니다.

예를 들어 마틴 파울러(Martin Fowler)는 "엔터프라이즈 애플리케이션 아키텍처 패턴"이라는 책에서 전체 아키텍처를 프리젠테이션 계층, 도메인 계층, 데이터 소스 계층의 세 가지 주요 계층으로 나눕니다. 도메인 중심

디자인의 선구자로서 Eric Evans는 비즈니스 로직 레이어를 보다 세부적으로 구분하여 이를 애플리케이션 레이어와 도메인 레이어로 세분화하고 레이어링을 통해 도메인 로직과 도메인 로직 솔루션을 더욱 분리했습니다.

비즈니스 로직 계층은 시스템 아키텍처에서 중요한 역할을 하며 데이터 액세스 계층과 프레젠테이션 계층 사이에 위치하며 데이터 교환에서 연결 역할을 합니다. 레이어는 약하게 결합된 구조이므로 레이어 간의 종속성은 상위 레이어에 대해 "무지"합니다.

인터페이스에 대한 디자인 아이디어를 레이어드 디자인에서 따른다면 이러한 하향 의존도 약한 의존이 되어야 합니다. 따라서 인터페이스 정의를 변경하지 않고 이상적인 계층형 아키텍처는 추출 가능성과 교체 가능성을 지원하는 "서랍" 아키텍처여야 합니다. 이로 인해 비즈니스 논리 계층의 디자인은 두 가지 다른 역할을 수행하므로 확장성을 지원하는 아키텍처에 특히 중요합니다.

데이터 액세스 계층의 경우 호출자이고 프레젠테이션 계층의 경우 호출 수신자입니다. 의존성과 의존성 사이의 관계는 비즈니스 로직 계층에서 얽혀 있습니다. 의존성 관계의 분리를 어떻게 실현할 것인지는 비즈니스 로직 구현 외에 디자이너에게 맡겨진 과제입니다.

데이터 계층

데이터 액세스 계층: 지속성 계층이라고도 하며 해당 기능은 주로 데이터베이스 액세스를 담당하며 데이터베이스 시스템, 바이너리 파일, 텍스트에 액세스할 수 있습니다. 문서 또는 XML 문서.

간단히 말하면 데이터 테이블에 Select, Insert, Up날짜, 삭제 작업을 구현하는 것입니다. ORM 요소를 추가하려는 경우 객체와 데이터 테이블 간의 핑과 객체 엔터티의 지속성이 포함됩니다.

장점 및 단점

장점

1. 개발자는 전체 구조 중 한 레이어에만 집중할 수 있습니다.

2. 원래 레이어 구현을 새로운 것으로 쉽게 교체할 수 있습니다.

3. 레이어 간의 종속성을 줄일 수 있습니다.

예. >

5. 각 레이어의 로직 재사용에 도움이 됩니다.

6. 구조가 깔끔해짐

7. 추후 유지관리시 유지관리 비용과 유지시간이 대폭 줄어듭니다

단점

1. 시스템 성능이 저하되었습니다. 이것은 자명합니다. 계층적 구조를 채택하지 않으면 많은 기업이 데이터베이스에 직접 접근해 해당 데이터를 얻을 수 있지만 이제는 중간 계층을 거쳐야 한다.

2. 계단식 수정으로 이어지는 경우도 있습니다. 이 수정은 특히 하향식 방향에 반영됩니다. 프리젠테이션 레이어에 기능을 추가해야 하는 경우 해당 디자인이 계층 구조를 따르도록 하기 위해 해당 비즈니스 로직 레이어와 데이터 액세스 레이어에 해당 코드를 추가해야 할 수도 있습니다.

3. 개발 비용 증가.

규칙

프로그램의 3계층 구조는 프로젝트가 DAL, BLL, WebUI의 세 가지 모듈로 나누어져 있다는 의미는 아닙니다. 레이어 다음 질문은 프로젝트 내부에 있습니다.

1. UILayer에는 SQL 문이나

저장 프로시저 호출이 적거나 없습니다. 데이터를 수정하려면?

2. UILayer를 제거해도 프로젝트가 인터페이스/

API 수준에서 모든 기능을 계속 제공할 수 있습니까?

3. 유사한 환경의 다른 프로젝트에 이식할 수 있습니까?

4. 세 가지 모듈을 서로 다른 서버에서 실행할 수 있습니까?

모든 대답이 '예'가 아니라면 귀하의 프로젝트는 세 가지- 3 레이어 프로그램에는 동의해야 할 몇 가지 규칙이 있습니다.

1. 가장 중요한 것은 UI 레이어는 셸로만 사용할 수 있으며 BizLogic 처리를 포함할 수 없다는 것입니다.

2. 디자인은 UI가 아닌 시작점부터 시작해야 합니다. BLL 레이어는 모든 BizLogic을 API에서

객체 지향 방식으로 구현해야 합니다. 🎜>3. 데이터 계층이 단순한 SqlHelper인지 아니면 매핑 클래스

인지 여부는 어느 정도 추상화 수준에서 시스템 독립적이어야 합니다.

4. >엔터프라이즈 서비스), 또는

원격 개체 기술과 같은 원격 개체 기술은 배포 중에 실제로 다른 서버에 배포되는지 여부에 관계없이 설계 시 최소한 이러한 고려 사항을 고려해야 합니다.

COM+(그래서 프로젝트에 3티어/다티어 디자인을 적용할지를 고려할 때 실제로 필요한지 여부를 먼저 고려해야 합니까? WebApplication을 여는 데 충분하며 전혀 할 필요가 없습니다. 매우 복잡한 Remoting,프로젝트 요구 사항WebService을 해결하기 위해 다층 구조가 사용됩니다.

MVC

의 차이점

MVC(Model-View-Controller)는 도메인 객체와 UI 프리젠테이션 레이어 객체를 구별하는 데 사용할 수 있는 디자인 패턴입니다.

또한 아키텍처 수준에서도 마찬가지입니다. 둘 다 프리젠테이션 레이어가 있다는 점이지만 차이점은 다른 두 레이어에 있습니다.

은 3티어 아키텍처에서 Controller의 개념을 정의하지 않습니다. 이것이 제가 생각하는 가장 다른 점입니다. MVC는 비즈니스 논리적 액세스를 두 계층으로 간주하지 않습니다. 이것이 3계층 아키텍처 또는 MVC를 사용하여 프로그램을 구축하는 것의 주요 차이점입니다. 물론. 3-Tier 아키텍처에서도 모델이 언급되지만, 3-Tier 아키텍처의 Model 개념은 MVC의 Model 개념과 다릅니다. "3-Tier"의 일반적인 Model 계층은 엔터티 클래스로 구성됩니다. , MVC에서는 비즈니스 로직과 액세스 데이터로 구성됩니다.

위 내용은 자바 3티어 아키텍처의 원리와 기능 요약(그림)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?Mar 17, 2025 pm 05:46 PM

이 기사에서는 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 및 Gradle을 사용하여 접근 방식과 최적화 전략을 비교합니다.

적절한 버전 및 종속성 관리로 Custom Java 라이브러리 (JAR Files)를 작성하고 사용하려면 어떻게해야합니까?적절한 버전 및 종속성 관리로 Custom Java 라이브러리 (JAR Files)를 작성하고 사용하려면 어떻게해야합니까?Mar 17, 2025 pm 05:45 PM

이 기사에서는 Maven 및 Gradle과 같은 도구를 사용하여 적절한 버전 및 종속성 관리로 사용자 정의 Java 라이브러리 (JAR Files)를 작성하고 사용하는 것에 대해 설명합니다.

카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까?카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까?Mar 17, 2025 pm 05:44 PM

이 기사는 카페인 및 구아바 캐시를 사용하여 자바에서 다단계 캐싱을 구현하여 응용 프로그램 성능을 향상시키는 것에 대해 설명합니다. 구성 및 퇴거 정책 관리 Best Pra와 함께 설정, 통합 및 성능 이점을 다룹니다.

캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?Mar 17, 2025 pm 05:43 PM

이 기사는 캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA를 사용하는 것에 대해 설명합니다. 잠재적 인 함정을 강조하면서 성능을 최적화하기위한 설정, 엔티티 매핑 및 모범 사례를 다룹니다. [159 문자]

Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?Mar 17, 2025 pm 05:35 PM

Java의 클래스 로딩에는 부트 스트랩, 확장 및 응용 프로그램 클래스 로더가있는 계층 적 시스템을 사용하여 클래스로드, 링크 및 초기화 클래스가 포함됩니다. 학부모 위임 모델은 핵심 클래스가 먼저로드되어 사용자 정의 클래스 LOA에 영향을 미치도록합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.