RPC와 웹 서비스의 차이점

Anonim

RPC vs Web Service

SOAP 프로토콜을 사용하여 웹 서비스를 생성하려면 두 가지 대안 중 하나를 사용해야합니다. 하나는 Document SOAP 프로토콜 또는 RPC SOAP 메시징 프로토콜을 따를 수 있습니다. RPC는 원격 프로 시저 호출을 나타내며 다른 원격 컴퓨터에있는 다른 프로그램에서 특정 서비스를 요청하기 위해 해당 프로그램에서 사용할 수있는 프로토콜입니다. RPC를 사용할 때 프로그램의 네트워크 세부 정보를 알 필요가 없습니다. 주어진 프로 시저 호출은 서브 루틴 호출 또는 함수 호출이라고합니다.

RPC를 사용하면 클라이언트 / 서버 모델을 많이 사용하게됩니다. 수행 할 서비스를 요청하는 프로그램은 클라이언트 측에 있고 주어진 프로그램의 실행을 제공하는 컴퓨터는 서버 측에 있다고합니다. RPC 작업은 원격 프로 시저의 결과가 제공 될 때까지 일시 중단 된 지정된 작업을 갖는 작업을 요청하는 프로그램을 필요로한다는 점에서 동기식이라고 할 수 있습니다.

보류중인 다른 동작이있을 때 장치가 너무 오래 걸리지 않도록 RPC는 주어진 주소를 공유하는 여러 스레드를 처리 할 수있게하여 응답이 올 때 제공 될 수 있습니다, 다음 행동을 시작하기 위해 하나의 행동이 완료되어야하는 일련의 활동이 아닙니다.

SOAP 컨트롤을 사용하여 생성 된 웹 서비스는 RPC 또는 문서 메시징 스타일을 따를 수 있습니다. 따라서 문서 스타일은 특정을 나타낼 수 있습니다. 지정된 XML 스키마에 대해 유효성을 검사 할 수있는 XML 문서입니다. Java RPC는 EJB와 같은 플랫폼의 통신에 사용되므로 Java에서 실행되는 유사한 응용 프로그램입니다. 반면에 웹 서비스는 Java에서 실행되지 않고 웹 서비스에 연결하려는 앱을 사용할 때마다 주로 사용됩니다.

RPC와 웹 서비스 간의 성능은 매우 다르다. 웹 서비스와 RPC 사이의 엄청난 차이가 상당히 가변적이다. 어떤 경우에는, 탄력성을 고려하여 변형이 아주 작을 수 있습니다. RPC는 혼잡 한 서버 환경을 가지고 있기 때문에 여러 클라이언트에서 작업하기가 어렵습니다.

한편, 웹 서비스는 HTTP를 통해 웹 서비스가 호출되는 것만으로도 여러 가지 서비스 배포가 가능합니다. 이를 통해 대규모 사이트에서 사용되는 일반적인 네트워크 스프레이 및 라우팅 기술을 활용할 수 있습니다. 또한 웹 서비스는 서버 또는 클라이언트와 함께 작동하기 위해 특별한 코딩을 필요로하지 않는다는 점에 유의해야합니다. RPC와 웹 서비스의 탄력성을 동일하게 비교할 수는 있지만 RPC에서는 중개자를 사용하여 예상대로 작동해야합니다.EE EJB와 Spring과 같은 프레임 워크가 등장했습니다. 최상의 서비스를 위해 RPC 환경을 가져 오기 전에 먼저 Java EE EJB로 작업하는 것이 좋습니다. 이 환경과 RPC에 대한 웹 서비스 노출은 구성을 훨씬 쉽게 만듭니다.

요약

RPC는 원격 프로 시저 호출을 나타냅니다.

클라이언트 / 서버 모델을 많이 사용하는 경우 RPC를 사용하는 것이 좋습니다.

RPC는 주어진 주소를 공유하는 여러 스레드를 처리 할 수있게합니다.

EJB를 사용하는 플랫폼에서 사용되는 RPC.

앱이 액세스를 원할 때 Java가 아닌 플랫폼에서 사용되는 웹 서비스.

웹 서비스는 비동기 통신의 동기화에도 사용됩니다.