지역

Photon Cloud는 다양한 지역에 서버를 호스팅 하여 전 세계적으로 빠른 게임 환경을 제공합니다.

클라이언트는 Photon 네임 서버에서 지역 목록을 가져옵니다. 프로젝트의 수명 동안 새로운 지역이 추가되거나 오래된 지역이 더 이상 사용되지 않을 수 있습니다.

각 지역은 서로 완전히 독립적이며, 매치메이킹을 위한 마스터 서버와 룸을 호스팅 하는 게임 서버로 구성됩니다.

Photon Cloud Regions' Connect Flows
Photon Cloud 지역에 연결

사용 가능한 지역 목록은 제품(Fusion, Quantum, Chat 등)에 따라 다릅니다.
지역 허용 목록을 사용하여 AppId 별로 사용할 수 있는 지역을 정의할 수 있습니다(아래 참조).

아래는 이 제품에 대한 지역 목록입니다.

사용 가능한 지역

Photon Cloud는 전 세계 여러 호스팅 센터에 분산된 여러 지역의 서버로 구성되어 있습니다.
일부 지역 서버는 특정 제품 및 클라이언트 SDK만 지원합니다. 예를 들어, Fusion 클라이언트는 일본 지역을 사용할 수 있지만 Chat은 사용할 수 없습니다.

각 Photon Cloud 지역은 대소문자를 구분하지 않는 짧은 문자열인 "지역 토큰"으로 식별됩니다.
예: "EU" 또는 "eu"는 동일한 유럽 지역을 나타냅니다.

지역호스팅 위치토큰
아시아싱가포르asia
호주시드니au
캐나다 동부몬트리올cae
중국 본토 (설명 보기)상하이cn
유럽암스테르담eu
홍콩홍콩hk
인도첸나이in
일본도쿄jp
남아프리카요하네스버그za
남아메리카상파울루sa
대한민국서울kr
터키이스탄불tr
아랍에미리트두바이uae
미국 동부워싱턴 D.C.us
미국 서부산호세usw
미국 남중부댈러스ussc

허용 지역 목록

허용 지역 목록을 사용하면 관리 화면에서 애플리케이션 별로 사용 가능한 지역을 직접 사용자 정의할 수 있습니다. 최적의 지역 기능을 사용하는 클라이언트는 자동으로 조정됩니다.

더 많은 지역을 사용하거나 줄임으로써 서비스 품질(플레이어와 가까운 지역일수록 왕복 시간이 더 짧아짐)과 매치메이킹 경험(적은 지역일수록 지역당 더 많은 플레이어를 의미함) 간의 균형을 맞출 수 있습니다.

앱별로 지역을 정의하려면, 관리 화면 열기, 선택한 애플리케이션의 "관리"를 클릭한 다음 "허용 목록 편집"을 클릭하십시오. 다음과 같이 허용 지역 목록을 입력할 수 있는 입력 필드가 제공됩니다:

  • 사용 가능한 지역은 위에서 SDK 별로 나열되어 있으며, 때로는 산업 서클에 대해 별도로 나열됩니다.
  • 허용 목록은 세미콜론으로 구분된 지역 토큰 문자열이어야 합니다. 예: "eu;us".
  • 지역 토큰은 대소문자를 구분하지 않습니다.
  • 정의되지 않았거나 인식되지 않은 지역 토큰은 목록에서 무시됩니다.
  • 빈 문자열("") 또는 잘못된 형식 문자열(예: ";;;")은 모든 사용 가능한 지역이 허용됨을 의미합니다.

변경(확인 및 저장) 후 10분 이내에 네임 서버가 필터링 된 목록을 연결 클라이언트에 전송합니다.
클라이언트 측의 충돌을 피하려면 핑을 통해 "최적의 지역"에 연결하거나 지역 목록에서 받은 지역을 선택하십시오.

