compassServer Browser

Welcome to Edgegap Server Browser OPEN BETA. We hope you enjoy the opportunity to preview our new service, and help shape it's future through roundtable discussions in our Discord.

Server Browser is a managed service for Match-Bound and Persistent servers:

  • help players search and join suitable servers based on capacity, latency, or game parameters;

  • pre-warm new servers to serve global audiences at scale and prevent frustrating queues;

  • streamline server operations including updates, restarts, persistence, meshing, and more.

circle-check

✔️ Preparation

Testing this service is entirely free, no credit card required.

Free Tier allows up to 3 hours of runtime on our shared test cluster, after each restart.

This tutorial assumes you have already:

Flow and Hierarchy

Server Browser: Flow and Hierarchy

Server Browser offers two main features:

▶️ Start Browsing with Game Clients to:

  • Discover and find suitable server instances, view slots, and reserve available capacity.

  • Reserve seats in an instance slot, retrieve connection details, and connect to servers.

  • Authenticate player connections from Deployments using Federated Identity.

  • Update instance slots' available capacity and/or metadata to modify discovery criteria.

🚀 Automated Scaling (optional) with Scaling Policies to:

  • Monitor available server instances, slots, capacity - per region and/or other criteria.

  • Deploy Servers to increase capacity with prewarming or just-in-time scaling.

  • Automate ops with special policies for demos, updates, testing, QA, tournaments, and more.

circle-info

After release, your server browser will need to run 24/7 to ensure players across the world can join servers.

▶️ Start Browsing

Learn about server/player lifecycle and their responsibilities to ensure efficient server use.

Authenticate

All requests must send an Authorization HTTP header with your secret Auth Token:

circle-exclamation

Server Browser automatically generates two types of tokens:

Discover Instance

New Deployments must create a new Instance with at least one Slot when initialized.

circle-info

See 🚀 Automated Scaling to learn about Scaling Policies and start deployments automatically.

Optional custom metadata parameters for player filtering, sorting, and browsing.

Examples:

  • slot information - team capacity and team-specific metadata (e.g. team name),

  • name and tags - customizable, unique, human-readable and searchable labels;

  • connection details - URL, IP, external ports, or other parameters;

  • compatibility data - server version or supported client versions;

  • latency qualifiers - city and region identifiers, and assigned Ping Beacons details;

  • game parameters - level/scene/map, game mode, difficulty, mods used;

  • any other custom parameters to help players filter and find a suitable server.

circle-info

Metadata parameters above are just examples, you can define any parameters including the above. All metadata parameters are optional, and some instances may not need to define all parameters.

Metadata supports string keys and values containing string, number, boolean, or array of strings.

circle-check

Servers may update instance or slot metadata anytime to modify their discoverability criteria.

Server Instances must periodically send a keep-alive heartbeat to verify their ongoing availability and prevent players from joining crashed or offline servers. Missing heartbeat for the configured expiration period will automatically delete instance and any pending seat reservations.

circle-info

See Persistence for managing persistent world state and Active Caching for faster deployments.

Search and Browse

Players may list server instances and paginate through results to find a server they'd like to join. To display ping (latency) data, read each instance's Ping Beacons details and measure latency.

Instances and slots may be filtered by joinable seats or indexed metadata parameters.

Parameter
Operators
Example Filter (based on Simple Example)

"joinable_seats"

eq or ne or

lt or le or

gt or ge

"string" (metadata)

eq or ne or

lt or le or

gt or ge or contains

"int" , or "float"

(metadata)

eq or ne or

lt or le or

gt or ge

"bool" (metadata)

eq or ne

circle-check
circle-info

Learn about cursor-based Pagination to let users fetch more results.

Reserve Seats

Before joining a server, a seat reservation is required to ensure that the instance offers sufficient available capacity. Reservations can include a group of players or a solo individual.

