데이터 흐름 아키텍처

데이터 흐름 아키텍처에서 전체 소프트웨어 시스템은 데이터와 작업이 서로 독립적 인 연속적인 조각 또는 입력 데이터 집합에 대한 일련의 변환으로 간주됩니다. 이 접근 방식에서는 데이터가 시스템에 입력 된 다음 최종 대상 (출력 또는 데이터 저장소)에 할당 될 때까지 한 번에 하나씩 모듈을 통과합니다.

구성 요소 또는 모듈 간의 연결은 I / O 스트림, I / O 버퍼, 파이프 또는 기타 유형의 연결로 구현 될 수 있습니다. 데이터는주기가있는 그래프 토폴로지,주기가없는 선형 구조 또는 트리 유형 구조로 비행 할 수 있습니다.

이 접근 방식의 주요 목적은 재사용 및 수정 가능성의 품질을 달성하는 것입니다. 컴파일러 및 비즈니스 데이터 처리 응용 프로그램과 같이 순서대로 정의 된 입력 및 출력에 대해 잘 정의 된 일련의 독립적 데이터 변환 또는 계산을 포함하는 응용 프로그램에 적합합니다. 모듈 사이에는 세 가지 유형의 실행 시퀀스가 ​​있습니다.

  • 배치 순차
  • 파이프 및 필터 또는 비 순차적 파이프 라인 모드
  • 공정 제어

배치 순차

배치 순차는 데이터 변환 하위 시스템이 이전 하위 시스템이 완전히 완료된 후에 만 ​​프로세스를 시작할 수있는 고전적인 데이터 처리 모델입니다.

  • 데이터 흐름은 한 하위 시스템에서 다른 하위 시스템으로 전체 데이터 배치를 전달합니다.

  • 모듈 간의 통신은 연속적인 하위 시스템에서 제거 할 수있는 임시 중간 파일을 통해 수행됩니다.

  • 데이터가 일괄 처리되고 각 하위 시스템이 관련 입력 파일을 읽고 출력 파일을 쓰는 애플리케이션에 적용 할 수 있습니다.

  • 이 아키텍처의 일반적인 응용 프로그램에는 은행 및 유틸리티 청구와 같은 비즈니스 데이터 처리가 포함됩니다.

장점

  • 하위 시스템에 더 간단한 분할을 제공합니다.

  • 각 하위 시스템은 입력 데이터에 대해 작업하고 출력 데이터를 생성하는 독립적 인 프로그램이 될 수 있습니다.

단점

  • 높은 지연 시간과 낮은 처리량을 제공합니다.

  • 동시성 및 대화 형 인터페이스를 제공하지 않습니다.

  • 구현을 위해 외부 제어가 필요합니다.

파이프 및 필터 아키텍처

이 접근 방식은 연속적인 구성 요소에 의한 데이터의 점진적 변환에 중점을 둡니다. 이 접근 방식에서 데이터 흐름은 데이터에 의해 주도되고 전체 시스템은 데이터 소스, 필터, 파이프 및 데이터 싱크의 구성 요소로 분해됩니다.

모듈 간의 연결은 바이트, 문자 또는 기타 유형의 다른 유형이 될 수있는 선입 선출 버퍼 인 데이터 스트림입니다. 이 아키텍처의 주요 기능은 동시 및 증분 실행입니다.

필터

필터는 독립적 인 데이터 스트림 변환기 또는 스트림 변환기입니다. 입력 데이터 스트림의 데이터를 변환하고 처리 한 다음 처리 할 다음 필터를 위해 파이프를 통해 변환 된 데이터 스트림을 기록합니다. 증분 모드에서 작동하며 연결된 파이프를 통해 데이터가 도착하자마자 작동을 시작합니다. 두 가지 유형의 필터가 있습니다.active filterpassive filter.

Active filter