참고: 인기 있는 앱의 사용 가능한 지역을 변경하면 여러 지역에서 피크 CCU에 영향을 미치며, 이는 구독 요금의 기준이 됩니다. 더 비싼 초과 요금을 피하기 위해 구독 플랜을 필요한 만큼 조정하십시오. 전환이 안정된 후에는 구독을 줄이는 것도 완전히 괜찮습니다.

지역 선택 방법

미국 사용자는 Photon Cloud의 미국 지역에 연결할 경우 가장 낮은 지연 시간을 경험할 수 있습니다. 간단합니다.


하지만 전 세계에 사용자가 있다면 어떻게 해야 할까요?

옵션은 다음과 같습니다..

  • a) 게임 클라이언트가 다양한 Photon Cloud 지역에 핑을 보내고 가장 낮은 핑의 지역을 미리 선택하도록 설정합니다. 방법 보기를 참조하세요.
  • b) 지역에 맞춘 클라이언트 빌드를 배포하여, 서로 다른 지역의 사용자가 다른 Photon Cloud 지역에 연결되도록 합니다.
  • c) 게임 UI 내에서 사용자가 적합한 지역을 선택할 수 있도록 합니다.
  • d) 높은 지연 시간이 게임 플레이에 영향을 주지 않는다면, 모든 사용자를 동일한 지역에 연결시킵니다.

모든 Photon Cloud 앱은 추가 비용 없이 모든 사용 가능한 지역에서 작동합니다.

가격 정보 보기

Photon Cloud의 대시보드를 통해 각 지역에서 게임의 사용량을 모니터링하고 구독 플랜을 손쉽게 업그레이드하거나 다운그레이드 할 수 있습니다.

관리 화면으로 이동

C# Realtime API

Photon Realtime(대부분의 Photon SDK에서 사용)은 연결할 최적의 지역을 감지하고 해당 지역에 고정할 수 있는 기능을 제공합니다.

이를 위해 클라이언트는 연결 시 항상 네임 서버에서 사용 가능한 지역 목록을 가져옵니다.
서버의 응답은 LoadBalancingClient.RegionHandler를 설정하는 데 사용되며, 이는 IConnectionCallbacks에 정의된 콜백 OnRegionListReceived(RegionHandler regionHandler)를 통해 제공됩니다.

일반적으로 다음 단계는 regionHandler.PingMinimumOfRegions()를 호출하여 각 지역의 현재 핑을 감지하는 것입니다. 완료 시 호출할 메서드를 전달해야 하며, 가능하면 이전 실행에서 저장된 "최적의 지역 요약"을 전달할 수도 있습니다(아래에 설명됨).

서버를 핑한 후, (새로운) 결과는 regionHandler.SummaryToCache에 요약되며, 나중에 사용할 수 있도록 기기에 저장되어야 합니다.

이전 세션의 SummaryToCache가 없으면 모든 지역을 핑하게 되어 시간이 조금 더 걸립니다.
이전 결과가 있는 경우, 클라이언트는 다음을 확인합니다:

a. 지역 목록이 변경되었는지(이전 "최적의 지역"이 여전히 사용 가능한 경우 포함)
b. 핑이 더 이상 허용되지 않는 수준인지(이전 저장된 참조 값의 1.5배 이상 느린 경우)

위의 둘 중 하나에 해당하면 모든 지역을 핑하고 새 결과를 선택합니다.

최적의 지역 기능은 대시보드의 서버 측 지역 필터와 잘 작동합니다.
이를 통해 플레이어에게 제공되는 지역 목록을 필요에 따라 변경할 수 있습니다.

지역 목록에 접근하거나 이전 결과를 재정의하려면 지역에 대한 API 참조를 확인하세요.

최적의 지역에 대한 고려 사항

"최적 지역" 옵션은 결정론적이지 않습니다.
때로는 약간의 변동성 또는 정확히 동일한 핑 계산으로 인해 "무작위" 일 수 있습니다.

이론적으로 가능한 것:

  • 동일한 기기에서 여러 영역으로 동일한 핑 값을 가진 경우입니다. 따라서 동일한 네트워크에 연결된 클라이언트는 무작위로 다른 지역에 연결됩니다.
  • 동일 네트워크에 연결된 서로 다른 기기에서 동일한 지역에 대하여 서로 다른 핑 값(또는 동일한 기기에서 다른 시도)

