계층 구조

계층 구조는 전체 시스템을 계층 구조로 간주하며 소프트웨어 시스템은 계층 구조의 여러 수준에서 논리 모듈 또는 하위 시스템으로 분해됩니다. 이 접근 방식은 일반적으로 네트워크 프로토콜 및 운영 체제와 같은 시스템 소프트웨어를 설계하는 데 사용됩니다.

시스템 소프트웨어 계층 설계에서 하위 수준 하위 시스템은 하위 수준의 메서드를 호출하는 인접한 상위 하위 하위 시스템에 서비스를 제공합니다. 하위 계층은 I / O 서비스, 트랜잭션, 스케줄링, 보안 서비스 등과 같은보다 구체적인 기능을 제공합니다. 중간 계층은 비즈니스 로직 및 핵심 처리 서비스와 같은 더 많은 도메인 종속 기능을 제공합니다. 그리고 상위 계층은 GUI, 쉘 프로그래밍 기능 등과 같은 사용자 인터페이스 형태로 더 추상적 인 기능을 제공합니다.

또한 네임 스페이스 계층 구조에서 .NET 클래스 라이브러리와 같은 클래스 라이브러리의 구성에도 사용됩니다. 모든 디자인 유형은이 계층 적 아키텍처를 구현할 수 있으며 종종 다른 아키텍처 스타일과 결합됩니다.

계층 적 건축 스타일은 다음과 같이 나뉩니다.

  • Main-subroutine
  • Master-slave
  • 가상 기기

메인 서브 루틴

이 스타일의 목적은 모듈을 재사용하고 개별 모듈 또는 서브 루틴을 자유롭게 개발하는 것입니다. 이 스타일에서 소프트웨어 시스템은 시스템의 원하는 기능에 따라 하향식 세분화를 사용하여 서브 루틴으로 나뉩니다.

이러한 개선은 분해 된 모듈이 배타적 인 독립 책임을 가질 수있을만큼 단순해질 때까지 수직으로 이어집니다. 기능은 상위 계층의 여러 호출자가 재사용하고 공유 할 수 있습니다.

데이터가 서브 루틴에 매개 변수로 전달되는 두 가지 방법이 있습니다.

  • Pass by Value − 서브 루틴은 과거 데이터 만 사용하며 수정할 수 없습니다.

  • Pass by Reference − 서브 루틴은 매개 변수가 참조하는 데이터의 값을 사용하고 변경합니다.

장점

  • 계층 개선을 기반으로 시스템을 분해하기 쉽습니다.

  • 객체 지향 디자인의 하위 시스템에서 사용할 수 있습니다.

단점

  • 전 세계적으로 공유되는 데이터가 포함되어있어 취약합니다.

  • 긴밀한 결합은 변화의 더 많은 파급 효과를 유발할 수 있습니다.

주인 노예

이 접근 방식은 '분할 및 정복'원칙을 적용하고 오류 계산 및 계산 정확도를 지원합니다. 시스템의 신뢰성과 내결함성을 제공하는 메인 서브 루틴 아키텍처의 수정입니다.

이 아키텍처에서 슬레이브는 마스터에게 중복 서비스를 제공하고 마스터는 특정 선택 전략에 따라 슬레이브 중에서 특정 결과를 선택합니다. 슬레이브는 서로 다른 알고리즘 및 방법 또는 완전히 다른 기능에 의해 동일한 기능 작업을 수행 할 수 있습니다. 여기에는 모든 슬레이브가 병렬로 실행될 수있는 병렬 컴퓨팅이 포함됩니다.

마스터-슬레이브 패턴의 구현은 5 단계를 따릅니다.

  • 작업 계산을 동일한 하위 작업 집합으로 나눌 수있는 방법을 지정하고 하위 작업을 처리하는 데 필요한 하위 서비스를 식별합니다.

  • 개별 하위 작업을 처리하여 얻은 결과를 사용하여 전체 서비스의 최종 결과를 계산하는 방법을 지정합니다.

  • 1 단계에서 식별 된 하위 서비스에 대한 인터페이스를 정의합니다.이 인터페이스는 슬레이브에 의해 구현되고 마스터가 개별 하위 작업의 처리를 위임하는 데 사용됩니다.

  • 이전 단계에서 개발 한 사양에 따라 슬레이브 구성 요소를 구현합니다.

  • 1 ~ 3 단계에서 개발 한 사양에 따라 마스터를 구현합니다.

응용

  • 소프트웨어의 신뢰성이 중요한 문제인 애플리케이션에 적합합니다.

  • 병렬 및 분산 컴퓨팅 영역에 널리 적용됩니다.

장점

  • 더 빠른 계산과 쉬운 확장 성.

  • 슬레이브를 복제 할 수 있으므로 견고 함을 제공합니다.

  • Slave는 의미 오류를 최소화하기 위해 다르게 구현할 수 있습니다.

단점

  • 통신 오버 헤드.

  • 모든 문제를 나눌 수있는 것은 아닙니다.

  • 구현하기 어렵고 이식성 문제.

가상 머신 아키텍처

가상 머신 아키텍처는 구현 된 하드웨어 및 / 또는 소프트웨어에 고유하지 않은 일부 기능을 가장합니다. 가상 머신은 기존 시스템을 기반으로 구축되며 가상 추상화, 속성 집합 및 작업을 제공합니다.

