node.js_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 구현을 참조할 수 있습니다.

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제









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

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

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

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

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

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

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

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