예를 들어, "us" 그리고 "usw"인 경우(또는 "ru" 그리고 "rue")에, 원하는 지역을 선택 또는 나머지 지역을 없앨 수 있도록 온라인 지역 화이트리스트를 사용할 수 있거나 지역을 지정하여 접속할 수 있습니다.

특정 마스터 서버에 연결하기

클라이언트를 특정 지역에 연결하려면, AppSettings.FixedRegion을 유효한 지역 토큰으로 설정하고 ConnectUsingSettings(settings)를 호출하십시오.

SDK는 요청된 지역의 마스터 서버 주소를 네임 서버에서 가져옵니다(그림 "Photon Cloud 지역에 연결"의 1번).
그리고 선택한 지역의 마스터 서버에 자동으로 연결합니다(그림 "Photon Cloud 지역에 연결"의 2번).

FixedRegion을 설정하면 클라이언트는 지역 목록을 가져오지 않으며, 최적의 지역 결과를 위한 지역 핑 작업을 건너뜁니다.
이는 연결 시간을 단축시킵니다.

빌드에 FixedRegion을 컴파일한 경우, 업데이트 없이는 변경할 수 없습니다.
가장 좋은 방법은 최적의 지역과 지역 허용 목록을 사용하는 것입니다.

지역 목록 표시 방법

런타임에 지역을 선택하려면(예: 사용 가능한 지역 목록을 플레이어에게 표시하고 선택하도록 하기 위해), 먼저 네임 서버에 연결해야 합니다.
이 작업은 현재 사용 가능한 지역 마스터 서버 주소 목록을 자동으로 가져옵니다(그림 "Photon Cloud 지역에 연결"의 1번).

"Name Server"에 대해 설명할 때, Name Server는 사용 가능한 지역에 따라 지리적으로 로드 밸런싱 됩니다. 이는 마스터 서버 주소 요청 시간을 최소화합니다.

C# 클라이언트 SDK (C# Client SDKs)

C#

    loadBalancingClient.ConnectToNameServer()

성공적으로 연결되면 LoadBalancingClient.OpGetRegions()가 내부적으로 호출됩니다.
그 결과는 loadBalancingClient.RegionHandler를 설정하며, 코드가 이를 구현하고 콜백을 등록한 경우 OnRegionListReceived를 호출합니다.

마스터 서버 목록이 준비되면, 모든 서버에 핑을 보내 가장 낮은 지연 시간으로 연결할 수 있는 최적의 지역을 선택하거나, 플레이어가 지역을 선택하도록 할 수 있습니다.
이 작업은 RegionHandler.PingMinimumOfRegions()로 수행할 수 있습니다.

클라이언트가 특정 지역을 결정하면, 해당 지역의 마스터 서버에 연결합니다(그림 "Photon Cloud 지역에 연결"의 2번).

C#

    loadBalancingClient.ConnectToRegionMaster("us")

마지막으로, 게임을 위한 방에 참여하거나 방을 생성하십시오(그림 "클라이언트의 Photon Cloud 연결"의 3번).

C++ 클라이언트 SDK

  1. Client 클래스의 생성자는 몇 가지 선택적 매개변수를 가질 수 있습니다.
    그중 마지막 매개변수는 regionSelectionMode라고 하며, LoadBalancing::RegionSelectionMode의 값 중 하나를 사용하며 기본값은 RegionSelectionMode::DEFAULT입니다.
    이 매개변수에 대해 명시적으로 RegionSelectionMode::SELECT를 전달하십시오.

  2. Client::connect()를 호출하여 시작되는 연결 과정에서 클라이언트는 네임 서버로부터 사용 가능한 지역 목록을 수신합니다.
    Listener는 선택적 콜백 Listener::onAvailableRegions()를 선언합니다.
    만약 regionSelectionModeRegionSelectionMode::SELECT를 전달했다면, Client는 해당 지역 목록에서 자동으로 항목을 선택하지 않고 목록을 콜백으로 전달합니다.
    따라서 Listener 구현에서는 기본적으로 비어 있는 이 콜백의 구현을 덮어쓰고, 사용 가능한 기준에 따라 지역을 선택하는 의미 있는 구현을 제공해야 합니다.

  3. 지역을 선택할 때까지 연결 과정은 완전히 중단됩니다.

  4. 선택한 지역을 Client::selectRegion()에 전달하여 연결 과정을 계속 진행하십시오.

