nodejs에서 웹소켓 통신 기능을 구현하는 방법
이 글에서는 websocket 통신 기능을 구현하기 위해 nodejs를 소켓.io와 결합하는 방법을 주로 소개하며, websocket 통신을 구현하기 위해 nodejs와 소켓.io를 결합한 관련 작업 기술을 예시로 분석합니다. 이 글의 예시를 참고하세요
nodejs와 소켓.io를 결합하여 웹소켓 통신 기능을 구현하는 방법을 설명합니다. 참고할 수 있도록 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.
프로젝트에 백그라운드 데이터의 실시간 획득이 필요한 시나리오가 있기 때문에 이전에는 http 하트비트 요청 방법이 사용되었습니다. websocket은 이 모드에 비해 성능이 크게 향상되고 실시간 성능도 향상시킬 수 있기 때문에 websocket에 대한 연구가 진행되어 왔습니다. 이는 nodejs+socket.io를 사용하여 구현됩니다.
목표 달성
원래 백그라운드 데이터 하트비트 요청 방식을 백그라운드 소켓 연결을 통한 통합 푸시 방식으로 수정했습니다. 백그라운드 데이터는 다른 프로세스에 의해 파일이나 Redis에 기록됩니다. 여기서 구현되는 것은 파일을 읽는 방법입니다.
사전 준비
nodejs 설치(생략)
서버측
새 프로젝트 디렉토리를 생성하세요. 여기는 소켓테스트입니다
sockettest 디렉토리에 들어가서 express 모듈과 소켓io 모듈을 설치하세요
npm install --save express@4.10.2 npm install --save socket.io
새 package.json 파일에 다음 내용을 작성하세요.
{ "name": "socket-test", "version": "0.0.1", "description": "my first socket.io app", "dependencies": { "express": "^4.10.2", "socket.io": "^1.7.2" } }
여기서는 사용되지 않으므로 기본 액세스 표시 페이지로 사용되는 새 index.html을 만듭니다. 내용은 임의입니다.
새로 만듭니다. Trends.js 파일을 만들고 그 안에 내용을 작성하세요. :
var app = require('express')(); var http = require('http').Server(app); var io = require('socket.io')(http); var fs = require('fs'); #默认打开文件 app.get('/', function(req, res){ res.sendfile('index.html'); }); #用于存储所有socket以广播数据 var iolist = []; #定义socket on connection(连入)事件行为 io.on('connection', function(socket){ #将连入socket加入列表 iolist.push(socket); #记录index,在disconnect(断开连接)发生时将对应的socket删除 var sockex = iolist.indexOf(socket); #定义on disconnect事件行为 socket.on('disconnect', function(){ #将断开连接的socket从广播列表里删除 iolist.splice(sockex, 1); }); }); # 数据广播进程:每1秒钟广播一次 setInterval(function() { # 如果没有正在连接的socket,直接返回; if (iolist.length <= 0) return; var trends = fs.readFileSync('./data/trends.json','utf-8');#trends数据 var coins = fs.readFileSync('./data/coins.json','utf-8');#coins数据 #向所有socket连接发送数据 for (i in iolist) { # 向客户端发送trends数据 iolist[i].emit('trends', trends); # 向客户端发送coins数据 iolist[i].emit('coins', coins); } }, 1000); # 服务器侦听在sockettest.com的3000端口上 http.listen(3000, function(){ # 输出到标准输出 console.log('listening on sockettest.com:3000'); });
새 데이터 디렉터리를 만들고, 아래에 두 개의 새 파일인 Trend와 Coin을 만들어 소켓 서버에서 읽을 데이터를 저장합니다.
새 공용 디렉터리를 만들고 그 안에 index.html이라는 새 파일을 만듭니다. 파일 내용은 다음과 같습니다.
<!--引入必要的js文件--> <script type="text/javascript" src="http://sockettest:3000/socket.io/socket.io.js"></script> <script type="text/javascript"> //新建socket var socket = io('http://sockettest.com:3000'); socketdata(socket); function socketdata() { #定义接收到coins类型数据时的行为 socket.on('coins', function(msg){ console.log(msg); } #定义接收到trends类型数据时的行为 socket.on('trends', function(msg){ console.log(msg); } } </script>
코드 배포
두 개의 index.html 파일을 만든 이유는 다음과 같습니다. 웹 프로젝트에서는 nodejs에서 제공하는 소켓 서비스를 사용합니다. 이러한 방식으로 nginx나 tomcat과 같은 다른 서버에 public/index.html을 배포한 다음 루트 디렉터리에서 소켓 서버를 시작하여 소켓 서비스를 제공할 수 있습니다.
먼저 지금 프로젝트의 루트 디렉터리에서
node ./trends.js
를 실행하고 터미널을 계속 실행한 다음 nginx에 프로젝트를 배포하고 크롬을 통해 nginx에서 제공하는 웹 서비스에 액세스하세요:
http://hostname/public/ index.html
개발자 모드를 열면 콘솔에서 매초마다 노드 서버로부터 소켓 푸시 메시지를 받는 것을 볼 수 있습니다. 데이터 디렉터리에 있는 두 파일을 수정하면 해당 파일에 기록된 데이터도 실시간으로 클라이언트에 푸시되는 것을 확인할 수 있습니다.
위 내용은 모두를 위해 제가 정리한 내용입니다. 앞으로 모든 사람에게 도움이 되기를 바랍니다.
관련 기사:
다중 페이지 스캐폴딩 재구성을 구현하기 위해 vue에서 cli를 사용하는 방법
JS에서 클릭 투 클릭 드롭다운 메뉴 콘텐츠 동기화 입력 상자 실현
위 내용은 nodejs에서 웹소켓 통신 기능을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제











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

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

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

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

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는 대규모 엔터프라이즈 애플리케이션에 적합합니다.

원제: "무선 마우스는 어떻게 무선이 되나요?" 》무선 마우스는 점차 오늘날 사무용 컴퓨터의 표준 기능이 되었습니다. 이제 더 이상 긴 코드를 끌 필요가 없습니다. 그런데 무선 마우스는 어떻게 작동하나요? 오늘은 No.1 무선 마우스의 개발 역사에 대해 알아보겠습니다. 무선 마우스가 이제 40년이 되었다는 사실을 알고 계셨나요? 1984년에 로지텍이 세계 최초의 무선 마우스를 개발했는데, 이 무선 마우스는 적외선을 신호로 사용했습니다. 캐리어는 아래 사진처럼 생겼다고 하는데 나중에 성능상의 문제로 실패했습니다. 10년 후인 1994년이 되어서야 로지텍은 마침내 27MHz에서 작동하는 무선 마우스를 성공적으로 개발했습니다. 이 27MHz 주파수는 오랫동안 무선 마우스가 되었습니다.

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

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