-
Notifications
You must be signed in to change notification settings - Fork 1
Socket.io
dannysir edited this page Nov 22, 2024
·
1 revision
연결
const socket = io("https://server-domain.com");
기본 구조
// server-side
io.on('connection', (socket: Socket) => {
console.log('사용자가 연결되었습니다.');
socket.on('chat message', (msg: string) => {
io.emit('chat message', msg);
});
socket.on('disconnect', () => {
console.log('사용자 연결이 끊어졌습니다.');
});
});
// client-side
import { io, Socket } from 'socket.io-client';
const socket: Socket = io('http://localhost:3000');
socket.on('chat message', (msg: string) => {
const li = document.createElement('li');
li.textContent = msg;
messages.appendChild(li);
});
-
이벤트 관련:
-
socket.emit(eventName[, ...args][, ack])
: 이벤트 발생 -
socket.on(eventName, callback)
: 이벤트 리스너 등록 -
socket.once(eventName, callback)
: 일회성 이벤트 리스너 등록 -
socket.off(eventName, listener)
: 이벤트 리스너 삭제.예시
const listener = (...args) => { console.log(args); }; socket.on("details", listener); // 나중에 리스너 제거 socket.off("details", listener);
-
-
룸 관련:
-
socket.join(room)
: 소켓을 특정 룸에 추가 -
socket.leave(room)
: 소켓을 특정 룸에서 제거 -
socket.to(room).emit(eventName[, ...args])
: 특정 룸에 이벤트 발생
-
-
연결 관련:
-
socket.disconnect(close)
: 소켓 연결 해제 -
socket.connected
: 연결 상태 확인 -
socket.id
: 소켓의 고유 식별자
-
-
데이터 전송:
-
socket.compress(value)
: 데이터 압축 설정 -
socket.volatile
: 휘발성 메시지 전송 설정
-
-
인증 및 보안:
-
socket.handshake
: 핸드셰이크 정보 접근 -
socket.client
: 기본 클라이언트 객체 접근
-
-
네임스페이스 관련:
-
socket.nsp
: 소켓이 속한 네임스페이스 객체
-
-
미들웨어:
-
socket.use(fn)
: 미들웨어 함수 등록
-
기본적으로 emit은 단방향이지만, 아래 방법을 통해 클라이언트에서 emit을 보낸 후에 잘 받았는지 확인이 가능하다.
Server
io.on("connection", (socket) => {
socket.on("update item", (arg1, arg2, callback) => {
console.log(arg1);// 1
console.log(arg2);// { name: "updated" }
callback({
status: "ok"
});
});
});
- 서버는 "update item" 이벤트를 수신합니다.
- 이벤트 핸들러는 세 개의 인자를 받습니다:
arg1
,arg2
,callback
. - 처리가 완료되면
callback
함수를 호출하여 클라이언트에 응답을 보냅니다.
Client
socket.emit("update item", "1", { name: "updated" }, (response) => {
console.log(response.status); *// ok*
});
- 클라이언트는 "update item" 이벤트를 emit합니다.
- 첫 두 인자는 서버로 전송할 데이터입니다.
- 마지막 인자는 서버의 응답을 처리할 콜백 함수입니다.
socket.onAny(listener)
모든 수신 이벤트를 디버깅하거나 할 때 유용.
typescriptsocket.onAny((eventName, ...args) => {
console.log(`이벤트 수신: ${eventName}`);
console.log('인자:', args);
});
- 모든 수신 이벤트에 대한 리스너를 추가합니다.
-
listener
함수는 이벤트 이름과 전달된 인자들을 받습니다.
- [FE] 프론트엔드 기술스택
- [FE] 라이브러리 없이 차트 구현 이유
- [FE] Canvas API 사용방법
- [FE] 네비게이션 바 애니메이션 구현
- [FE] Socket.io 사용방법
- [FE] Tanstack Router에 대하여...
- [FE] Intl(Internationalization) API
- [FE] React Suspense 적용
- [FE] 한글 입력 방식의 유연성을 높인 검색 시스템 구현하기
- [BE] 백엔드 기술 스택
- [BE] SSE vs Socket.io
- [BE] Redis를 도입하게 된 계기
- [BE] ACG Rule을 활용한 Secure CI CD 파이프라인 구현
- [BE] Nginx 로드밸런싱을 통해 한국 투자 API 소켓 제한 극복
- [BE] 주가 지수 기능 개발 과정
- [BE] 매수 및 매도 기능 개발 과정
- [BE] 실시간 자산 조회 기능 개발 과정
- [BE] 단위 테스트
- [BE] redis를 이용한 한국투자 Open API 세션 관리
- [BE] 데이터베이스 인덱싱
- [FE] React에서의 DOM 요소 접근 (useRef vs getElementById)
- [FE] Outlet을 활용한 공통 레이아웃 관리
- [FE] react hooks가 특정 조건에서 실행되면 안되는 이유 & useQuery에 query function 매개변수가 undefined일 수도 있을 때 어떻게 해결할까
- [FE] cross‐domain 로컬 환경에서 cookie로 인증 처리하기 with vite proxy
- [FE] 크롬&사파리 Composition 차이
- [FE] useEffect 의존성 배열
- [BE] Naver Cloud Platform HTTPS 무응답 현상
- [BE] 한국투자 Open API에서 access token을 발급받지 못하는 문제
- [BE] 한국투자 Open API와 웹소켓 연결이 되지 않던 문제
- [BE] 한국투자 Open API 웹소켓 연결이 중단되는 문제
- [BE] 같은 주식 주문이 동시에 여러 번 체결되는 문제
- [BE] 한국투자 Open API Websocket 세션을 두 개에서 한 개로 변경하기
- [BE] Nginx 로드 밸런싱 중 Socket bad Request 발생하는 현상
- [BE] 매수/매도 체결 로직에 의해 redis pub/sub이 정상적으로 동작하지 않는 문제