활성 필터를 사용하면 연결된 파이프가 데이터를 가져오고 변환 된 데이터를 내보낼 수 있습니다. 그것은 당기고 밀기위한 읽기 / 쓰기 메커니즘을 제공하는 패시브 파이프로 작동합니다. 이 모드는 UNIX 파이프 및 필터 메커니즘에서 사용됩니다.

Passive filter

패시브 필터를 사용하면 연결된 파이프가 데이터를 입력 및 추출 할 수 있습니다. 필터에서 데이터를 가져와 다음 필터로 푸시하는 활성 파이프와 함께 작동합니다. 읽기 / 쓰기 메커니즘을 제공해야합니다.

장점

  • 과도한 데이터 처리를 위해 동시성과 높은 처리량을 제공합니다.

  • 재사용 성을 제공하고 시스템 유지 관리를 단순화합니다.

  • 필터 간 수정 가능성 및 낮은 결합을 제공합니다.

  • 파이프로 연결된 두 필터 사이에 명확한 구분을 제공하여 단순성을 제공합니다.

  • 순차 및 병렬 실행을 모두 지원하여 유연성을 제공합니다.

단점

  • 동적 상호 작용에는 적합하지 않습니다.

  • ASCII 형식으로 데이터를 전송하려면 낮은 공통 분모가 필요합니다.

  • 필터 간 데이터 변환의 오버 헤드.

  • 필터가 협력하여 문제를 해결하는 방법을 제공하지 않습니다.

  • 이 아키텍처를 동적으로 구성하기가 어렵습니다.

파이프

파이프는 상태 비 저장이며 두 필터 사이에 존재하는 이진 또는 문자 스트림을 전달합니다. 한 필터에서 다른 필터로 데이터 스트림을 이동할 수 있습니다. 파이프는 약간의 컨텍스트 정보를 사용하고 인스턴스화 사이에 상태 정보를 유지하지 않습니다.

공정 제어 아키텍처

데이터가 일괄 처리 된 순차 또는 파이프 라인 스트림이 아닌 데이터 흐름 아키텍처 유형입니다. 데이터 흐름은 프로세스 실행을 제어하는 ​​변수 집합에서 비롯됩니다. 전체 시스템을 하위 시스템 또는 모듈로 분해하여 연결합니다.

하위 시스템 유형

프로세스 제어 아키텍처는 processing unit 공정 제어 변수 변경 및 controller unit 변화량을 계산합니다.

컨트롤러 장치에는 다음 요소가 있어야합니다.

  • Controlled Variable− 제어 변수는 기본 시스템에 대한 값을 제공하며 센서로 측정해야합니다. 예를 들어, 크루즈 컨트롤 시스템의 속도.

  • Input Variable− 프로세스에 대한 입력을 측정합니다. 예를 들어, 온도 제어 시스템의 환기 온도

  • Manipulated Variable − 조작 된 변수 값은 컨트롤러에 의해 조정 또는 변경됩니다.

  • Process Definition − 일부 프로세스 변수를 조작하기위한 메커니즘이 포함되어 있습니다.

  • Sensor − 제어와 관련된 공정 변수의 값을 얻고 조작 된 변수를 재 계산하기위한 피드백 참조로 사용할 수 있습니다.

  • Set Point − 제어 변수에 대한 원하는 값입니다.

  • Control Algorithm − 공정 변수를 조작하는 방법을 결정하는 데 사용됩니다.

응용 분야

프로세스 제어 아키텍처는 다음 영역에 적합합니다.

  • 프로세스 제어 변수 데이터에 의해 시스템이 조작되는 임베디드 시스템 소프트웨어 설계.

  • 주어진 참조 값에서 프로세스 출력의 지정된 속성을 유지하는 것을 목표로하는 애플리케이션.

  • 자동차 크루즈 제어 및 건물 온도 제어 시스템에 적용 가능합니다.

  • 자동차 잠금 방지 브레이크, 원자력 발전소 등을 제어하는 ​​실시간 시스템 소프트웨어