분산 아키텍처란 무엇인가요?
분산 아키텍처는 분산 컴퓨팅 기술의 응용 프로그램이자 도구입니다. 현재 성숙한 기술에는 J2EE, CORBA 및 .NET(DCOM)이 포함됩니다.
1. 분산 컴퓨팅 기술의 형성
CORBA(Common Object Request Broker Architecture)는 1992년 OMG(Open Management Group)에 의해 제안되었습니다. 당시 분산 응용 프로그램 환경은 모두 클라이언트/서버 아키텍처를 채택했으며 CORBA의 적용으로 분산 응용 소프트웨어의 개발 효율성이 크게 향상되었습니다.
당시 또 다른 분산 시스템 개발 도구는 Microsoft의 DCOM(Distributed Common Object Model)이었습니다. Windows 플랫폼에서 개발된 다양한 응용 소프트웨어 제품의 기능이 런타임 시 서로 호출할 수 있도록(예: Microsoft Word에서 Excel 파일을 직접 편집) Microsoft는 나중에 OLE(Linked and Embedded Object) 기술을 구현했습니다. COM(공통 개체 모델)에서 파생됩니다.
인터넷의 인기와 웹 서비스의 광범위한 적용으로 인해 브라우저/서버 아키텍처 모델은 점차 그 장점을 보여왔습니다. 따라서 Sun은 Java 기술을 기반으로 하는 B/S 아키텍처용 J2EE 개발 및 애플리케이션 플랫폼을 출시했으며 Microsoft도 DCOM 플랫폼을 기반으로 하는 B/S 애플리케이션용 .NET 개발 및 애플리케이션을 출시했습니다.
2. 사용되는 프로토콜
.NET에서 다루는 DCOM 기술은 네트워크 전송 계층에서 TCP/IP 프로토콜을 사용하는 CORBA와 동일하며 자체 IDL 사양도 있습니다. . 차이점은 TCP/IP 위에 CORBA는 GIOP/IIOP 프로토콜을 사용하고 모든 CORBA 서버는 IIOP와 통신하여 독립적인 통신 프로토콜을 사용하는 J2EE의 RMI를 형성한다는 점입니다. RMI/IIOP는 J2EE의 개방성을 반영합니다. DCOM에는 자체 통신 프로토콜(포트 135의 TCP 서비스)이 있지만 Microsoft는 이 프로토콜의 사양을 공개하지 않았습니다. 마찬가지로 CORBA의 IDL은 C++와 유사한 정의를 채택합니다. 공개 사양, DCOM의 IDL 파일은 텍스트 형식이지만 Microsoft는 공식적으로 사양을 발표하지 않았습니다. 사용 중인 .NET의 IDL은 개발 도구에 의해 생성됩니다.
3. 애플리케이션 환경
.NET에 대해 빌 게이츠는 이렇게 말했습니다. "간단히 말하면 .NET은 다양한 Microsoft 제품을 개발 도구 및 애플리케이션 플랫폼으로 사용합니다. XML 기반 네트워크 서비스 구현 "Microsoft 세계에서는 .NET이 강력하지만 서버 시장의 대부분을 차지하는 Unix 및 Linux와 같은 시스템에서는 .NET이 무력하다는 것도 알 수 있습니다.
따라서 J2EE는 크로스 플랫폼 장점을 보여주며 네트워크 서비스 제공자에게 우수한 프런트엔드 개발 및 애플리케이션 플랫폼을 제공합니다. 네트워크 서비스가 더욱 널리 사용되고 서비스 통합이 이루어짐에 따라 컴퓨팅 성능이 향상되었습니다. 점점 더 큰 분산 컴퓨팅 환경이 네트워크 서비스 제공자의 백엔드에 형성될 것입니다. 따라서 CORBA 모듈 구조는 네트워크 서비스의 과금 프로그램과 같은 다양한 백엔드 서비스에 더 적합하다고 볼 수 있습니다. J2EE와 CORBA 기술은 각각 웹 서비스의 푸른 하늘 아래 자신만의 바다와 땅을 가지고 있습니다. .NET 개발 플랫폼이 프런트엔드에서 사용된다면 DCOM은 백엔드의 분산 구조에서 이상적인 선택입니다.
J2EE는 순수 Java 기술입니다. 많은 테스트에서 RMI(Java) 서버의 응답 속도가 Java가 아닌 CORBA 서버의 응답 속도보다 훨씬 느린 것으로 나타났습니다.
따라서 데이터 처리 속도와 응답 시간에 대한 높은 요구 사항이 있는 일부 시스템 개발에서는 선택하기 전에 RMI 및 CORBA의 성능을 테스트하고 비교해야 합니다.
4. 응용 소프트웨어 개발 및 유지 관리
응용 소프트웨어 개발 프로세스의 관점에서 볼 때 J2EE는 설계자와 개발자 모두를 위한 표준을 지향하는 완전한 개방형 플랫폼입니다. CORBA도 표준이지만 CORBA 제품 제공자가 이 표준의 실제 실행자입니다. 애플리케이션 개발 프로그래머는 IDL 언어의 사양을 이해하고 있습니다. ORB/GIOP/IIOP의 프로토콜 세부 사항을 자세히 알아야 합니다. .NET은 Microsoft의 대표적인 네트워크 환경으로 C#, C++ 등과 같은 일련의 제품화된 개발 도구로 구현됩니다. 이러한 개발 도구는 애플리케이션 개발자를 직접 대상으로 합니다. 실제로 썬이 제공하는 J2EE 역시 개발자들이 접할 수 있는 수많은 소프트웨어 패키지(애플리케이션 API)로 구성돼 있다.
소프트웨어 개발 비용과 주기, 소프트웨어 유지 관리 측면에서 J2EE는 CORBA에 비해 위와 같은 장점을 가지고 있습니다.
5. 응용 전망
분산 컴퓨팅 기술의 아키텍처와 관련하여 어느 것이 더 낫다고 말할 수는 없으며 어느 것이 더 적합하다고만 말할 수 있습니다. 다양한 소프트웨어 프로젝트 요구 사항의 경우 특정 분석이 현명한 선택입니다.
거시 시장 관점에서 볼 때 CORBA 제품 판매는 예상대로 CORBA 제품 제공업체에 상당한 이익을 가져오지 못했으며 RMI/통합으로 인해 J2EE의 목소리도 .NET보다 높습니다. J2EE의 IIOP 및 CORBA 개발 비용 및 사용 편의성을 고려한 인터페이스 개선으로 인해 J2EE 포괄적인 개방형 환경이 사람들이 가장 먼저 고려하는 선택이 될 것입니다. 그러나 CORBA 표준의 강력한 호환성도 이를 가능하게 합니다. 대규모 시스템 개발에 더 널리 사용되는 기술입니다.