웹 프론트엔드 JS 튜토리얼 Nodejs 미니멀리스트 입문 튜토리얼(3): Process_node.js

Nodejs 미니멀리스트 입문 튜토리얼(3): Process_node.js

May 16, 2016 pm 04:32 PM
nodejs 시작하기 튜토리얼 프로세스

Node에는 여러 스레드가 있지만 v8에서 실행되는 JavaScript는 단일 스레드입니다. Node의 child_process 모듈은 자식 프로세스를 생성하는 데 사용되며, 자식 프로세스를 통해 CPU를 최대한 활용할 수 있습니다. 예:

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

var 포크 = require('child_process').fork;
// 현재 머신의 CPU 수를 가져옵니다
var CPUs = require('os').cpus();
for (var i = 0; i // 새로운 프로세스 생성
포크('./worker.js');
}

다음은 포크를 포함한 몇 가지 프로세스 생성 방법입니다.

1.spawn(command, [args], [options]), 명령 명령을 실행하기 위해 새 프로세스를 시작합니다. args는 명령줄 매개변수입니다
2.exec(command, [options], callback), 명령 명령을 실행하기 위해 새로운 프로세스를 시작하고, 콜백은 프로세스 종료 시 표준 입력, 표준 출력 및 오류 정보를 얻기 위해 사용됩니다
3.execFile(file, [args], [options], [callback]), 실행 파일 파일을 실행하기 위해 새로운 프로세스를 시작하고, 콜백은 프로세스 종료 시 표준 입력, 표준 출력 및 오류 정보를 얻기 위해 사용됩니다
4.fork(modulePath, [args], [options])는 JavaScript 파일 모듈을 실행하기 위해 새 프로세스를 시작하며 이때 Node 하위 프로세스가 생성됩니다

노드간 프로세스 통신

상위 프로세스

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

// parent.js
var 포크 = require('child_process').fork;
// 포크는 하위 프로세스 객체 n을 반환합니다
var n = 포크('./child.js');
// 이벤트 메시지 처리
n.on('메시지', function(m) {
// 자식 프로세스가 보낸 메시지를 받습니다
console.log('메시지를 받았습니다: ' m);
});

//자식 프로세스에 메시지 보내기
n.send({hello: 'world'});

하위 프로세스

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

// child.js
// 이벤트 메시지 처리
process.on('메시지', function(m) {
console.log('메시지를 받았습니다: ' m);
});

// 상위 프로세스에 메시지를 보내는 데 사용되는 send 메소드가 프로세스에 있습니다.
process.send({foo: 'bar'});