가상 머신 아키텍처에서 마스터는 슬레이브의 '동일한'하위 서비스를 사용하고 작업 분할, 슬레이브 호출 및 결과 결합과 같은 기능을 수행합니다. 개발자는 아직 구축되지 않은 플랫폼을 시뮬레이션 및 테스트하고 실제 시스템으로 테스트하기에는 너무 복잡하거나 비용이 많이 들거나 위험한 "재해"모드를 시뮬레이션 할 수 있습니다.

대부분의 경우 가상 머신은 실행 플랫폼에서 프로그래밍 언어 또는 애플리케이션 환경을 분리합니다. 주요 목표는portability. 가상 머신을 통한 특정 모듈의 해석은 다음과 같이 인식 될 수 있습니다.

  • 해석 엔진은 해석되는 모듈에서 명령을 선택합니다.

  • 명령에 따라 엔진은 가상 머신의 내부 상태를 업데이트하고 위의 프로세스를 반복합니다.

다음 그림은 단일 물리적 시스템의 표준 VM 인프라 아키텍처를 보여줍니다.

그만큼 hypervisor, 또한 virtual machine monitor, 호스트 OS에서 실행되며 일치하는 리소스를 각 게스트 OS에 할당합니다. 게스트가 시스템 호출을 할 때 하이퍼 바이저는이를 가로 채서 호스트 OS에서 지원하는 해당 시스템 호출로 변환합니다. 하이퍼 바이저는 CPU, 메모리, 영구 스토리지, I / O 장치 및 네트워크에 대한 각 가상 머신 액세스를 제어합니다.

응용

가상 머신 아키텍처는 다음 도메인에 적합합니다.

  • 직접적인 해결책이없는 경우 시뮬레이션이나 번역으로 문제를 해결하는 데 적합합니다.

  • 샘플 응용 프로그램에는 마이크로 프로그래밍, XML 처리, 스크립트 명령 언어 실행, 규칙 기반 시스템 실행, Smalltalk 및 Java 인터프리터 유형 프로그래밍 언어의 인터프리터가 포함됩니다.

  • 가상 머신의 일반적인 예는 인터프리터, 규칙 기반 시스템, 구문 셸 및 명령 언어 프로세서입니다.

장점

  • 휴대 성 및 기계 플랫폼 독립성.

  • 소프트웨어 개발의 단순성.

  • 프로그램을 중단하고 쿼리하는 기능을 통해 유연성을 제공합니다.

  • 재난 작업 모델을위한 시뮬레이션.

  • 런타임에 수정 사항을 도입하십시오.

단점

  • 인터프리터 특성으로 인해 인터프리터 실행이 느립니다.

  • 실행과 관련된 추가 계산으로 인해 성능 비용이 발생합니다.

레이어드 스타일

이 접근 방식에서 시스템은 계층 구조에서 여러 상위 및 하위 계층으로 분해되며 각 계층은 시스템에서 고유 한 책임을 갖습니다.

  • 각 계층은 패키지, 배포 된 구성 요소 또는 메서드 라이브러리 또는 헤더 파일 형식의 서브 루틴 그룹으로 캡슐화 된 관련 클래스 그룹으로 구성됩니다.

  • 각 계층은 그 위에있는 계층에 서비스를 제공하고 아래 계층에 대한 클라이언트 역할을합니다. 즉, 계층 i +1에 대한 요청은 계층 i의 인터페이스를 통해 계층 i에서 제공하는 서비스를 호출합니다. 작업이 완료되면 응답이 레이어 i +1로 돌아갈 수 있습니다. 그렇지 않으면 계층 i가 아래 계층 i-1에서 서비스를 계속 호출합니다.

응용

레이어드 스타일은 다음 영역에 적합합니다.

  • 계층 적으로 구성 할 수있는 고유 한 서비스 클래스를 포함하는 응용 프로그램입니다.

  • 애플리케이션 별 및 플랫폼 별 부분으로 분해 할 수있는 모든 애플리케이션.

  • 핵심 서비스, 중요 서비스 및 사용자 인터페이스 서비스 등을 명확하게 구분하는 애플리케이션

장점

  • 점진적인 추상화 수준을 기반으로 디자인합니다.

  • 한 레이어의 기능에 대한 변경 사항이 최대 두 개의 다른 레이어에 영향을 미치므로 향상된 독립성을 제공합니다.

  • 표준 인터페이스와 그 구현의 분리.

  • 시스템에서 새 구성 요소의 플러그 앤 플레이를 훨씬 쉽게 허용하는 구성 요소 기반 기술을 사용하여 구현됩니다.

  • 각 레이어는 이식성을 지원하는 독립적으로 배포 된 추상 머신이 될 수 있습니다.

  • 하향식 세분화 방식으로 작업 정의를 기반으로 시스템 분해 용이

  • 동일한 레이어의 서로 다른 구현 (동일한 인터페이스 사용)을 서로 바꿔서 사용할 수 있습니다.

단점

  • 많은 애플리케이션 또는 시스템이 계층화 된 방식으로 쉽게 구성되지 않습니다.

  • 클라이언트의 요청 또는 클라이언트에 대한 응답이 잠재적으로 여러 계층을 거쳐야하므로 런타임 성능이 저하됩니다.

  • 또한 각 계층의 데이터 마샬링 및 버퍼링에 대한 오버 헤드에 대한 성능 문제도 있습니다.

  • 계층 간 통신이 열리면 교착 상태가 발생할 수 있으며 "브리징"으로 인해 긴밀한 결합이 발생할 수 있습니다.

  • 예외 및 오류 처리는 계층화 된 아키텍처에서 문제입니다. 한 계층의 오류가 모든 호출 계층으로 확산되어야하기 때문입니다.