Reservations exceeding slot's joinable seat capacity will be automatically rejected (409 Conflictarrow-up-right). Joinable seats are any available seats which have not been reserved by other players yet.

Federated Identity: Players must provide a unique third party player ID in their reservation. Sending the same ID once they Connect to Server will allow the server to verify their identity.

Once a reservation is made successfully (200 OKarrow-up-right) players should attempt connecting immediately. Pending reservations will expire after 30 seconds unless they are confirmed by your server.

circle-info

Server may forcefully change any slot's capacity, add, delete, or update any slots. All reservations for a given slot will be removed if any pending reservations exceed new available slot capacity.

Connect to Server

Once a player found a suitable instance, they can retrieve required connection details from metadata (URL, IP, External Port). As soon as the seat reservation is made, players may proceed to connect to your deployment's game server and pass their player ID.

To connect from PIE (Editor) during development and testing, press the tilde key ~ and type open {URL}:{port} and wait for your editor to load the map.

circle-check

To authenticate new connections, your server must send a bulk reservation confirmation request with all new players' IDs, receiving information in confirmation response:

  • assignment of accepted player reservations to their preferred slot,

  • assignment of expired player reservations to their preferred slot,

  • a list of unknown player IDs.

Your server may decide how to handle each group of players and whether to allow or kick/ban expired or rejected users. Each of the instance's slots must be updated immediately with the new available seat count to ensure new reservations won't exceed capacity.

Abandon Server

When players leave, the server must update their assigned slot to reflect new available seat capacity.

circle-check

We recommend stopping servers with no players to optimize your hosting cost. Waiting a few minutes before doing so can reduce the amount of restarts during short periods of idling.

Read about Recovery Objectives to prevent frustrating persistent server rollbacks.

🚀 Automated Scaling

Server Browser is compatible with several different methods of autoscaling:

The following guide will focus on pre-warming with Scaling Policies as the primary method.

circle-check

Monitor Capacity

Scaling policies continuously refresh the list of your server instances (discovered Deployments), repeating every monitoring_interval . Each policy can include a filter using the same filtering syntax as players do when searching for instances - per region, capacity, or other criteria.

Your configured minimum_active_instances amount can be treated either as a:

  • fixed capacity of deployments that you wish to keep running at all times,

  • pre-warm standby deployment buffer to hide initialization delays.

Fixed Capacity

Keeping a fixed amount of servers can be useful particularly for games with Persistence, particularly when such games offer players to rent Community Servers.

This type of policy configuration is also sometimes used for Quality Assurance, Tournaments, Closed Alphas, Publisher Demos, or other kinds of limited capacity events and operations.

circle-info

Scaling policy helps you automatically restart and recycle crashed or stopped servers on the fly.

Pre-Warm Standby

Starting servers ahead of player demand can be advantageous when:

  • launch major releases or updates and expect rapid inflow of players in a short timespan,

  • or server initialization requires more than 30 seconds (not including deployment time),

  • or game implements meshing strategies requiring complex or circular network dependencies.

circle-info

With matchmaking, you'll need to Backfill Match to utilize this capacity before starting new deployments.

Deploy Servers

New deployments will be started automatically when the amount of monitored server instances falls below the configured minimum of active instances. All deployments are requested immediately and retried infinitely after deployment_registration_period elapsed.

circle-exclamation

When defining a deployment request for your policy, we use the standard deployment parameters allowing deployment in Private Fleets (with Overflow to Cloud) or directly to Cloud:

Example Policies

Test and modify any of these policies as you need. Most games will use multiple policies.

chevron-right🍀 Quality Assurance Pool (Minimal Example)hashtag

A simple policy to keep one server deployed for testing at all times.

chevron-right🌡️ Pre-Warm Release Per Regionhashtag

Each region starts a deployments prior to the release in anticipation of demand.

chevron-right❄️ Server Meshing Grouphashtag

One policy per group of servers, where game backend adds new policy for each group.

