inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[C++과 언리얼로 만드는 MMORPG 게임 개발 시리즈] Part4: 게임 서버

JobTimer

OnDisconnected() 부근에서 _players.clear() 의문점이 있습니다.

138

맞수

작성한 질문수 6

1

06:05 부근 질문입니다.

클라이언트가 캐릭터 선택과 동시에 연결이 종료될 때 서버가 혼잡하다면, Handle_C_ENTER_GAME()과 OnDisconnect()가 동시에 일어날 수 있다고 생각되는데요.. 그렇다면 멀티 스레드에서 _players에 동시 접근하는 일이 발생하지 않나요?

그렇게 된다면, _players.clear() 이후 _players[index] 접근하는 문제로 서버가 튕길 거라고 생각했습니다.

지금까지는 그러한 오류가 터진 적이 없었는데, 테스트가 부족했던 것인지 아니면 잘못 생각하고 있는 것인지 알고 싶습니다.

네트워크 MMORPG windows-server

답변 2

1

Rookiss

네 락을 걸어야 하는 것이 맞습니다.
그게 아니라면 OnDisconnect를 Job으로 던지거나요.

0

맞수

감사합니다

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

맞수님께서 질문 주신 내용은 C++과 언리얼 엔진을 사용한 MMORPG 게임 개발에서 발생할 수 있는 동시성 문제에 대한 것입니다. 멀티스레드 환경에서 서버의 _players 리스트를 수정할 경우 발생할 수 있는 가능성 있는 문제에 대한 우려를 표명하셨습니다.

게임 서버 개발에서 멀티스레드 환경에서 데이터가 안전하지 않게 수정되는 문제는 꽤 흔한 일이며, 특히 _players와 같은 전역 리스트에 대해 동시에 액세스하거나 수정할 경우 문제가 발생할 수 있습니다. 이는 서버의 안정성 및 데이터 일관성을 위협할 수 있습니다.

고려해야 할 두 가지 해결책:

  1. 쓰레드 동기화: 지역적으로 동시접근이 확인되는 영역에 락(critical section)을 이용하거나, mutex를 사용하여 동기화를 유지할 수 있습니다. 이렇게 하면 동시에 여러 스레드가 _players 데이터에 접근하지 못하게 하여 안전하게 접근이 가능합니다.

  2. 유니크한 쓰레드로 작업 분리: _players.clear()와 같은 작업을 안전하게 수행하려면 별도의 쓰레드를 통해 현 코드를 잠시 멈추고 실행하는 방법으로 서버의 다른 작업과 겹치지 않게 해야 합니다. 이 때도 큐를 사용하여 동작을 순차적으로 처리할 수 있도록 설계하는 것이 좋습니다.

이에 관한 추가적인 자료나 유사한 질문의 토론을 참조하시려면 다음 링크를 확인해 보실 수 있습니다:
- “스레드 관련 문의드립니다”
- “FindPlayer”

이 설명이 도움이 되었길 바랍니다. 추가적인 궁금한 점이 있으시면 언제든지 질문해 주세요.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

Memory Pool에서 오버플로우 질문입니다.

0

63

2

포토폴리오 및 진로 관련하여 고민입니다.

0

112

1

포토폴리오 관련 고민입니다.

0

62

1

실무에서도 alloc, 스마트포인터 등을 구현해서 쓰는지 궁금합니다.

0

82

2

성능 테스트 결과

0

103

2

게임 서버 Stateful, Stateless 진로 고민

0

121

1

WaitOnAddress와 Sleep의 차이 질문

0

83

1

궁금한거 있습니다.

0

82

2

JobTimer 구동 스레드

0

107

2

TryPop() 동작 관련 질문

0

81

1

로드맵 C#서버 C++서버 방향성 질문

0

148

2

스레드 id를 출력할떄 메인스레드 id도 출력되나요?

0

73

1

생명주기를 위한 의도적 복사

0

86

2

락프리의 실무에서 사용 질문

0

139

2

32bit threadID와 16비트 상위 WriteFlag에 대해

0

101

2

mutex와 sleep 차이점

0

117

1

실무에서는 어떠한 코드 스타일을 사용하는지 궁금합니다

0

152

2

Stomp Allocator의 Release함수에 대한 질문입니다.

0

96

1

공부법 관련해서

0

183

2

MakeShared 함수 관련

0

114

1

지금까지 서버코어에서 만든 내용에 대해 궁금한 점이 있어서 질문 드립니다.

0

144

2

운영체제관련 질문입니다

0

131

1

send하려는 데이터 크기가 크면 memcpy에서 문제가 발생할 것 같습니다.

0

117

2

메모리 풀 질문있습니다.

0

124

1