>  기사  >  Java  >  Java RMI 원격 호출 단계 분석

Java RMI 원격 호출 단계 분석

王林
王林앞으로
2021-02-19 09:50:222049검색

Java RMI 원격 호출 단계 분석

먼저 Java RMI의 정의를 살펴보겠습니다.

RMI(Remote Method Invocation, 원격 메소드 호출)는 Java를 사용하여 JDK1.2에서 구현되며, 이는 Java의 분산 애플리케이션 개발 능력을 크게 향상시킵니다. 널리 사용되는 네트워크 개발 언어인 Java의 강력한 힘은 분산 네트워크 애플리케이션을 개발하는 강력한 능력에 반영되며 RMI는 100% 순수 Java 네트워크 분산 애플리케이션 시스템을 개발하기 위한 핵심 솔루션 중 하나입니다. 실제로 이는 RPC의 Java 버전으로 간주될 수 있습니다. 그러나 전통적인 RPC는 분산 객체 시스템에 잘 적용될 수 없습니다. Java RMI는 원격 개체 간의 원활한 원격 호출을 달성하기 위해 서로 다른 주소 공간에 저장된 프로그램 수준 개체 간의 통신을 지원합니다.

RMI 원격 호출 단계

RMI 상호 작용 다이어그램:

Java RMI 원격 호출 단계 분석

RMI는 세 부분으로 구성됩니다. 첫 번째는 rmiregistry(bin 디렉토리에서 독립적으로 실행할 수 있는 JDK에서 제공하는 프로그램)이고, 두 번째는 서버입니다. - 외부 세계에 원격 객체를 제공하는 측 프로그램이고, 세 번째는 원격 객체의 메소드를 호출하려는 클라이언트 측 프로그램입니다.
먼저 rmiregistry 서비스를 시작합니다. 시작할 때 서비스가 수신 대기하는 포트를 지정하거나 기본 포트(1099)를 사용할 수 있습니다.
둘째, 서버 측은 먼저 로컬에서 서비스를 제공하는 구현 클래스를 인스턴스화한 다음 Naming/Context/Registry(아래 예에서 사용된 레지스트리) 및 RMI에서 제공하는 다른 클래스의 바인딩 또는 리바인드 메소드를 통해 방금 인스턴스화된 구현 클래스를 등록합니다. . rmiregistry로 이동하여 이름을 외부 세계에 공개하십시오.
마지막으로 클라이언트는 로컬 인터페이스와 알려진 이름(즉, rmiregistry에 의해 노출된 이름)을 사용한 다음 Naming/Context/Registry의 조회 메서드와 RMI에서 제공하는 기타 클래스를 사용하여 RMIService에서 구현 클래스를 가져옵니다. 이렇게 하면 로컬에서는 이 클래스의 구현 클래스가 없지만 모든 메서드가 인터페이스에 있고 개체의 메서드를 원격으로 호출할 수 있습니다.

스텁과 백본 네트워크 간의 구체적인 통신 프로세스:

Java RMI 원격 호출 단계 분석

메서드 호출은 스텁, 원격 참조 계층(Remote Reference Layer) 및 전송 계층(Transport Layer)을 통해 클라이언트 개체에서 호스트로 전달됩니다. ) 그런 다음 다시 전송 계층을 거쳐 원격 호출 계층과 백본 네트워크(Skeleton)를 거쳐 서버 개체에 도달합니다.
스텁은 원격 서버 개체에 대한 프록시 역할을 하여 클라이언트가 개체를 활성화할 수 있도록 합니다.
원격 참조 계층은 의미 체계를 처리하고, 단일 또는 다중 개체의 통신을 관리하며, 호출을 하나의 서버로 보낼지 여러 서버로 보낼지 결정합니다.
전송 계층은 실제 연결을 관리하고 메서드 호출을 수락할 수 있는 원격 개체를 추적합니다.
백본 네트워크는 서버 개체에 대한 실제 메서드 호출을 완료하고 반환 값을 얻습니다.
반환 값은 원격 참조 계층과 서버 측 전송 계층을 통해 클라이언트로 다시 전달된 다음 전송 계층과 원격 호출 계층을 통해 위쪽으로 반환됩니다. 마지막으로 스텁은 반환 값을 얻습니다.

JAVA RMI 간단한 예

이 예는 서버 측 원격 객체의 덧셈과 뺄셈 메소드를 호출하는 것입니다. 구체적인 단계는 다음과 같습니다.
1. 원격 인터페이스 정의

import java.rmi.Remote;
import java.rmi.RemoteException;

/**
 * 必须继承Remote接口。
 * 所有参数和返回类型必须序列化(因为要网络传输)。
 * 任意远程对象都必须实现此接口。
 * 只有远程接口中指定的方法可以被调用。
 */
public interface IRemoteMath extends Remote {

  	// 所有方法必须抛出RemoteException
	public double add(double a, double b) throws RemoteException;
	public double subtract(double a, double b) throws RemoteException;
	
}

(동영상 공유 학습: java 영상) 튜토리얼)

2. 원격 인터페이스 클래스. 참조:

https://blog.csdn.net/xinghun_4/article/details/45787549

관련 권장 사항:

java 입문 튜토리얼

위 내용은 Java RMI 원격 호출 단계 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 csdn.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제