일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 자바네트워크
- 유닉스
- 코틀린
- NIO
- oracle
- android
- kotlin
- JVM
- python
- 파이썬
- 소프트웨어공학
- 웹 크롤링
- 시스템
- Database
- GPT-4's answer
- spring data jpa
- 데이터베이스
- spring integration
- chatGPT's answer
- jpa
- flet
- 리눅스
- Java
- 인프라
- 고전역학
- write by chatGPT
- 자바암호
- write by GPT-4
- 역학
- 자바
- Today
- Total
기억을 지배하는 기록
Middle Ware 본문
개요
미들웨어는 한 기업에 설치된 다양한 하드웨어, 네트워크 프로토콜, 응용 프로그램, 근거리통신망 환경, PC 환경 및 운영체제의 차이를 메워주는 소프트웨어를 말한다. 즉, 복잡한 이기종 환경에서 응용 프로그램과 운영환경 간에 원만한 통신을 이룰 수 있게 해주는 소프트웨어이다. 미들웨어는 분산 컴퓨팅 환경이 보급되면서부터 등장하였다. 인터넷의 보급과 중앙에 집중된 메인프레임(mainframe) 컴퓨팅 파워를 업무의 특성에 따라 다중의 호스트(host)로 분리하고자 하는 다운사이징(downsizing) 기법, 기존에 구축된 독립적인 이기종의 시스템들을 하나의 네트워크로 연결하고자 하는 SI(system integration: 시스템통합) 기법이 등장하면서 기존의 집중식 컴퓨팅(centralized computing)은 급격히 분산 컴퓨팅(distributed computing)으로 변하였다. 분산 컴퓨팅은 초고속정보통신망 등 통신망의 구축이 확산됨에 따라 그 중요성이 부각되고 있지만, 이를 실현하기 위해서는 서로 다른 운영체제와 서버 프로그램과의 호환성뿐만 아니라 이종의 통신 프로토콜을 사용하는 네트워크 간의 접속, 네트워크 자원에 대한 접근, 그리고 시스템을 연결해 단일한 사용자 환경으로 만들어 주는 것이 필수적이다. 이처럼 분산 컴퓨팅 환경을 구현하는데 발생하는 여러 문제점들을 해결하기 위해 등장한 소프트웨어가 미들웨어(middleware)이다. TCP/IP, 데이터베이스 액세스 미들웨어, DCOM(Distributed Component Object Model: 분산컴포넌트객체기술) , CORBA(Common Object Request Broker Architecture: 코바) 등의 분산기술이 이에 해당한다.
Middle Ware의 정의
단일 또는 분산시스템 환경에서 각 어플리케이션들을 연결하고 이들이 서로 데이터를 교환할 수 있도록 하는 소프트웨어
분산 컴퓨팅 환경에서 서로 다른 기종간의 서버와 클라이언트들을 연결해주는 소프트웨어
서로 다른 하드웨어, 운영체제, 네트워크, 데이터베이스 환경에서 데이터 변환 및 클라이언트 서버간 통신부분을 담당함으로써 하드웨어나 소프트웨어에 구애 받지 않고 네트워크상에서 수월하게 데이터를 주고 받을 수 있도록 함.
분산된 어플리케이션 환경을 하나의 로컬 어플리케이션 환경처럼 운용하게 함으로서 분산 어플리케이션을 수월하게 개발, 유지보수 할 수 있도록 해줌
Middle Ware 분류
1. 기능별 분류
구분 | 내용 | 비고 |
메시지 서비스 미들웨어 | 어플리케이션 사이의 통신 메시지 전달을 수행 | RPC, ORB, OLTP(OnLine Transaction Processing) |
데이터 서비스 미들웨어 | 어플리케이션과 데이터 베이스 사이에서 데이터를 전달 | RDA(Remote Database Access), RFS(Remote File Server) |
기반 서비스 미들웨어 | 분산환경에서 기반 서비스를 제공 | Directory 서비스, Time 서비스, Security 서비스 |
2. 메시지 처리 방식별 분류
구분 | 내용 | 비고 |
Synchronous 방식 미들웨어 | 클라이언트와 서버의 어플리케이션이 동시에 수행되어 데이터와 메시지를 주고 받을 수 있게 하는 미들웨어
| 메시지 패싱, RPC, ORB, OLTP, RDA |
Asynchronous 방식 미들웨어 | 클라이언트에서 보낸 메시지는 메시지 큐에 저장되어 있다가 필요시, 또는 주기적으로 서버 어플리케이션이 기동되어 메시지를 처리할 수 있게 하는 방식 | 메시지 큐잉(MQ) |
3. 제공 유형별 분류
구분 | 내용 | 비고 |
범용 미들웨어 | 데이터베이스나 서버에 종속되지 않고 다양한 데이터베이스를 접속하거나 어플리케이션을 개발할 수 있도록 지원하는 미들웨어 | RPC : DCE RPC OLTP : Tuxedo, Topend RDA : EDA/SQL, SequeLink |
전용 미들웨어 | 업체가 자사의 데이터베이스를 연결하기 위해 제공 | 메세징 : MQ Series ORB : DSOM, DOMF RDA : SQL Net |
특수목적 미들웨어 | 업체가 자사의 데이터베이스와 타사의 데이터베이스를 연결하기 위해 제공 | RDA : Oracle의 DB2 Gateway |
Middle Ware 개념의 확장
1. 객체지향 프로토콜 지원 Middle Ware
최근 다양한 분산처리 환경에 따라 단순 통신 데이터 뿐 아니라 객체의 상태 및 속성 등을 제공하는 분산 객체 프로토콜 및 해당 프로토콜을 지원하는 제품 군 등을 포함 하여 Middle Ware로 보는 것이 일반적인 시각임
- ORB(Object Request Broker)
- Application과 Network Service(보안, 성능 모니터링, 프린트 등) 사이에서 정보를 전달
- 서비스들과 상호운영 Application들을 위한 더 넓은 아키텍처 표준들의 핵심 부분
- 서로 다른 모든 컴포넌트가 서로 통신할 수 있도록 하기 위해서 일관된 객체지향 아키텍처가 필요함
- CORBA(Common Object Request Broker Architecture), OMG(Object Management Group), EJB(Enterprise Java Bean), COM+(Component Object Model)
2. Web Application Middle Ware(WAS)
- 기업의 일반적인 Application 운영 환경은 Web 및 멀티 티어의 트랜잭션 처리를 기본으로 하고 있으며 이에 프리젠테이션 계층(웹 서버)과 데이터베이스 계층의 유기적 통신이 매우 중요함
- 데이터베이스 계층과 프리젠테이션 계층의 데이터 전달 및 부하분산 데이터베이스 연결뿐 아니라 웹 서버와 연관된 기능 등을 종합하여 서비스 해주는 Package Software
Middle Ware 도입시 고려사항
- 통합 보안 서비스 제공 여부
- 하드웨어나 데이터베이스 업체들에 대한 독립성 극대화
- 표준을 준수하는 Middle Ware 선택
- 다른 업체의 Middle Ware와 상호 운용이 가능
- 사용이 쉬워 많은 교육이 필요 없는 Middle Ware
- 운영 비용에 대한 고려
- 컴퓨팅 자원 요구 정도를 고려한 저 자원 소모 Middle Ware 선정
- 새로운 컴퓨팅 플랫폼 및 네트워크를 지원할 수 있음을 점검
- 디렉토리 서비스, X.509 인증 체계 지원 및 SSO등을 지원하여 물리적 위치에 상관없이 클라이언트나 서버에 대한 논리적 재배치가 가능해야 하는 지를 점검
- 동기식, 비동기식 고려
- 부하 분산기능 등이 적절한지 고려
- 자동 복구 및 Fail-Over 기능 등의 고 가용성 지원유무를 고려
'Infrastructure' 카테고리의 다른 글
OSGi Alliance (0) | 2018.04.18 |
---|---|
NAT [Network Address Translation] (0) | 2018.04.18 |
MEAP: Mobile Enterprise Application Platform (0) | 2018.04.18 |
M-Commerce(Mobile Commerce) (0) | 2018.04.18 |
Lx 스위치(EtherNet Switch) (0) | 2018.04.18 |