웹 프론트엔드 JS 튜토리얼 node.js_node.js의 RPC(원격 프로시저 호출) 구현 원칙 소개

node.js_node.js의 RPC(원격 프로시저 호출) 구현 원칙 소개

May 16, 2016 pm 04:29 PM
node.js rpc 원격 프로시저 호출

방금 원격 시스템의 프로그램을 로컬에서 호출할 수 있는 방법인 RPC(원격 프로시저 호출)를 접하게 되었습니다. RPC의 원리를 학습하는 데 매우 좋은 간단한 nodejs 구현을 보았습니다. nodejs light_rpc

사용 예:

코드 복사 코드는 다음과 같습니다.

//서버
var light_rpc = require('./index.js');
var 포트 = 5556;
var rpc = 새로운 light_rpc({
결합: 함수(a, b, 콜백){
         콜백(a b);
},
​ 곱하기: 함수(t, cb){
         cb(t*2);
}
}).listen(포트);

샘플 클라이언트:

코드 복사 코드는 다음과 같습니다.

//클라이언트
rpc.connect(5556, 'localhost', function(remote, conn){
Remote.combine(1, 2, 함수(res){
If(res != 3){
console.log('ERROR', res);
}
});
});

전체 과정을 간략히 설명해주세요:

1. 서버는 프로그램을 시작하고, 포트를 수신하고, 클라이언트가 호출한 기능(예: 위 예의 결합 및 곱하기)을 구현하고 이를 개체에 저장합니다.
2. 클라이언트는 프로그램을 시작하고, 서버에 연결하고, 연결이 완료된 후 설명 명령을 보내 서버에 호출에 제공할 수 있는 함수 이름을 반환하도록 요청합니다.

코드 복사 코드는 다음과 같습니다.

Connection.on('연결', function(){
연결.쓰기(명령(descrCmd));
});

3. 서버는 설명 명령을 수신하고 호출 가능한 함수 이름을 래핑하여 전송합니다("결합", "곱하기")
4. 클라이언트는 서버에서 보낸 함수 이름을 받아 자체 개체에 등록하고 각 함수 이름에 대한 메서드를 래핑하므로 이러한 함수를 로컬에서 호출할 때 실제로 서버에 요청을 보냅니다.

코드 복사 코드는 다음과 같습니다.

for(cmd.data의 var p){
remoteObj[p] = getRemoteCallFunction(p, self.callbacks, 연결);
//getRemoteCallFunction 구현은 아래와 같습니다
}

5. 클라이언트가 서버 측 함수를 호출합니다.

1) callbackId라는 수신 콜백 함수에 대한 고유 ID를 생성하고 이를 클라이언트 개체에 기록합니다.
2) 호출 함수 이름, JSON 직렬화된 매개변수 목록, callbackId

등의 데이터를 패키징하여 서버로 보냅니다.

코드 복사 코드는 다음과 같습니다.

함수 getRemoteCallFunction(cmdName, 콜백, 연결){
반환 함수(){
var id = uuid.generate();
If(인수 유형[arguments.length-1] == '함수'){
​​ 콜백[id] = 인수[arguments.length-1];
}
var args = parsArgumentsToArray.call(this, 인수);
var newCmd = command(cmdName, {id: id, args: args});
Connection.write(newCmd);
}
}

6. 서버는 위의 정보를 받아 데이터를 파싱하고 매개변수 목록을 역직렬화한 후 함수 이름과 매개변수에 따라 함수를 호출합니다.

코드 복사 코드는 다음과 같습니다.

var args = cmd.data.args;
args.push(getSendCommandBackFunction(c, cmd.data.id));
self.wrapper[cmd.command].apply({}, args);

7. 함수가 완료된 후 결과를 직렬화하고 이전에 받은 callbackId와 함께 클라이언트에 다시 보냅니다.

코드 복사 코드는 다음과 같습니다.

함수 getSendCommandBackFunction(연결, cmdId){
반환 함수(){
var innerArgs =parseArgumentsToArray.call({}, 인수);
var resultCommand = command(resultCmd, {id: cmdId, args: innerArgs});
Connection.write(resultCommand);
};
}

8. 클라이언트는 함수 연산 결과와 callbackId를 수신하고, callbackId를 기반으로 콜백 함수를 꺼내어 연산 결과를 콜백 함수에 전달하여 실행합니다.

