웹소켓(WebSocket)
하나의 TCP 접속에 전이중 통신 채널을 제공하는 컴퓨터 통신 프로토콜이다. 웹소켓 프로토콜은 2011년 IETF에 의해 RFC 6455로 표준화되었으며 웹 IDL의 웹소켓 API는 W3C에 의해 표준화되고 있다.
웹소켓은 HTTP와 구분된다. 두 프로토콜은 모두 OSI 모델의 제 7계층에 위치해 있으며 제 4계층의 TCP에 의존한다. 이들에 차이가 있으나 "RFC 6455"에 따르면 웹소켓은 HTTP 포트 80과 443 위에 동작하도록 설계되었으며 HTTP 프록시 및 중간 층을 지원하도록 설계되었으므로 HTTP 프로토콜과 호환이 된다. 호환을 달성하기 위해 웹소켓 핸드셰이크는 HTTP 업그레이드 헤더를 사용하여 HTTP 프로토콜에서 웹소켓 프로토콜로 변경한다.
웹소켓 프로토콜은 HTTP 풀링과 같은 반이중방식에 비해 더 낮은 부하를 사용하여 웹 브라우저(또는 다른 클라이언트 애플리케이션)과 웹 서버 간의 통신을 가능케 하며, 서버와의 실시간 데이터 전송을 용이케 한다. 이는 먼저 클라이언트에 의해 요청을 받는 방식이 아닌, 서버가 내용을 클라이언트에 보내는 표준화된 방식을 제공함으로써, 또 연결이 유지된 상태에서 메시지들을 오갈 수 있게 허용함으로써 가능하게 되었다. 이러한 방식으로 양방향 대화 방식은 클라이언트와 서버 간에 발생할 수 있다. 통신은 TCP 포트 80(TLS 암호화 연결의 경우 443)를 통해 수행되며 방화벽을 통해 웹이 아닌 인터넷 연결을 차단하는 일부 환경에 도움이 된다. 단순 양방향 브라우저-서버 통신은 코멧 등의 스톱갭(stopgap) 기술을 사용하는 비표준 방식으로 수행된다.
Google Chrome, MicroSoft edge, Internet Explorer, FireFox, Safari, opera 등 대부분의 브라우저가 이 프로토콜을 지원한다.
요약
HTTP와 달리 웹소켓은 전이중 통신을 사용한다. 또, 웹소켓은 TCP 위에서 메시지 스트리밍을 가능케 한다. TCP 단독으로는 메시지의 상속 개념 없이 바이트 스트림을 다룬다. 웹소켓 이전에는 포트 80 전이중 통신은 코멧 채널을 사용하여 수행이 가능했다. 그러나 코멧 구현체는 간단한 것이 아니었으며, TCP 핸드세이크와 HTTP 헤더 부하로 인해 작은 메시지에는 비효율적이다. 웹소켓 프로토콜은 웹의 보안 문제를 타협하지 않고 이 문제를 해결하는 것을 목적으로 한다.
웹소켓 프로토콜 사양은 2개의 새로운 통합 지원 식별자(URI) 스킴으로 WS(WebSocket), WSS(WebSocket Secure)를 정의하며 이들은 암호화되지 않은 연결과 암호화된 연결에 각각 사용된다.
출처 : ko.wikipedia.org/wiki/%EC%9B%B9%EC%86%8C%EC%BC%93
'Programming > Java' 카테고리의 다른 글
[Java] 강한 결합 vs 약한 결합(의존성 주입) (1) | 2024.10.14 |
---|---|
[Java] 자바빈(JavaBean) 란? (0) | 2020.04.21 |
[Java] String -> int, int ->String 변환 (0) | 2019.04.30 |
[Java] Class파일 Java 변환/디컴파일 (0) | 2019.03.21 |
[Java] String - 문자열<->배열 변환(toCharArray(), getBytes(), new String()) (0) | 2019.03.21 |