Regions
The Photon Cloud provides low latency gaming globally by hosting servers in various regions.
Clients get the list of regions from our Photon Name Servers. Over the lifetime of a project, new regions may be added or old ones may be deprecated and removed.
Each region is completely separate from the others and consists of a Master Server (for matchmaking) and Game Servers (hosting rooms).
The list of available regions differs per product (Fusion, Quantum, Chat etc.).
With the Region Allowlist, you can define which regions should be available per AppId (see below).
Below is the list of regions for this product.
Available Regions
The Photon Cloud consists of servers in several regions, distributed across multiple hosting centers over the world.
Some regional servers only support specific products and client SDKs. This means for example that Fusion clients can use the region Japan but Chat can not.
Each Photon Cloud region is identified by a "region token", which is a case insensitive, short string.
For example, "EU" or "eu" are both accepted and refer to the same Europe region.
Region | Hosted in | Token |
---|---|---|
Asia | Singapore | asia |
Australia | Sydney | au |
Canada, East | Montreal | cae |
Chinese Mainland (See Instructions) | Shanghai | cn |
Europe | Amsterdam | eu |
Hong Kong | Hong Kong | hk |
India | Chennai | in |
Japan | Tokyo | jp |
South Africa | Johannesburg | za |
South America | Sao Paulo | sa |
South Korea | Seoul | kr |
Turkey | Istanbul | tr |
United Arab Emirates | Dubai | uae |
USA, East | Washington D.C. | us |
USA, West | San José | usw |
USA, South Central | Dallas | ussc |
Region Allowlist
The Region Allowlist enables you to customize the available regions per application directly from the dashboard. Clients using the Best Region feature, will adapt automatically.
By using using more or less regions, you balance the quality of service (roundtrip times are better, when there is a region close to players) versus the matchmaking experience (less regions mean more players per region).
To define the regions per app, open the dashboard, click "Manage" for a chosen application and then click "Edit Allowlist".
You will find an input field to enter the list of allowed regions as follows:
- the available regions are listed above per SDK and sometimes separately for the Industries Circle.
- the allowlist must be a string of region tokens separated by semicolons. e.g. "eu;us".
- region tokens are case insensitive.
- undefined or unrecognized region tokens will be ignored from the list.
- empty ("") or malformed string (e.g. ";;;") means all available regions are allowed.
Within 10 minutes of a change (confirm and save), the Name Servers will send the filtered list to connecting clients.
To avoid conflicts on the client side, connect to the "Best Region" by ping or make sure to pick a region received with the regions list.
How To Choose A Region
Users in the US have the lowest latency if connected to the Photon Cloud US region. Easy.
But what if you have users from all over the world?
Options are..
- a) let the game client ping the different Photon Cloud regions and pre-select the one with the best ping, read our how-to
- b) distribute client builds tied to a region, so users from different regions connect to different Photon Cloud regions or
- c) let the user choose a matching region from within your game`s UI.
- d) let all users connect to the same region if the higher latency is acceptable for your gameplay.
All Photon Cloud apps are working in all available regions without any extra charge.
Photon Cloud's dashboard lets you monitor the usage of your game in each region and easily upgrade or downgrade your subscription plan.
C# Realtime API
Photon Realtime (used by most Photon SDKs) can detect the Best Region to connect to and enables you to stick to that region.
To do so, clients always fetch the list of available regions from the Name Server on connect.
The servers response is used to setup the LoadBalancingClient.RegionHandler
which is also provided via the callback OnRegionListReceived(RegionHandler regionHandler)
, as defined in the IConnectionCallbacks
.
Typically, the next step is to call regionHandler.PingMinimumOfRegions()
to detect the current ping to each region. You need to pass a method to call on completion and in best case you can also pass the "best region summary" from a previous run (explained below).
After pinging the servers, the (new) results are summarized in the regionHandler.SummaryToCache
which should be saved on the device for later use.
Without the SummaryToCache
from a previous session, all regions will be pinged, which takes a moment longer.
If a previous result is available, the client will check:
a. if the region list changed (covers the case if the "previous best region" is still available)
b. if the ping is no longer acceptable (>= 1.5x slower than previously saved reference value)
If either applies, all regions are pinged and a new result gets picked.
Using Best Region works well with the server-side Region Filter in the Dashboard.
It enables you to change the list of regions available to players on demand.
To access the list of regions or to override previous results, refer to the API Reference for regions.
Best Region Considerations
"Best Region" option is not deterministic.
Sometimes it may be "random" due to little variations or exact same ping calculations.
Theoretically, you could:
- have the same exact ping to multiple regions from the same device. So it is random, if you end up with different regions on clients connected to the same network.
- different ping values for the same region on different devices (or different retries on the same device) connected to the same network.
For instance, in the case of "us" and "usw" (or "ru" and "rue"), you could either make use of the online regions allowlist to select the ones you want and drop the others or connect to an explicit region.
To debug, set the logging level to "Info" and clear the "current best region" (in PUN: PhotonNetwork.BestRegionSummaryInPreferences = null). Have a look at the details or send us the log via mail.
Using The Chinese Mainland Region
The Photon Name Server has to be local to China, as the firewall might block the traffic otherwise.
The Chinese Photon Name Server is "ns.photonengine.cn".
Connecting with clients from outside of China mainland will most likely not produce good results.
Also, connecting from the Photon servers to servers outside of China mainland (e.g. for Custom Authentication, WebHooks, WebRPCs) might not be reliable.
Also, for legal reasons, you need a separate build for China and we recommend using a separate AppId with it.
For example, use a compile condition (of your choice) to change the AppId and the Photon Name Server depending on the build.
Follow the instructions corresponding to your client SDK to make a special build for the Chinese market.
Photon Voice
Without PUN integration (manual voice client connection)
C#
void ConnectToChina()
{
// you could also set these values directly in the VoiceConnection.Settings from Unity Editor
// in that case call voiceConnection.ConnectUsingSettings(); without passing parameter
AppSettings chinaSettings = new AppSettings();
chinaSettings.FixedRegion = "cn";
chinaSettings.UseNameServer = true;
chinaSettings.AppIdVoice = "ChinaVoiceAppId"; // TODO: replace with your own Voice AppId unlocked for China region
chinaSettings.AppVersion = "ChinaAppVersion"; // optional
chinaSettings.Server = "ns.photonengine.cn";
voiceConnection.ConnectUsingSettings(chinaSettings);
}
With PUN integration and using PUN settings
Since PUN is included in Voice, we just need to follow the steps required for PUN.
Photon Voice will automatically connect to the same servers unless PhotonVoiceNetwork.Instance.UsePunSettings
is set to false
.
In that case use the manual voice client steps stated above.
Using PhotonServerSettings
Using Code
C#
void ConnectToChina()
{
AppSettings chinaSettings = new AppSettings();
chinaSettings.UseNameServer = true;
chinaSettings.ServerAddress = "ns.photonengine.cn";
chinaSettings.AppIdRealtime = "ChinaPUNAppId"; // TODO: replace with your own PUN AppId unlocked for China region
chinaSettings.AppSettings.AppIdVoice = "ChinaVoiceAppId"; // TODO: replace with your own Voice AppId unlocked for China region
chinaSettings.AppVersion = "ChinaAppVersion"; // optional
PhotonNetwork.ConnectUsingSettings(chinaSettings);
}