참고:
Client::selectRegion()Listener::onAvailableRegions() 호출을 받은 이후에만 호출하는 것이 권장됩니다(콜백 내에서 직접 호출하거나, 콜백이 반환된 후 호출).
그렇지 않으면 클라이언트는 지역 선택을 위한 연결 흐름의 올바른 단계에 있지 않으며 예상치 못한 동작이 발생할 수 있습니다.

다음은 Client SDK의 demo_loadBalancing 소스 코드에 있는 Listener::onAvailableRegions() 구현 예제입니다:

C++

void NetworkLogic::onAvailableRegions(const ExitGames::Common::JVector<ExitGames::Common::JString>& availableRegions, const ExitGames::Common::JVector<ExitGames::Common::JString>& availableRegionServers)
{
    EGLOG(ExitGames::Common::DebugLevel::INFO, L"%ls / %ls", availableRegions.toString().cstr(), availableRegionServers.toString().cstr());
    mpOutputListener->writeLine(L"onAvailableRegions: " + availableRegions.toString() + L" / " + availableRegionServers.toString());
    // select first region from list
    mpOutputListener->writeLine(L"selecting region: " + availableRegions[0]);
    mLoadBalancingClient.selectRegion(availableRegions[0]);
}

selectRegion()은 연결 과정 중 onAvailableRegions() 호출을 받은 이후에만 호출되어야 합니다.
다른 시간이나 상태에서 호출하거나, 단일 onAvailableRegions() 호출에 대해 여러 번 호출하면 지원되지 않으며 예상치 못한 동작이 발생할 수 있습니다.

Objective-C 클라이언트 SDK

  1. EGLoadBalancingClient 클래스의 생성자는 몇 가지 선택적 매개변수를 가질 수 있습니다.
    그중 마지막 매개변수는 regionSelectionMode라고 하며, EGRegionSelectionMode.h의 값 중 하나를 사용하며 기본값은 EGRegionSelectionMode_DEFAULT입니다.
    이 매개변수에 대해 명시적으로 EGRegionSelectionMode_SELECT를 전달하십시오.

  2. EGLoadBalancingClient::connect()를 호출하여 시작되는 연결 과정에서 클라이언트는 Name Server로부터 사용 가능한 지역 목록을 수신합니다.
    EGLoadBalancingListener는 선택적 콜백 EGLoadBalancingListener::onAvailableRegions()를 선언합니다.
    만약 regionSelectionModeEGRegionSelectionMode_SELECT를 전달했다면, EGLoadBalancingClient는 해당 지역 목록에서 자동으로 항목을 선택하지 않고 목록을 콜백으로 전달합니다.
    따라서 EGLoadBalancingListener 구현에서는 기본적으로 비어 있는 이 콜백의 구현을 덮어쓰고, 사용 가능한 기준에 따라 지역을 선택하는 의미 있는 구현을 제공해야 합니다.

  3. 지역을 선택할 때까지 연결 과정은 완전히 중단됩니다.

  4. 선택한 지역을 EGLoadBalancingClient::selectRegion()에 전달하여 연결 과정을 계속 진행하십시오.

참고:
EGLoadBalancingClient::selectRegion()EGLoadBalancingListener::onAvailableRegions() 호출을 받은 이후에만 호출하는 것이 권장됩니다(콜백 내에서 직접 호출하거나, 콜백이 반환된 후 호출).
그렇지 않으면 클라이언트는 지역 선택을 위한 연결 흐름의 올바른 단계에 있지 않으며 예상치 못한 동작이 발생할 수 있습니다.