9. 전체 프로세스가 완료되었습니다. 자세한 내용은 소스 코드를 참조하세요. https://github.com/romulka/nodejs-light_rpc

몇 가지 참고 사항:

1. 클라이언트와 서버는 전체 프로세스 동안 연결을 유지합니다. http 프로토콜과 달리 전송 및 수신 후에 연결이 끊어지기 때문에 연결을 끊는 것으로 데이터 전송 완료를 판단할 수 없습니다. 데이터 수신 완료를 판단하기 위해 클라이언트와 서버에서 보낸 데이터는 간단한 프로토콜을 따릅니다. 데이터 패킷의 길이와 데이터 앞에 구분 기호를 추가합니다. 예를 들어 구분 기호는 n: [패킷 길이]입니다. data]를 이용하여 데이터를 수신한 후 먼저 데이터 패킷의 길이를 꺼내어 수신한 누적 데이터 패킷이 이 길이 이상인지 지속적으로 판단하면 1회의 데이터 전송이 완료됩니다. 데이터 분석 및 추출을 시작합니다.

2. 이 RPC는 매개변수의 함수 유형을 고려하지 않기 때문에 간단합니다. 예를 들어 매개변수가 객체이고 이 객체 아래에 함수 멤버가 있는 경우 JSON 직렬화 중에 함수가 무시됩니다. 함수는 서버 측에서 실행될 수 없습니다.

이 문제를 해결하려면 복잡한 처리가 필요합니다.

1. 원격 엔드로 전송될 각 매개변수를 심층적으로 탐색하고, 함수 멤버를 추출하고, 이 함수에 대한 고유 ID를 생성하고, 이를 로컬 객체에 넣고, 이 함수 멤버를 이 ID 문자열로 바꾸고 식별합니다. 멤버는 실제로 함수입니다. 이런 방식으로 객체를 직렬화하여 전송할 수 있습니다.
2. 서버는 호출을 수신하고 매개변수 객체에 있는 함수를 사용하려고 할 때 이것이 클라이언트에서 처리한 함수이고 ID를 가지고 있는지 확인하여 클라이언트에 다시 보냅니다. 동일한 방법으로 자체 콜백 함수를 설정하고 ID를 클라이언트에 전달하고 클라이언트의 콜백을 기다립니다.
3. 클라이언트는 함수 ID를 수신하고, 함수 엔터티를 찾아 호출하고, 완료 후 서버에서 제공한 콜백 ID에 따라 서버로 다시 보냅니다.
4. 서버는 결과를 받아 콜백 함수를 찾아 실행을 계속하고 완료합니다.

함수의 기록 방법은 다른 방법으로 완성할 수 있습니다. 일반적인 아이디어는 함수를 직렬화할 수 있는 것으로 대체하고, 원격 측에서 호출할 때 해당 함수를 로컬에서 찾을 수 있도록 기록하는 것입니다. dnode 구현을 참조할 수 있습니다.

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Windows 11에서 원격 프로시저 호출 실패 오류를 수정하는 방법 Windows 11에서 원격 프로시저 호출 실패 오류를 수정하는 방법 Apr 14, 2023 pm 06:25 PM

많은 Windows 사용자가 자신의 컴퓨터에서 "원격 프로시저 호출 실패" 오류를 경험했습니다. 일반적으로 이 오류는 문서, 사진 및 Windows 응용프로그램을 열려고 할 때 보고됩니다. 이 오류는 네트워크의 다른 시스템에 존재하는 다른 프로그램에서 서비스를 요청하기 위한 프로토콜인 RPC(원격 프로시저 호출)와 관련이 있습니다. 따라서 PC에서 RPC가 항상 실행되고 있는 것이 중요합니다. Windows PC에서 이 RPC 호출 실패 오류의 영향을 받은 사용자입니까? 그렇다면 당신은 올바른 기사를 읽고 있는 것입니다. 이 문서에서는 컴퓨터에서 이 문제를 해결하는 데 도움이 될 수 있는 몇 가지 솔루션을 선별했습니다. 수정 1 – 특정 항목을 열도록 설정된 기본 프로그램 변경

RPC 서버 연결 불가 및 데스크탑 진입 불가 현상에 대한 해결 방법 RPC 서버 연결 불가 및 데스크탑 진입 불가 현상에 대한 해결 방법 Feb 18, 2024 am 10:34 AM