여기서 전송 방법은 동기식이므로 많은 양의 데이터를 전송하는 것은 권장되지 않습니다(대신 파이프를 사용할 수 있습니다. 자세한 내용은 http://nodejs.org/api/를 참조하세요). 모두.html#child_process_child_process_spawn_command_args_options).
특수한 경우 메시지의 cmd 속성 값에 NODE_ 접두사가 포함된 경우(예: {cmd: 'NODE_foo'} 메시지) 이 메시지는 메시지 이벤트(그러나 InternalMessage 이벤트)에 제출되지 않습니다. Node에서 내부적으로 사용됩니다.

send 메소드의 프로토타입은 다음과 같습니다:

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

보내기(메시지, [sendHandle])

여기에서 sendHandle(handle)을 사용하여 다음을 보낼 수 있습니다.

1.net.Native, 네이티브 C TCP 소켓 또는 파이프
2.net.Server, TCP 서버
3.net.Socket, TCP 소켓
4.dgram.Native, 네이티브 C UDP 소켓
5.dgram.Socket, UDP 소켓

send가 sendHandle을 보낼 때 실제로는 JavaScript 개체를 직접 보내지 않고 보낼 수 없지만 파일 설명자를 보냅니다(결국 JSON 문자열로 전송됨). 다른 프로세스는 이 파일 설명자를 사용하여 해당 개체를 복원할 수 있습니다.

이제 예를 살펴보겠습니다.

상위 프로세스

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

// parent.js
var 포크 = require('child_process').fork;

var n = 포크('./child.js');

var 서버 = require('net').createServer();
server.listen(7000, function() {
//TCP 서버를 자식 프로세스로 보내기
n.send('서버', 서버);
}).on('연결', function() {
console.log('연결 - 상위');
});

하위 프로세스

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

process.on('메시지', function(m, h) {
If (m === '서버') {
          h.on('connection', function() {
console.log('연결 - 하위');
        });
}
});

포트 7000을 통해 이 프로그램에 액세스하면 연결 – 상위 또는 연결 – 하위가 출력될 수 있습니다. 여기서 하위 프로세스와 상위 프로세스는 동시에 포트 7000을 수신하고 있습니다. 일반적으로 동일한 포트를 수신하는 여러 프로세스는 EADDRINUSE 예외를 발생시킵니다. 이 경우 두 개의 서로 다른 프로세스가 동일한 파일 설명자를 사용하며 Node의 최하위 계층은 포트에서 수신할 때 소켓에 SO_REUSEADDR 옵션을 설정합니다. 이 소켓을 다른 프로세스에서 재사용할 수 있습니다. 여러 프로세스가 동일한 포트를 수신하는 경우 파일 설명자는 동시에 하나의 프로세스에서만 사용할 수 있으며 이러한 프로세스의 소켓 사용은 선점형입니다.

클러스터 모듈

Node v0.8에는 클러스터 모듈이 추가되었습니다. 클러스터 모듈을 통해 물리적 머신에서 동일한 포트를 수신하는 프로세스 그룹을 쉽게 구축할 수 있습니다. 예:

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

var 클러스터 = require('클러스터');
var http = require('http');
var numCPUs = require('os').cpus().length;

// 해당 프로세스가 마스터 프로세스인지 확인
if (cluster.isMaster) {
for (var i = 0; i // 새로운 작업자 프로세스 생성(마스터 프로세스만 호출 가능)
        Cluster.fork();

Cluster.on('exit', function(작업자, 코드, 신호) {
console.log('worker ' 작업자.process.pid ' 사망');
});
} 그 밖의 {
http.createServer(함수(req, res) {
           res.writeHead(200);
          res.end('hello worldn');
}).listen(8000);
}

작업자 프로세스에서 듣기 메소드를 호출하면 듣기 요청이 마스터 프로세스로 전달됩니다. 마스터 프로세스에 작업자 프로세스의 요구 사항을 충족하는 수신 서버가 이미 있는 경우 이 서버의 핸들이 작업자에게 전달됩니다. 존재하지 않는 경우 마스터 프로세스는 서버를 생성한 다음 해당 핸들을 작업자에게 전달합니다. 작업자 프로세스.

클러스터에 대한 자세한 문서: http://www.nodejs.org/api/cluster.html

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

nodejs는 백엔드 프레임워크인가요? nodejs는 백엔드 프레임워크인가요? Apr 21, 2024 am 05:09 AM

Node.js는 고성능, 확장성, 크로스 플랫폼 지원, 풍부한 생태계, 개발 용이성 등의 기능을 제공하므로 백엔드 프레임워크로 사용할 수 있습니다.

nodejs를 mysql 데이터베이스에 연결하는 방법 nodejs를 mysql 데이터베이스에 연결하는 방법 Apr 21, 2024 am 06:13 AM

MySQL 데이터베이스에 연결하려면 다음 단계를 따라야 합니다. mysql2 드라이버를 설치합니다. mysql2.createConnection()을 사용하여 호스트 주소, 포트, 사용자 이름, 비밀번호 및 데이터베이스 이름이 포함된 연결 개체를 만듭니다. 쿼리를 수행하려면 Connection.query()를 사용하세요. 마지막으로 Connection.end()를 사용하여 연결을 종료합니다.

nodejs의 전역 변수는 무엇입니까 nodejs의 전역 변수는 무엇입니까 Apr 21, 2024 am 04:54 AM

Node.js에는 다음과 같은 전역 변수가 존재합니다. 전역 개체: 전역 핵심 모듈: 프로세스, 콘솔, 필수 런타임 환경 변수: __dirname, __filename, __line, __column 상수: undefine, null, NaN, Infinity, -Infinity

nodejs 설치 디렉토리에 있는 npm과 npm.cmd 파일의 차이점은 무엇입니까? nodejs 설치 디렉토리에 있는 npm과 npm.cmd 파일의 차이점은 무엇입니까? Apr 21, 2024 am 05:18 AM

Node.js 설치 디렉터리에는 npm과 npm.cmd라는 두 가지 npm 관련 파일이 있습니다. 차이점은 다음과 같습니다. 확장자가 다릅니다. npm은 실행 파일이고 npm.cmd는 명령 창 바로 가기입니다. Windows 사용자: npm.cmd는 명령 프롬프트에서 사용할 수 있으며, npm은 명령줄에서만 실행할 수 있습니다. 호환성: npm.cmd는 Windows 시스템에만 해당되며 npm은 크로스 플랫폼에서 사용할 수 있습니다. 사용 권장사항: Windows 사용자는 npm.cmd를 사용하고, 기타 운영 체제는 npm을 사용합니다.

nodejs와 java 사이에 큰 차이가 있나요? nodejs와 java 사이에 큰 차이가 있나요? Apr 21, 2024 am 06:12 AM

Node.js와 Java의 주요 차이점은 디자인과 기능입니다. 이벤트 중심 대 스레드 중심: Node.js는 이벤트 중심이고 Java는 스레드 중심입니다. 단일 스레드 대 다중 스레드: Node.js는 단일 스레드 이벤트 루프를 사용하고 Java는 다중 스레드 아키텍처를 사용합니다. 런타임 환경: Node.js는 V8 JavaScript 엔진에서 실행되는 반면 Java는 JVM에서 실행됩니다. 구문: Node.js는 JavaScript 구문을 사용하고 Java는 Java 구문을 사용합니다. 목적: Node.js는 I/O 집약적인 작업에 적합한 반면, Java는 대규모 엔터프라이즈 애플리케이션에 적합합니다.

nodejs는 백엔드 개발 언어인가요? nodejs는 백엔드 개발 언어인가요? Apr 21, 2024 am 05:09 AM

예, Node.js는 백엔드 개발 언어입니다. 서버 측 비즈니스 로직 처리, 데이터베이스 연결 관리, API 제공 등 백엔드 개발에 사용됩니다.

nodejs 프로젝트를 서버에 배포하는 방법 nodejs 프로젝트를 서버에 배포하는 방법 Apr 21, 2024 am 04:40 AM

Node.js 프로젝트의 서버 배포 단계: 배포 환경 준비: 서버 액세스 권한 획득, Node.js 설치, Git 저장소 설정. 애플리케이션 빌드: npm run build를 사용하여 배포 가능한 코드와 종속성을 생성합니다. Git 또는 파일 전송 프로토콜을 통해 서버에 코드를 업로드합니다. 종속성 설치: SSH를 서버에 연결하고 npm install을 사용하여 애플리케이션 종속성을 설치합니다. 애플리케이션 시작: node index.js와 같은 명령을 사용하여 애플리케이션을 시작하거나 pm2와 같은 프로세스 관리자를 사용합니다. 역방향 프록시 구성(선택 사항): Nginx 또는 Apache와 같은 역방향 프록시를 사용하여 트래픽을 애플리케이션으로 라우팅합니다.

nodejs와 java 중 어느 것을 선택해야 합니까? nodejs와 java 중 어느 것을 선택해야 합니까? Apr 21, 2024 am 04:40 AM

Node.js와 Java는 각각 웹 개발에 장단점이 있으며 선택은 프로젝트 요구 사항에 따라 다릅니다. Node.js는 실시간 애플리케이션, 신속한 개발 및 마이크로서비스 아키텍처에 탁월한 반면, Java는 엔터프라이즈급 지원, 성능 및 보안에 탁월합니다.

See all articles