# 웹소켓이란? # javascript 웹소켓 개념
시작하는 말
글쓴이가 웹소켓을 처음 접하게 된 계기는 회사의 클라우드의 서버에서 단말과 연동하기 위해 사용되었기 때문이었다. 어떻게 서로 데이터를 주고받을 수 있는지 궁금했던 경험을 바탕으로 이번 포스팅에서는 양방향 통신을 지원하는 웹소켓에 대해 적어보려 한다.
웹 소켓(Web socket)이란?
Stateful protocol - HTML5 순수 웹 환경에서 연결 지향 양방향 통신을 지원하는 것이다. ( 참고로 AJax, Comet은 모두 Polling 방식이라 한다 Stateless protocol )
웹 소켓은 웹 서버와 웹 브라우저가 지속적으로 연결된 TCP라인을 통해 실시간으로 데이터를 주고 받을 수 있도록 하는 HTML5의 새로운 사양이다. 따라서 웹 소켓을 이용하면 일반적인 TCP소켓과 같이 연결지향 양방향 전이중 통신이 가능하다.
웹소켓은 크게 클라이언트와 서버로 나누어지는데 개념은 다음과 같다.
클라이언트 : 웹 소켓이 제공하는 자바스크립트 API를 이용해 서버에 연결하고 데이터를 송/수신하는 코드를 구현
서버 : 웹 소켓 프로토콜에 맞는 전용 장치 구축
1) 웹 소켓 클라이언트
서버 연결
var wSocket = new WebSocket("ws://domain/demo"); //wss 보안 통신
데이터 송신
wSocket.send("메세지");
데이터 수신
서버에서 푸시하는 데이터를 받으려면 message 이벤트를 구현
wSocket.onmessage = function(e) - e
//메세지 이벤트를 통해 수신된 데이터 조회 e.data
클라이언트 측 코드는 나름 직관적이다. 그러나 클라이언트와 통신하는 서버가 존재해야 한다. 그럼 웹 소켓 서버도 알아보자.
웹 소켓 서버
일반적인 TCP 소켓과는 다른 프로토콜로 설계된 웹 소켓. 따라서 웹 소켓 서버 사양에 맞게 구현해야 한다. ws모듈 이용 : 처음에 웹소켓이 연결될 때, wss.on('connection', callback) 함수가 실행 다양한 오픈소스가 제공되고 있다. pywebsocket, phpwebsocket, jWebSocket, web-socket-ruby 와 같은 모듈을 이용하면 쉽게 구축 가능
1) 자바로 구현된 jWebSocket의 jWebSocketClient를 받는다.
- jWebSocket 라이브러리 링크 : http://jwebsocket.org/
2) 아파치 웹서버 or 톰켓으로 구동 / 자바 가상 머신 설치이 필요하다.
- 퀵스타트 : http://code.google.com/p/jwebsocket/wiki/QuickStart를 참고 하자
서버구축은 다음 포스팅에서 직접 구축해보자.
추가로 socket.io란?
socket.io란 위에서 설명한 WebSocket과 같이 클라이언트와 서버의 양방향 통신을 가능하게 해주는 모듈.
(다양한 방식의 실시간 웹 기술을 손쉽게 사용할 수 있는 모듈 (웹 클라이언트로의 푸쉬를 지원하는 모듈)) 통신을 시작할때 가장 적절한 방법을 찾아 메세지를 보내준다.
Socket.io는 현재 바로 사용 가능.
개발자가 Socket.io로 개발을 하고 클라이언트로 푸쉬 메세지를 보내면 다양한 방법으로 내부적으로 푸쉬 메세지를 보내준다. 어느 브라우저와 상관 없이 일관적으로 통신할 수 있다.
일반 TCP Socket과의 차이점 Permalink
일반 HTTP Request를 통해 handshaking 과정을 거쳐 최초 접속이 이루어진다.
오늘 성장에 도움을 주신 개발자분들
참고문헌 : https://m.mkexdev.net/98
참고문헌 : http://www.secmem.org/blog/2019/08/17/websocket-socketio/
이미지 출처 : https://docs.microsoft.com/ko-kr/azure/application-gateway/application-gateway-websocket
감사합니다.
'개발 > javascript' 카테고리의 다른 글
ES5, ES6이란? (0) | 2021.08.20 |
---|---|
stopPropagation 간단정리? (0) | 2021.08.05 |
[javascript] Promise란? (0) | 2021.07.12 |
[javascript] 비동기란? (0) | 2021.07.08 |
Javascript Object태그란? (0) | 2021.07.03 |
댓글