inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

Slack 클론 코딩[실시간 채팅 with React]

socket 객체의 삭제에 관한 질문

418

김민우

작성한 질문수 14

0

안녕하세요 제로초님 ㅎ

제가 sleact프론트 만들기 강의를 듣고 express로 서버를 직접 구현해보고 있습니다.

근데 socket부분을 구현하던 중 의문이 들었습니다.

 

workspace가 바뀌거나, 페이지 새로고침을 하면 서버에 새롭게 socket.on('connect')

요청이 가고 서버에선 새롭게 다시 통신을 합니다.

 

onlineMap[newNamespace.name][socket.id] = id; //유저정보 기록

이렇게 새롭게 유저를 넣어주고,

newNamespace.emit('onlineList', onlineMap[newNamespace.name]);

이렇게 서버로 온라인 리스트를 보내주고 콘솔에 찍어주니

 

새로고침할때마다 id 앞에있는 socket id가 이렇게 바뀌는데, 

 

매번 새로고침할때마다 기존의 socket은 삭제되고, 새롭게 생성되는 것인가요?

(disconnect해서 onlineList= {} 에서 삭제되는것 질문하는거아님)

 

그리고 DMList에서 onlineList를 가져온다음 socket.off를 해주는 이유가 무엇인가요>?

 

질문이 길어서 죄송합니다. 답변 기다리겠습니다!

Socket.io typescript react 웹팩 babel 클론코딩

답변 1

0

제로초(조현영)

네 새로고침하면 기존 소켓은 연결이 끊깁니다. 그래서 새로 연결해야 하는 것이고요.

DMList에서는

useEffect니까 당연히 return은 cleanup입니다. 기존 연결했던 socket을 끊어주어야 합니다. 이 useEffect는 socket이 변경될 때마다 실행되는데 기존 socket이 계속 연결되어있으면 안 되니까요.

0

김민우

답변 감사합니다! 항상 많이 배우고 갑니다

기본 셋팅과 관련하여

0

109

1

초기 셋팅 back과 front만 남겨두고 다 지운 후 진행 방법

0

111

2

focus 시에만 화면 업데이트 되는 이유 + 해결방법

0

169

2

useEffect 개수 관리

0

123

2

라이브러리 서치 방법

0

118

2

함수 정의 패턴

0

81

1

npm run dev 에러

0

157

3

npx webpack 후 에러

0

190

2

'void' 형식 식의 truthiness를 테스트할 수 없습니다.ts(1345)

0

154

2

사용자 가입시 에러발생 (TypeError: Cannot read properties of null (reading 'addMembers')

1

193

2

초기세팅중 packge.json 에러떠요

0

163

2

CORS - Access-Control-Allow-Origin 누락 문제

0

440

3

로그인 페이지 무한 새로고침 현상

0

610

2

Module not found: Error: Can't resolve './App' 에러

0

971

1

배포 방법

0

307

2

npm run dev 시 빌드가 매우 느려졌습니다

0

1017

2

alias 경로 설정 오류

0

463

2

fetcher 함수의 data 값이 두번 찍히는 이유

0

284

1

제네릭 질문

0

227

2

ts-node 대신 tsx 사용여부

0

380

1

배포 관련 질문

0

249

1

[nginx + https] 서비스를 실행하면 niginx가 아닌 서비스 화면을 보여주게 하고 싶습니다.

0

396

2

[배포하기] webpack에 aws 퍼블릭 IPv4 주소 와 포트 주소를 작성하고 나서 빌드후 실행하면 오류가 발생합니다.

0

343

1

users 호출 시 쿠키가 담기지 않는 이슈 질문드립니다.

0

255

2