데이터 흐름 아키텍처
데이터 흐름 아키텍처에서 전체 소프트웨어 시스템은 데이터와 작업이 서로 독립적 인 연속적인 조각 또는 입력 데이터 집합에 대한 일련의 변환으로 간주됩니다. 이 접근 방식에서는 데이터가 시스템에 입력 된 다음 최종 대상 (출력 또는 데이터 저장소)에 할당 될 때까지 한 번에 하나씩 모듈을 통과합니다.
구성 요소 또는 모듈 간의 연결은 I / O 스트림, I / O 버퍼, 파이프 또는 기타 유형의 연결로 구현 될 수 있습니다. 데이터는주기가있는 그래프 토폴로지,주기가없는 선형 구조 또는 트리 유형 구조로 비행 할 수 있습니다.
이 접근 방식의 주요 목적은 재사용 및 수정 가능성의 품질을 달성하는 것입니다. 컴파일러 및 비즈니스 데이터 처리 응용 프로그램과 같이 순서대로 정의 된 입력 및 출력에 대해 잘 정의 된 일련의 독립적 데이터 변환 또는 계산을 포함하는 응용 프로그램에 적합합니다. 모듈 사이에는 세 가지 유형의 실행 시퀀스가 있습니다.
- 배치 순차
- 파이프 및 필터 또는 비 순차적 파이프 라인 모드
- 공정 제어
배치 순차
배치 순차는 데이터 변환 하위 시스템이 이전 하위 시스템이 완전히 완료된 후에 만 프로세스를 시작할 수있는 고전적인 데이터 처리 모델입니다.
데이터 흐름은 한 하위 시스템에서 다른 하위 시스템으로 전체 데이터 배치를 전달합니다.
모듈 간의 통신은 연속적인 하위 시스템에서 제거 할 수있는 임시 중간 파일을 통해 수행됩니다.
데이터가 일괄 처리되고 각 하위 시스템이 관련 입력 파일을 읽고 출력 파일을 쓰는 애플리케이션에 적용 할 수 있습니다.
이 아키텍처의 일반적인 응용 프로그램에는 은행 및 유틸리티 청구와 같은 비즈니스 데이터 처리가 포함됩니다.
장점
하위 시스템에 더 간단한 분할을 제공합니다.
각 하위 시스템은 입력 데이터에 대해 작업하고 출력 데이터를 생성하는 독립적 인 프로그램이 될 수 있습니다.
단점
높은 지연 시간과 낮은 처리량을 제공합니다.
동시성 및 대화 형 인터페이스를 제공하지 않습니다.
구현을 위해 외부 제어가 필요합니다.
파이프 및 필터 아키텍처
이 접근 방식은 연속적인 구성 요소에 의한 데이터의 점진적 변환에 중점을 둡니다. 이 접근 방식에서 데이터 흐름은 데이터에 의해 주도되고 전체 시스템은 데이터 소스, 필터, 파이프 및 데이터 싱크의 구성 요소로 분해됩니다.
모듈 간의 연결은 바이트, 문자 또는 기타 유형의 다른 유형이 될 수있는 선입 선출 버퍼 인 데이터 스트림입니다. 이 아키텍처의 주요 기능은 동시 및 증분 실행입니다.
필터
필터는 독립적 인 데이터 스트림 변환기 또는 스트림 변환기입니다. 입력 데이터 스트림의 데이터를 변환하고 처리 한 다음 처리 할 다음 필터를 위해 파이프를 통해 변환 된 데이터 스트림을 기록합니다. 증분 모드에서 작동하며 연결된 파이프를 통해 데이터가 도착하자마자 작동을 시작합니다. 두 가지 유형의 필터가 있습니다.active filter 과 passive filter.
Active filter
활성 필터를 사용하면 연결된 파이프가 데이터를 가져오고 변환 된 데이터를 내보낼 수 있습니다. 그것은 당기고 밀기위한 읽기 / 쓰기 메커니즘을 제공하는 패시브 파이프로 작동합니다. 이 모드는 UNIX 파이프 및 필터 메커니즘에서 사용됩니다.
Passive filter
패시브 필터를 사용하면 연결된 파이프가 데이터를 입력 및 추출 할 수 있습니다. 필터에서 데이터를 가져와 다음 필터로 푸시하는 활성 파이프와 함께 작동합니다. 읽기 / 쓰기 메커니즘을 제공해야합니다.
장점
과도한 데이터 처리를 위해 동시성과 높은 처리량을 제공합니다.
재사용 성을 제공하고 시스템 유지 관리를 단순화합니다.
필터 간 수정 가능성 및 낮은 결합을 제공합니다.
파이프로 연결된 두 필터 사이에 명확한 구분을 제공하여 단순성을 제공합니다.
순차 및 병렬 실행을 모두 지원하여 유연성을 제공합니다.
단점
동적 상호 작용에는 적합하지 않습니다.
ASCII 형식으로 데이터를 전송하려면 낮은 공통 분모가 필요합니다.
필터 간 데이터 변환의 오버 헤드.
필터가 협력하여 문제를 해결하는 방법을 제공하지 않습니다.
이 아키텍처를 동적으로 구성하기가 어렵습니다.
파이프
파이프는 상태 비 저장이며 두 필터 사이에 존재하는 이진 또는 문자 스트림을 전달합니다. 한 필터에서 다른 필터로 데이터 스트림을 이동할 수 있습니다. 파이프는 약간의 컨텍스트 정보를 사용하고 인스턴스화 사이에 상태 정보를 유지하지 않습니다.
공정 제어 아키텍처
데이터가 일괄 처리 된 순차 또는 파이프 라인 스트림이 아닌 데이터 흐름 아키텍처 유형입니다. 데이터 흐름은 프로세스 실행을 제어하는 변수 집합에서 비롯됩니다. 전체 시스템을 하위 시스템 또는 모듈로 분해하여 연결합니다.
하위 시스템 유형
프로세스 제어 아키텍처는 processing unit 공정 제어 변수 변경 및 controller unit 변화량을 계산합니다.
컨트롤러 장치에는 다음 요소가 있어야합니다.
Controlled Variable− 제어 변수는 기본 시스템에 대한 값을 제공하며 센서로 측정해야합니다. 예를 들어, 크루즈 컨트롤 시스템의 속도.
Input Variable− 프로세스에 대한 입력을 측정합니다. 예를 들어, 온도 제어 시스템의 환기 온도
Manipulated Variable − 조작 된 변수 값은 컨트롤러에 의해 조정 또는 변경됩니다.
Process Definition − 일부 프로세스 변수를 조작하기위한 메커니즘이 포함되어 있습니다.
Sensor − 제어와 관련된 공정 변수의 값을 얻고 조작 된 변수를 재 계산하기위한 피드백 참조로 사용할 수 있습니다.
Set Point − 제어 변수에 대한 원하는 값입니다.
Control Algorithm − 공정 변수를 조작하는 방법을 결정하는 데 사용됩니다.
응용 분야
프로세스 제어 아키텍처는 다음 영역에 적합합니다.
프로세스 제어 변수 데이터에 의해 시스템이 조작되는 임베디드 시스템 소프트웨어 설계.
주어진 참조 값에서 프로세스 출력의 지정된 속성을 유지하는 것을 목표로하는 애플리케이션.
자동차 크루즈 제어 및 건물 온도 제어 시스템에 적용 가능합니다.
자동차 잠금 방지 브레이크, 원자력 발전소 등을 제어하는 실시간 시스템 소프트웨어