chevron-right🔑 Community Serverhashtag

One policy per server owner, passing a custom password used for server authentication.

chevron-right🔒 Region-Locked MMOhashtag

Each region adds deployments as available capacity drops below a threshold.

⚙️ Configuration

Server Browser API is generated from a JSON configuration specified when you create a new (or quick-restart) Server Browser. You may specify server and slot expiration, and custom metadata:

circle-info

For best performance, avoid specifying indices for metadata not used for filtering or sorting. Non-indexed params can be still set and read with server instance or slot details API methods, see 📗 API.

☁️ Hosting Cluster

Server Browser is conveniently hosted and managed 24/7 around the clock by Edgegap.

Choose a hosting option best suited for your goal:

  • Free Cluster (shared) to test all features and explore synergies with your design,

    • shuts down after 3 hours automatically, requiring restart to continue testing.

  • Private Cluster (dedicated) to ensure a stable environment for your production needs,

    • pick your region and get 24/7 support for live games to release with confidence.

Private Cluster Tiers

We currently offer 3 private cluster tiersarrow-up-right to cater to everybody’s needs:

Tier
Hobbyist Tier
Studio Tier
Enterprise Tier

Best Suited For

enthusiasts, solo developers

commercial releases

high-traffic launches

Resources

1 vCPU + 2GB RAM

6 vCPU + 12GB RAM

18 vCPU + 48GB RAM

Redundancy

1x virtual node

3x virtual nodes

3x virtual nodes

Rate Limit (req/s)

200

750

2,000

Price, hourly

$0.0312

$0.146

$0.548

Price, 30 days (nonstop usage)

$22.464

$105.12

$394.56

Upgrade to a private cluster with one click to benefit from highly available hosting maintained by Edgegap team with 24/7 live support for publicly released games.

Resource requirements for your instance will depend on factors:

  • number of players - more players result in more API requests,

  • number of requests per player - faster retries increase service load and consume resources,

  • number of servers - more servers result in more data stored and more API requests,

  • client retry fallback logic - retrying with jittered backoff helps spread traffic burst peaks,

  • average match duration - shorter sessions require more frequent server browser interaction.

circle-info

Our clusters use cloud machines featuring AMD/Intel CPUs with clock speed 2.4 - 3.2 GHz.

📗 API

Game Clients and Dedicated Servers send API requests throughout their lifecycle to Server Browser.

circle-info

Unity/Android - consider using raw string interpolationarrow-up-right to prevent code stripping of hardcoded JSONs.

circle-check

Import API specification to Scalar API Web Clientarrow-up-right or Swagger Editorarrow-up-right to inspect details.

Pagination

Server Browser provides cursor pagination to fetch filtered data incrementally in a specific order. This approach requires sending a cursor (starting point) and a page size (number of response items) whenever fetching more results, as opposed to the traditional limit-offset pagination.

circle-info

Combined with our proprietary database indexing system developed for game server metadata, cursor pagination provides a fast, consistent, and flexible user experience for filtering highly dynamic data.

Our goal is for users to find a suitable server on the first page. For best experience, we recommend showing cached results for previous pages, and only refreshing results when the user clicks Search.

🔖 Changelog

Semantic Versioning

Our matchmaker uses official Semantic Versioningarrow-up-right guidelines. Each configuration JSON is tied to a specific version of the service. Service version dictates which rules and settings are available in your configuration and API. Once a version is released, it will never change.

circle-info

The latest version of server browser is 0.0.5 . Keep an eye out for updates and announcements.

0.0.5 (Mar 18, 2026)

0.0.4 (Jan 05, 2026)

0.0.3 (Nov 28, 2025)

  • Initial release of Server Browser service launched in CLOSED BETA.

  • List Servers, Manage Capacity, and Get Connection Details.

  • Support for match sessions with Cloud Deployments and always online with Private Fleets.

Last updated

Was this helpful?