KR20020054206A - 엔터프라이즈 자바빈즈 기반의 클라이언트/서버간의통신방법 - Google Patents
엔터프라이즈 자바빈즈 기반의 클라이언트/서버간의통신방법 Download PDFInfo
- Publication number
- KR20020054206A KR20020054206A KR1020000083174A KR20000083174A KR20020054206A KR 20020054206 A KR20020054206 A KR 20020054206A KR 1020000083174 A KR1020000083174 A KR 1020000083174A KR 20000083174 A KR20000083174 A KR 20000083174A KR 20020054206 A KR20020054206 A KR 20020054206A
- Authority
- KR
- South Korea
- Prior art keywords
- ejb
- client
- server
- container
- interface
- Prior art date
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L61/00—Network arrangements, protocols or services for addressing or naming
- H04L61/45—Network directories; Name-to-address mapping
- H04L61/4553—Object oriented directories, e.g. common object request broker architecture [CORBA] name server
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Stored Programmes (AREA)
Abstract
본 발명은 시스템의 컴포넌트화를 통해 표준인 OTS(Object Transaction Service)를 완벽하게 지원하는 EJB 컴포넌트 서버로 완벽한 분산 트랜잭션을 지원함으로써, EJB 컴포넌트 서버와 EJB 기반 클라이언트 사이에 통신방법을 정의하여 완벽한 분산처리방식을 지원하고 규모와 성능의 최적화에 용이하고 모듈성이 높고 유지 보수성이 뛰어나며, 멀티미디어 방식의 개발로 확장성, 성능, 안전성 등을 증가시키기 위한 엔터프라이즈 자바빈즈 기반의 클라이언트/서버간의 통신방법을 제공하기 위하여, 클라이언트가 디렉토리 서비스를 이용하여 컨테이너(서버) 객체의 이름을 찾고, JNDI(Java Naming Directory Interface) 서버를 통해 컨테이너(서버)의 위치를 파악하고 EJB 홈을 찾는 제 1 단계; 상기 클라이언트가 상기 EJB 홈을 참조하여 상기 컨테이너내에 새로운 EJB 오브젝트를 생성하고, 상기 컨테이너가 EJB 오브젝트 참조값을 상기 클라이언트로 반환하는 제 2 단계; 상기 클라이언트가 상기 EJB 오브젝트 참조값을 통해 상기 EJB 오브젝트에 대한 리모트 메소드를 호출하여 엔터프라이즈 자바빈즈와 통신하는 제 3 단계를 포함하며, EJB 기반 시스템등에 이용됨.
Description
본 발명은 엔터프라이즈 자바빈즈(Enterprise JavaBeans, 이하 EJB이라 함) 기반의 클라이언트/서버간의 통신방법과 상기 방법을 실현시키기 위한 프로그램을 기록한 컴퓨터로 읽을 수 있는 기록매체에 관한 것으로, 특히 시스템의 컴포넌트화를 통해 표준인 OTS(Object Transaction Service)를 완벽하게 지원하는 EJB 컴포넌트 서버로 완벽한 분산 트랜잭션을 지원함으로써, EJB 컴포넌트 서버와 EJB 기반 클라이언트 사이에 통신방법을 정의하여 완벽한 분산처리방식을 지원하고 규모와 성능의 최적화에 용이하고 모듈성이 높고 유지 보수성이 뛰어나며, 멀티미디어 방식의 개발로 확장성, 성능, 안전성 등을 증가시키기 위한 엔터프라이즈 자바빈즈 기반의 클라이언트/서버간의 통신방법과 상기 방법을 실현시키기 위한 프로그램을 기록한 컴퓨터로 읽을 수 있는 기록매체에 관한 것이다.
즉, 본 발명이 속하는 기술 분야는 객체지향 방법론을 적용하여 체계적으로 시스템을 개발하였고, 컴포넌트 기술로 각광받고 있는 엔터프라이즈 자바 빈즈(Enterprise JavaBeans) 기술을 적용하여 서버 프로그램을 컴포넌트화 하였으며, 또한 트랜잭션 및 메모리 관리를 자동화하기 위한 방법에 관한 기술이다.
좀 더 구체적으로 살펴보면, 본 발명은 프리젠테이션 레이어로 JSP(Java Server Page) 및 애플릿을 사용하여 웹 기반으로 전향 하였으며 엔터프라이즈 환경에서 동기 및 비동기적 메시지 전달을 JMS(Java Message Service)를 기반으로 구현한 기술이다. 전체적으로 J2EE(Java 2 Enterprise Edtion)환경으로 개발하여 시스템의 변화시 최소의 비용으로 빠른 시간에 이전이 가능해 졌다.
그러나, 종래의 기술은 구현방식에 따라 매우 다양하다.
첫 번째로, 소프트웨어 공학 영역에서 개념정의에 머물렀던 CORBA(Common Object Request Broker Architecture)/COM(Common Object Model) 관련 제품들이 출시되면서 개발자들에게 가시적으로 접근하게 되었으며 객체기반 미들웨어가 2 페이즈 커밋(Phase Commit)이라는 분산 트랜잭션 서비스를 지원하기 시작한 것이다.
MS(Microsoft) 윈도우엔티(WindowsNT)에 포함된 트랜잭션 서비스인 MTS(Microsoft Transaction Server)나 썬, 오라클이 중심이 된 마이크로소프트 진영의 EJB(Enterprise Java Beans), CORBA의 OTS(Object Transaction Service)가 바로 그것이다.
두 번째로, 오픈 플랫폼을 최대의 장점으로 내세우는 자바가 웹 브라우저상의 애플릿 수준에서 EJB의 탄생으로 기업용 대형 어플리케이션 개발에도 적용될 수 있는 환경을 마련한 것이다. 사실 자바의 안정성이나 속도면에서 기간업무에 적용할 수 있느냐라는 의구심을 가진 개발자가 많은 것도 사실이나 대부분의 웹 어플리케이션 서버 벤더들은 자바를 선택하고 있다.
세 번째로, CBD(Component Based Development) 개념의 활황인데 "마이크로소프트"사의 ADCU(Application Developers Customer Unit)전략이나 "IBM"사의 샌프란시스코 전략으로 대표되는 이 개념은 UML(Unified Modeling Language)의 사용, 룸(ROOM) 등의 객체지향 방법론의 도입을 촉구하고 있으며 객체지향기술을 근간으로 분산 어플리케이션 컴포넌트 개발, 웹으로의 이전을 장려하고 있다.
따라서, 현재의 기술분야에서는, 오브젝트 지향기술의 발전, 오브젝트 지향 언어의 활용, 네트워크 보급등에 의하여 소프트웨어의 컴포넌트화 기술이 실용화 되고 있는 정보기술 추이에 맞춰 소프트웨어의 급속한 적용 범위의 확대와 더불어 기업환경에 맞도록 적합화 (customizing)시키는 과정이 요구되며, 어플리케이션 개발의 효율 향상을 위하여 EJB(Enterprise Java Beans) 컴포넌트를 이용한 조립형 개발 방법을 제시하고, 다양한 업종별 생산형태별 비즈니스 요구사항을 수용하기 위한 EJB 컴포넌트 단위의 어플리케이션 서버 개발 방안이 필수적으로 요구되고 있다.
본 발명은, 상기한 바와 같은 요구에 부응하기 위하여 제안된 것으로, 시스템의 컴포넌트화를 통해 표준인 OTS(Object Transaction Service)를 완벽하게 지원하는 EJB 컴포넌트 서버로 완벽한 분산 트랜잭션을 지원함으로써, EJB 컴포넌트 서버와 EJB 기반 클라이언트 사이에 통신방법을 정의하여 완벽한 분산처리방식을 지원하고 규모와 성능의 최적화에 용이하고 모듈성이 높고 유지 보수성이 뛰어나며, 멀티미디어 방식의 개발로 확장성, 성능, 안전성 등을 증가시키기 위한 엔터프라이즈 자바빈즈 기반의 클라이언트/서버간의 통신방법과 상기 방법을 실현시키기 위한 프로그램을 기록한 컴퓨터로 읽을 수 있는 기록매체를 제공하는데 그 목적이 있다.
도 1 은 본 발명에 따른 엔터프라이즈 자바빈즈 기반 시스템의 구성도.
도 2 는 본 발명에 따른 엔터프라이즈 자바빈즈 기반 시스템의 상세 설명도.
도 3 은 본 발명에 따른 엔터프라이즈 자바빈즈 기반의 클라이언트/서버간의 통신방법의 일실시예 흐름도.
* 도면의 주요 부분에 대한 부호의 설명
110 : 자바빈 클라이언트111 : 텍스트 생성 및 EJB 룩업부
112 : EJB 생성부113 : EJB 파괴
114 : 메소드 호출부120 : EJB 서버
121 : EJB 컨테이너122 : EJB 클래스
123 : EJB 홈 인터페이스124 : EJB 원격 인터페이스
130 : JNDI 서버
상기 목적을 달성하기 위한 본 발명은, 엔터프라이즈 자바빈즈(EJB : Enterprise JavaBeans) 기반의 클라이언트/서버간의 통신방법에 있어서, 클라이언트가 디렉토리 서비스를 이용하여 컨테이너(서버) 객체의 이름을 찾고, JNDI(Java Naming Directory Interface) 서버를 통해 컨테이너(서버)의 위치를 파악하고 EJB 홈을 찾는 제 1 단계; 상기 클라이언트가 상기 EJB 홈을 참조하여 상기 컨테이너내에 새로운 EJB 오브젝트를 생성하고, 상기 컨테이너가 EJB 오브젝트 참조값을 상기 클라이언트로 반환하는 제 2 단계; 상기 클라이언트가 상기 EJB 오브젝트 참조값을 통해 상기 EJB 오브젝트에 대한 리모트 메소드를 호출하여 엔터프라이즈 자바빈즈와 통신하는 제 3 단계를 포함하여 이루어진 것을 특징으로 한다.
또한, 본 발명은, 프로세서를 구비한 엔터프라이즈 자바빈즈(EJB : Enterprise JavaBeans) 기반 시스템에, 클라이언트가 디렉토리 서비스를 이용하여 컨테이너(서버) 객체의 이름을 찾고, JNDI(Java Naming Directory Interface) 서버를 통해 컨테이너(서버)의 위치를 파악하고 EJB 홈을 찾는 제 1 기능; 상기 클라이언트가 상기 EJB 홈을 참조하여 상기 컨테이너내에 새로운 EJB 오브젝트를 생성하고, 상기 컨테이너가 EJB 오브젝트 참조값을 상기 클라이언트로 반환하는 제 2 기능; 상기 클라이언트가 상기 EJB 오브젝트 참조값을 통해 상기 EJB 오브젝트에 대한 리모트 메소드를 호출하여 엔터프라이즈 자바빈즈와 통신하는 제 3 기능을 실현시키기 위한 프로그램을 기록한 컴퓨터로 읽을 수 있는 기록매체를 제공한다.
본 발명은, 복수 벤더의 상호 운영 가능한 소프트웨어 오브젝트를 혼합해서조합할 수 있는 유연성과 소프트웨어 오브젝트의 집중관리, 재이용 가능한 오브젝트와 레거시(Legacy)코드의 간단한 통합에 따른 낮은 비용 및 개발 일정의 단기화, 어플리케이션의 집중적인 관리에 의한 클라이언트 시스템에 대한 소프트웨어 설치, 유지 비용 및 관리에 대한 대폭적 감소, 상호 운용성, 이식성, 오브젝트 벤더에 대한 폭 넓은 선택을 보증하고, 코바 및 IIOP(Internet Inter-ORB Protocol)등 폭 넓게 지원하기 위하여 어플리케이션 서버 분야의 핵심 컴포넌트로 활용할 수 있는 것을 특징으로 한다.
또한, 본 발명은, EJB 기술이 갖는 서버 컴포넌트 모델이며, 비즈니스 로직에 맞추어져 있고, 개발/전개가 쉽고, 이식성이 높으며, 프로토콜에 중립적이며, "자바소프트사"의 엔터프라이즈 API(Application Protocol Interface)의 일부분이기도 하다. 상기 제품의 EJB 컨테이너 갖는 많은 장점 가운데 2 가지가 있다면, 그것은 각각 컨테이너-관리 엔티티 빈과 상태유지 세션 빈이라 할 수 있다. 컨테이너-관리 엔티티 빈은 개발자에게 데이터베이스를 기반으로 하고 있는 응용프로그램에 좋은 해결책이 되는 컴포넌트 모델이고, 상태유지 세션 빈은 비활성화에 상관없이, 그리고 트랜잭션의 종료여부와 상관없이 그 상태가 계속 유지될 수 있도록 할 수 있으며, 컨테이너는 이 두 엔터프라이즈 빈(세션 빈과 엔티티빈)이 동작할 수 있는 여러 가지 서비스를 제공할 수 있는 특징이 있다.
상술한 목적, 특징들 및 장점은 첨부된 도면과 관련한 다음의 상세한 설명을 통하여 보다 분명해 질 것이다. 이하, 첨부된 도면을 참조하여 본 발명에 따른 바람직한 일실시예를 상세히 설명한다.
도 1 은 본 발명에 따른 엔터프라이즈 자바빈즈 기반 시스템의 구성도이다.
도 1에 도시된 바와 같이, 먼저 EJB 컴포넌트는 4가지 부분으로 구성되어 있다. 그것은 EJB 클래스(122)와, EJB홈 인터페이스(EJB Home Interface)(123)와, EJB 원격 인터페이스(Remote Interface)(124) 및 배치 디스크립터(Deployment Descriptor)(도면에 도시되지 않음) 등이다.
여기서, EJB 클래스(122)는 세션 빈과 엔티티 빈 두 종류 타입이 있다. 세션 빈은 상태의 유무에 따라 상태 빈즈와 무상태 빈즈로 나뉘게 되고, 엔티티 빈은 트랜잭션의 시작과 끝을 알리는 주체에 대해서 컨테이너 관리 엔티티 빈과 빈 관리 엔티티 빈으로 나뉘게 된다. 엔티티 빈은 테이블의 레코드에 해당되는 객체이며, 프라이머리 키에 대하여 자동적으로 입력, 수정, 삭제하는 코드를 생성하므로 직접 SQL(Standard Query Language)을 코딩하지 않는다. 보통 비즈니스 로직은 세션 빈에 기술하고, 데이터베이스 갱신과 같은 것은 엔티티 빈에서 처리한다.
EJB 컨테이너(121)는 비즈니스 빈이 있는 서버를 나타내는 명명된 객체를 나타낸다. 한편, 자바빈 클라이언트(110)가 디렉토리 서비스를 이용하여 컨테이너 객체의 이름을 찾게 되어 컨테이너 객체에 대한 참조를 가지게 되면 JNDI(Java Naming Directory Interface)(130)서버에 서버 명을 통하여 위치를 파악함으로써, EJB 홈을 찾는 텍스트 생성 및 EJB 룩업부(111)를 통해 EJB 홈을 참조하고, EJB 생성부(112)를 통해 컨테이너 내의 새로운 EJB 오브젝트를 생성하게 된다.
이후, 생성된 EJB 객체에 대한 리모트 메소드를 메소드 호출부(114)를 통해 호출하고, 내부에서 수행하는 EJB들에 대한 모든 종류의 권한을 유지하면서 정보에접근하게 된다.
도 2 는 본 발명에 따른 엔터프라이즈 자바빈즈 기반 시스템의 상세 설명도로서, 자바빈 클라이언트(210), EJB 컨테이너/서버(220), JNDI 서버(230)로 구성된다.
이에 따라, 본 발명에서는 EJB 컴포넌트 개발 방법을 순차적으로 도시하여 상기 도 1에서의 기능을 보다 자세하게 설명하고자 한다.
도 2에 도시된 바와 같이, EJB기반 어플리케이션 서버 모듈을 개발하기 위해서는 홈 오브젝트(221)를 참조하여 검색하고(1), 홈 오브젝트(221) 참조한 값을 돌려 주어(2) 홈 인터페이스를 정의하도록 하여 새로운 EJB 오브젝트(222)를 생성하게 된다(3).
이후, EJB 오브젝트(222)를 생성하여(4) 자바빈 클라이언트(210)로 EJB 오브젝트 참조값을 돌려준 후(5) 엔터프라이즈 자바빈(223)으로 전달한 후, 비즈니스 메소드 인보크(invoke)를 호출한다(6).
도 3 은 본 발명에 따른 엔터프라이즈 자바빈즈 기반의 클라이언트/서버간의 통신방법의 일실시예 흐름도로서, EJB에 의한 서버/클라이언트 컴포넌트 개발 과정에 대한 설명에 대한 것이다.
도 3에 도시된 바와 같이, 먼저 EJB 빈을 만들기 위해서는 디프로이먼트 디스크립터(Deployment Descriptor)를 작성하는 것이다. EJB 빈의 특성과 환경 변수가 여기에 저장되며, 디프로이먼트 디스크립터는 순차화(Serialization)를 거친 바이너리 형태이며, 이는 텍스트 형태의 디플로이먼트 디스크립터를 통하여 만드는것이 일반적이다.
첫 번째로, EJB 원격지 인터페이스를 정의한다(301).
즉, EJB는 원격지 서비스를 자바 인터페이스를 통해 선언해야 한다. 이를 위해 "java.rmi.Remote" 인터페이스를 확장하는 "java.ejb.EJBObject" 인터페이스를 확장하여야 한다. EJB가 트랜잭션이라면 CORBA 트랜잭션 객체 인터페이스를 확장해야 한다. 플래그가 비어 있는 경우 ORB가 트랜잭션 컨텍스트를 IIOP를 통해 전파한다. 마지막으로 EJB에 대해 팩토리 인터페이스를 정의해야 한다.
두 번째로, 선택적으로 CORBA IDL(Interface Definition Language)을 생성한다(302).
즉, 인터페이스를 실행하여 "RMI2IDL" 번역기를 통해 CORBA IDL을 생성한다. 그러나, 비자바 클라이언트를 지원하고 인터페이스 저장소(Interface Repository)를 채우기 위해서는 CORBA IDL을 필요로 한다.
세 번째로, 인터페이스를 컴파일한다(303). 즉, 자바 컴파일러를 이용하여 인터페이스를 컴파일해야 한다.
네 번째로, IIOP 스텁(stub)과 스켈레톤(skeleton)을 생성한다(304). ".class" 파일에 대해 "RMI2IIOP" 프리프로세서를 실행하여 원격지 클래스에 대한 클라이언트 스텁과 스켈레톤을 생성한다. 프리프로세서는 원격지 팩토리 인터페이스에 대한 스텁과 스켈레톤뿐만 아니라 필요한 헬퍼(helper) 클래스도 생성한다.
다섯 번째로, 서번트(Servant)를 구현한다(305).
즉, 외부세계에 공개하는 원격지 인터페이스를 구현하는 자바 서버 클래스를제공해야 한다. 이 클래스를 "ImpBase" 클래스에서 직접 유도하거나 "CORBA Tie" 메커니즘을 이용하여 호출을 독립된 구현 클래스에게 전달하도록 할 수 있다.
여섯 번째로, EJB 클래스를 컴파일한다(306). 즉, 서번트 클래스를 자바 컴파일러를 이용하여 컴파일 한다.
이와 같은 과정을 통해 서버에 EJB 구현을 등록한다. 즉, EJB 서번트 객체를 EJB JAR(Java ARchive)로 패키지화하고 CORBA OTM(Object Transaction Mornitor) 서버에 등록하고, EJB에 대한 팩토리 객체를 구현한다.
이어서, 일반적으로 팩토리 인터페이스를 구현하는 코드를 자동으로 생성하고, EJB 타입에 대한 팩토리 인터페이스를 정의하며, 팩토리 인터페이스에서 정의한 메소드에 대한 빈 클래스의 EJB 생성 메소드를 구현한다.
그리고나서 서버에 팩토리를 등록한다. 일반적으로 EJB에서와 동일한 JAR 팩토리 클래스를 패키지화한 후, OTM 서버에 등록한다.
한편, 클라이언트 코드를 작성한다(319). 이때, 클라이언트 코드는 적절한 CORBA 바인딩을 이용하여 EJB 클라이언트를 원하는 언어로 작성할 수 있다. EJB에 대한 참조를 명명 서비스(Naming Service)를 이용하거나 팩토리를 찾아 생성하여 얻는다. 컨테이너(또는 OTM)에게 특정 EJB 클래스를 위해 팩토리에 대한 참조를 항시 요구할 수 있고 원격지 객체에 대한 참조를 가지게 되면 프록시로서 수행하는 IIOP 스텁을 통해 메소드를 호출한 후, 자바 컴파일러를 이용하여 클라이언트 코드를 컴파일함으로써, 클라이언트를 시작한다.
상술한 바와 같은 본 발명의 방법은 프로그램으로 구현되어 컴퓨터로 읽을수 있는 기록매체(씨디롬, 램, 롬, 플로피 디스크, 하드 디스크, 광자기 디스크 등)에 저장될 수 있다.
이상에서 설명한 본 발명은 전술한 실시예 및 첨부된 도면에 의해 한정되는 것이 아니고, 본 발명의 기술적 사상을 벗어나지 않는 범위 내에서 여러 가지 치환, 변형 및 변경이 가능하다는 것이 본 발명이 속하는 기술분야에서 통상의 지식을 가진 자에게 있어 명백할 것이다.
상기한 바와 같은 본 발명은, 클라이언트/서버측 프로그램을 컴포넌트 단위로 개발함으로써, 특정 업체에 적용시 커다란 수정없이 커스터마이즈가 가능하며, 고 품질, 저 비용으로 패키지 개발이 가능하다. 또한, EJB 컴포넌트 모듈 생성 기술은 3계층 클라이언트/서버( 3-Tier Client/Server) 형을 기반으로 하고 있으므로 3 계층형이 갖는 모든 시스템에 적용할 수 있어 다음과 같은 효과를 누릴 수 있다.
첫 번째, 기존 시스템과의 연동문제는 시스템 재활용이라는 측면에서 매우 중요한 내용이다. 이미 사용중인 웹 서버, 미들웨어 등 여러 시스템이 이미 구축되어 있는 상황에 대처하기 위해 인터페이스를 컴포넌트 형태로 제공하고 있다. 기존에 설치된 웹 서버를 그대로 활용할 수 있도록 하며, EJB 컴포넌트를 통해 기존에 운영되던 미들웨어와 연동하여 사용중인 서비스 모듈을 그대로 사용할 수 있도록 하여 추가개발에 따른 비용과 시간의 낭비를 방지할 수 있도록 지원하고 있다.
두번째, 웹 기반의 애플리케이션에서 트랜잭션 처리는 매우 어렵고 복잡한처리 과정이다. 바로 애플리케이션에서 요구하는 수준의 트랜잭션을 유지하고 관리하기에 웹이 제공하는 환경은 부적합하기 때문이다. 따라서, 애플리케이션 서버의 가장 중요하고 핵심적인 기능이 바로 대용량 트랜잭션 처리라 할 수 있다.
따라서, 본 발명에서는, 대용량 트랜잭션을 처리하기 위해 OTM(Object Transaction Monitor)이라는 컨테이너가 포함된 서버 부하분산을 위한 로드 밸런싱(Load Balancing), 이기종 분산환경에서 트랜잭션의 안정성 유지를 위한 2-위상(Phase) 커밋(Commit) 기능 등을 제공함으로써, 안정적이고 신뢰성있는 대용량 트랜잭션 처리를 보장할 수 있도록 하는 효과가 있다.
Claims (3)
- 엔터프라이즈 자바빈즈(EJB : Enterprise JavaBeans) 기반의 클라이언트/서버간의 통신방법에 있어서,클라이언트가 디렉토리 서비스를 이용하여 컨테이너(서버) 객체의 이름을 찾고, JNDI(Java Naming Directory Interface) 서버를 통해 컨테이너(서버)의 위치를 파악하고 EJB 홈을 찾는 제 1 단계;상기 클라이언트가 상기 EJB 홈을 참조하여 상기 컨테이너내에 새로운 EJB 오브젝트를 생성하고, 상기 컨테이너가 EJB 오브젝트 참조값을 상기 클라이언트로 반환하는 제 2 단계;상기 클라이언트가 상기 EJB 오브젝트 참조값을 통해 상기 EJB 오브젝트에 대한 리모트 메소드를 호출하여 엔터프라이즈 자바빈즈와 통신하는 제 3 단계를 포함하는 엔터프라이즈 자바빈즈 기반의 클라이언트/서버간의 통신방법.
- 제 1 항에 있어서,상기 EJB 컨테이너는,데이터베이스 트랜잭션이나 보안문제, 데이터베이스의 커넥션 풀링(Connection Fooling), 쓰레딩(Threading)과 같은 기능을 제공하는 것을 특징으로 하는 엔터프라이즈 자바빈즈 기반의 클라이언트/서버간의 통신방법.
- 프로세서를 구비한 엔터프라이즈 자바빈즈(EJB : Enterprise JavaBeans) 기반 시스템에,클라이언트가 디렉토리 서비스를 이용하여 컨테이너(서버) 객체의 이름을 찾고, JNDI(Java Naming Directory Interface) 서버를 통해 컨테이너(서버)의 위치를 파악하고 EJB 홈을 찾는 제 1 기능;상기 클라이언트가 상기 EJB 홈을 참조하여 상기 컨테이너내에 새로운 EJB 오브젝트를 생성하고, 상기 컨테이너가 EJB 오브젝트 참조값을 상기 클라이언트로 반환하는 제 2 기능;상기 클라이언트가 상기 EJB 오브젝트 참조값을 통해 상기 EJB 오브젝트에 대한 리모트 메소드를 호출하여 엔터프라이즈 자바빈즈와 통신하는 제 3 기능을 실현시키기 위한 프로그램을 기록한 컴퓨터로 읽을 수 있는 기록매체.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR10-2000-0083174A KR100534591B1 (ko) | 2000-12-27 | 2000-12-27 | 엔터프라이즈 자바빈즈 기반의 클라이언트/서버 간의 통신방법 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR10-2000-0083174A KR100534591B1 (ko) | 2000-12-27 | 2000-12-27 | 엔터프라이즈 자바빈즈 기반의 클라이언트/서버 간의 통신방법 |
Publications (2)
Publication Number | Publication Date |
---|---|
KR20020054206A true KR20020054206A (ko) | 2002-07-06 |
KR100534591B1 KR100534591B1 (ko) | 2005-12-07 |
Family
ID=27686887
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR10-2000-0083174A KR100534591B1 (ko) | 2000-12-27 | 2000-12-27 | 엔터프라이즈 자바빈즈 기반의 클라이언트/서버 간의 통신방법 |
Country Status (1)
Country | Link |
---|---|
KR (1) | KR100534591B1 (ko) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100463837B1 (ko) * | 2002-12-10 | 2004-12-29 | 한국전자통신연구원 | 엔터프라이즈 빈 추출 장치 및 방법 |
KR100483883B1 (ko) * | 2002-05-28 | 2005-04-18 | 주식회사 이엔티미디어 | Ejb 환경에서의 서버 컴포넌트 아키텍쳐 및 아키텍쳐를생성하는 방법 |
CN103902283A (zh) * | 2014-03-03 | 2014-07-02 | 华东师范大学 | 在corba中利用模型转换实现实时异步通信的方法 |
CN110928607A (zh) * | 2019-11-21 | 2020-03-27 | 浙江大搜车软件技术有限公司 | 业务实现方法、装置、计算机设备及存储介质 |
-
2000
- 2000-12-27 KR KR10-2000-0083174A patent/KR100534591B1/ko not_active IP Right Cessation
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100483883B1 (ko) * | 2002-05-28 | 2005-04-18 | 주식회사 이엔티미디어 | Ejb 환경에서의 서버 컴포넌트 아키텍쳐 및 아키텍쳐를생성하는 방법 |
KR100463837B1 (ko) * | 2002-12-10 | 2004-12-29 | 한국전자통신연구원 | 엔터프라이즈 빈 추출 장치 및 방법 |
CN103902283A (zh) * | 2014-03-03 | 2014-07-02 | 华东师范大学 | 在corba中利用模型转换实现实时异步通信的方法 |
CN103902283B (zh) * | 2014-03-03 | 2017-04-19 | 华东师范大学 | 在corba中利用模型转换实现实时异步通信的方法 |
CN110928607A (zh) * | 2019-11-21 | 2020-03-27 | 浙江大搜车软件技术有限公司 | 业务实现方法、装置、计算机设备及存储介质 |
CN110928607B (zh) * | 2019-11-21 | 2024-05-14 | 浙江大搜车软件技术有限公司 | 业务实现方法、装置、计算机设备及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
KR100534591B1 (ko) | 2005-12-07 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
Völter et al. | Server component patterns: component infrastructures illustrated with EJB | |
Matena et al. | Applying enterprise JavaBeans: component-based development for the J2EE platform | |
DeMichiel et al. | Enterprise javabeans tm specification, version 2.0 | |
US5864866A (en) | Apparatus and method for providing externalization in an object-oriented environment | |
Lewandowski | Frameworks for component-based client/server computing | |
Kniesel | Type-safe delegation for run-time component adaptation | |
US7444433B2 (en) | Distributed computing system architecture | |
US7546606B2 (en) | System and method using a connector architecture for application integration | |
US6269373B1 (en) | Method and system for persisting beans as container-managed fields | |
US7152090B2 (en) | Metadata-aware enterprise application integration framework for application server environment | |
Merz et al. | Service trading and mediation in distributed computing systems | |
JP2004506264A (ja) | C/c++メタモデルを含む共通アプリケーション・メタモデル | |
US7577965B2 (en) | Push-based object request broker | |
JP2000515281A (ja) | インターフェイス定義言語によって定義されたインターフェイス、オペレーションおよびデータ型を記述するための方法および装置 | |
Pour | Enterprise JavaBeans, JavaBeans and XML expanding the possibilities for Web-based enterprise application development | |
Pour | COMPONENT TECHNOLOGIES | |
KR100534591B1 (ko) | 엔터프라이즈 자바빈즈 기반의 클라이언트/서버 간의 통신방법 | |
McArthur et al. | An evaluation of the impact of component-based architectures on software reusability | |
Anderson et al. | Enterprise Javabeans component architecture: Designing and coding enterprise applications | |
Kettemann et al. | Product line implementation technologies | |
Gani et al. | The object revolution. How COM technology is changing the way we do business | |
Özsu et al. | Building component database systems using CORBA | |
Pour | Component Technologies: Expanding the Possibilities for Development of Web-Based Enterprise Applications | |
Keith et al. | Pro JPA 2 | |
Hunt et al. | The EJB Architecture |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A201 | Request for examination | ||
E701 | Decision to grant or registration of patent right | ||
GRNT | Written decision to grant | ||
FPAY | Annual fee payment |
Payment date: 20081202 Year of fee payment: 4 |
|
LAPS | Lapse due to unpaid annual fee |