RPC 서버를 사용할 수 없고 데스크톱에서 접속할 수 없는 경우 어떻게 해야 합니까? 최근 몇 년 동안 컴퓨터와 인터넷이 우리 생활 곳곳에 침투했습니다. RPC(원격 프로시저 호출)는 중앙 집중식 컴퓨팅 및 리소스 공유를 위한 기술로서 네트워크 통신에서 중요한 역할을 합니다. 그러나 때때로 RPC 서버를 사용할 수 없어 데스크탑에 들어갈 수 없는 상황이 발생할 수 있습니다. 이 문서에서는 이 문제의 가능한 원인 중 일부를 설명하고 해결 방법을 제공합니다. 먼저 RPC 서버를 사용할 수 없는 이유를 이해해야 합니다. RPC 서버는

Node의 메모리 제어에 관한 기사 Node의 메모리 제어에 관한 기사 Apr 26, 2023 pm 05:37 PM

Non-Blocking, Event-Driven 기반으로 구축된 Node 서비스는 메모리 소모가 적다는 장점이 있으며, 대규모 네트워크 요청을 처리하는데 매우 적합합니다. 대규모 요청을 전제로 '메모리 제어'와 관련된 문제를 고려해야 합니다. 1. V8의 가비지 수집 메커니즘과 메모리 제한 Js는 가비지 수집 기계에 의해 제어됩니다.

Node V8 엔진의 메모리와 GC에 대한 자세한 그래픽 설명 Node V8 엔진의 메모리와 GC에 대한 자세한 그래픽 설명 Mar 29, 2023 pm 06:02 PM

이 기사는 NodeJS V8 엔진의 메모리 및 가비지 수집기(GC)에 대한 심층적인 이해를 제공할 것입니다. 도움이 되기를 바랍니다.

Node의 파일 모듈에 대해 자세히 이야기해 보겠습니다. Node의 파일 모듈에 대해 자세히 이야기해 보겠습니다. Apr 24, 2023 pm 05:49 PM

파일 모듈은 파일 읽기/쓰기/열기/닫기/삭제 추가 등과 같은 기본 파일 작업을 캡슐화한 것입니다. 파일 모듈의 가장 큰 특징은 모든 메소드가 **동기** 및 ** 두 가지 버전을 제공한다는 것입니다. 비동기**, sync 접미사가 있는 메서드는 모두 동기화 메서드이고, 없는 메서드는 모두 이기종 메서드입니다.

PHP 및 SOAP: 원격 프로시저 호출(RPC) 구현 방법 PHP 및 SOAP: 원격 프로시저 호출(RPC) 구현 방법 Jul 29, 2023 pm 02:45 PM

PHP 및 SOAP: 원격 프로시저 호출(RPC) 구현 방법 소개: 최근 몇 년 동안 분산 시스템이 등장하면서 원격 프로시저 호출(RPC)이 웹 개발에 널리 채택되었습니다. 이 기사에서는 PHP와 SOAP를 사용하여 RPC를 구현하는 방법을 소개하고 코드 예제를 통해 사용법을 보여줍니다. 1. 원격 프로시저 호출(RPC)이란 무엇입니까? 원격 프로시저 호출(RemoteProcedureCall, RPC)은 통신입니다.

Node의 이벤트 루프에 대해 이야기해 봅시다. Node의 이벤트 루프에 대해 이야기해 봅시다. Apr 11, 2023 pm 07:08 PM

이벤트 루프는 Node.js의 기본 부분이며 메인 스레드가 차단되지 않도록 하여 비동기 프로그래밍을 가능하게 합니다. 이벤트 루프를 이해하는 것은 효율적인 애플리케이션을 구축하는 데 중요합니다. 다음 기사는 Node.js의 이벤트 루프에 대한 심층적인 이해를 제공할 것입니다. 도움이 되기를 바랍니다!

노드의 버퍼에 대해 자세히 알아보기 노드의 버퍼에 대해 자세히 알아보기 Apr 25, 2023 pm 07:49 PM

초기에 JS는 브라우저 측에서만 실행되었습니다. 유니코드로 인코딩된 문자열은 처리하기 쉬웠지만 바이너리 및 유니코드가 아닌 인코딩된 문자열을 처리하는 것은 어려웠습니다. 그리고 바이너리는 컴퓨터의 가장 낮은 데이터 형식인 비디오/오디오/프로그램/네트워크 패키지입니다.

See all articles