다음은 Client SDK의 demo_loadBalancing_objc 소스 코드에 있는 EGLoadBalancingListener::onAvailableRegions() 구현 예제입니다:

Objective-C

- (void) onAvailableRegions:(EGArray*)availableRegions :(EGArray*)availableRegionServers
{
    NSString* r = [availableRegions componentsJoinedByString:@", "];
    NSString* s = [availableRegionServers componentsJoinedByString:@", "];
    EGLOG(EGDbgLvl::INFO, L"onAvailableRegions: %ls / %ls", [r UTF32String], [s UTF32String]);
    [mOutputListener writeLine:@"onAvailableRegions: %@ / %@", r, s];
    // select first region from list
    [mOutputListener writeLine:@"selecting region: %@", availableRegions[0]];
    [mLoadBalancingClient selectRegion:availableRegions[0]];
}

selectRegion()은 연결 과정 중 onAvailableRegions() 호출을 받은 후에만 호출되어야 합니다.
다른 시간이나 상태에서 호출하거나, 단일 onAvailableRegions() 호출에 대해 여러 번 호출하면 지원되지 않으며 예상치 못한 동작이 발생할 수 있습니다.

중국 본토 지역 사용

Photon 애플리케이션에서 중국 본토 지역에 액세스하려면 요청이 필요합니다. AppID를 해제하려면 이메일을 보내주세요.
대시보드에서는 중국 본토 지역에서 사용할 유료 플랜을 구독할 수 없습니다. 구독에 대한 견적을 받으려면 [email protected]으로 이메일을 보내주세요.

Photon 네임 서버는 중국 내에서 로컬이어야 합니다. 그렇지 않으면 방화벽이 트래픽을 차단할 수 있습니다.
중국 Photon 네임 서버는 "ns.photonengine.cn"입니다.

중국 본토 외부에서 클라이언트와 연결하면 결과가 좋지 않을 가능성이 높습니다.
또한, Photon 서버에서 중국 본토 외부 서버(예: Custom Authentication, WebHooks, WebRPCs)로의 연결은 신뢰할 수 없을 수 있습니다.

중요: 현재 단계에서는 대시보드를 통해 앱에 변경한 사항이 중국 앱 캐시에 자동으로 반영되지 않습니다. 업데이트 요청이 있는 경우 이메일로 알려주세요.

법적 이유로 중국에 별도의 빌드가 필요하며, 이를 위해 별도의 AppID를 사용하는 것을 권장합니다.
예를 들어, 컴파일 조건을 사용하여 빌드에 따라 AppID와 Photon 네임 서버를 변경할 수 있습니다.

중국 시장을 위한 특별 빌드를 만들려면 클라이언트 SDK에 해당하는 지침을 따르세요.

C# 클라이언트 SDK

C#

void ConnectToChina()
{
    AppSettings chinaSettings = new AppSettings();
    chinaSettings.UseNameServer = true;
    chinaSettings.ServerAddress = "ns.photonengine.cn";
    chinaSettings.AppIdRealtime = "ChinaRealtimeAppId"; // TODO: replace with your own Realtime AppId unlocked for China region
    chinaSettings.AppVersion = "ChinaAppVersion"; // optional
    
    client.ConnectUsingSettings(chinaSettings);
}

C++ 클라이언트 SDK

  • Client::connect()에 대한 serverAdress 매개변수로 "ns.photonengine.cn"을 전달합니다.
  • serverType 매개변수를 기본값인 ServerType::NAME_SERVER로 유지해야 합니다.

Objective-C 클라이언트 SDK (Objective-C Client SDKs)

  • EGLoadBalancingClient::connect()에 대한 serverAdress 매개변수로 "ns.photonengine.cn"을 전달합니다.
  • serverType 매개변수를 기본값인 EGServerType_NAME_SERVER로 유지해야 합니다.
Back to top