Skip to content

Configuration

Gate uses a YAML configuration file (config.yml) to configure all proxy settings.

Config File Location

Gate looks for config.yml in the current working directory by default. Use --config or -c to specify a custom path:

sh
$ gate                    # Uses ./config.yml
$ gate -c /path/to/config.yml

Gate supports YAML (.yml, .yaml), JSON (.json), and environment variables with GATE_ prefix. You can mix formats - use a config file and override values with environment variables.

Configuration Templates

Generate configuration files using the gate config command, or create them manually:

sh
# Write to config.yml
$ gate config --write
$ gate config --type <type> --write

# Write to custom file using pipe redirection
$ gate config > my-config.yml
$ gate config --type <type> > my-config.yml

You can also create the config.yml file manually using any of the templates below as a starting point.

yaml
# Gate proxy configuration for Minecraft Java Edition
config:
  # The bind address to listen for Minecraft client connections.
  bind: 0.0.0.0:25565
  # Whether to use the proxy in online (authenticate players with Mojang API) or offline mode (not recommended).
  onlineMode: true
  # Registers servers with the proxy by giving the address of backend server a custom reference name.
  servers:
    # Server name: server address
    server1: localhost:25566
    server2: localhost:25567
    server3: localhost:25568
    server4: localhost:25569
  # The list of servers to try (ordered) to connect a player to
  # upon login or fallback when a player is kicked from a server.
  try:
    - server1
    - server2
    - server3
    - server4
  # Configure the response for server list pings.
  status:
    # The message of the day in legacy '§' format or modern text component '{"text":"...", ...}' json.
    motd: |
      §bA Gate Proxy
      §bVisit ➞ §fgithub.com/minekube/gate
    # The maximum players shown (is not the actual player limit!).
    showMaxPlayers: 1000
    # The server image (optimal 64x64); a path of an image file or the base64 data uri.
    favicon: 
    # Whether to log ping requests in the console.
    logPingRequests: false
    # Whether the proxy should present itself as Forge/FML-compatible server.
    announceForge: false
  # Allows players transferred from other hosts via the
  # Transfer packet (Minecraft 1.20.5) to be received.
  # Default: false
  acceptTransfers: false
  # Whether the proxy should support bungee plugin channels.
  # (Disable this if your backend servers are untrusted.)
  bungeePluginChannelEnabled: true
  # Whether to register builtin commands on proxy start.
  # Default: true
  builtinCommands: true
  # Whether players require permissions to
  # execute a builtin proxy command like /server.
  # Ignore this if `builtinCommands` is set to false.
  # (This should be set to true in production environments.)
  # Default: false
  requireBuiltinCommandPermissions: false
  # Declares the proxy commands to 1.13+ clients.
  # Default: true
  announceProxyCommands: true
  # Should the proxy enforce the new public key
  # security standard added in Minecraft 1.19?
  # Default: true
  forceKeyAuthentication: true
  # The default disconnect reason to kick player on proxy shutdown when no other reason was given.
  # Either in simple legacy '§' format or modern text component '{"text":"...", ...}' json.
  shutdownReason: |
    §cGate proxy is shutting down...
    Please reconnect in a moment!
  # Packet compression settings.
  compression:
    # The minimum size (in bytes) a packet must be before the proxy compresses it.
    # The Minecraft vanilla server uses 256 by default.
    threshold: 256
    # Indicates what zlib compression level Gate should use.
    # It goes from -1 to 9 where zero means no compression and -1 the default.
    level: -1
  # The time Gate waits to connect to a server before timing out.
  connectionTimeout: 5s
  # The time Gate waits to receive data from a server before timing out.
  # If you use Forge, you may need to increase this setting.
  readTimeout: 30s
  # Whether to reconnect the player when disconnected from a server.
  failoverOnUnexpectedServerDisconnect: true
  # Whether to kick existing connected player when an online-mode player with the same name joins.
  # This is useful for scenarios where the real Minecraft account takes precedence over the cracked one.
  # Note that enabling this would allow real Minecraft account players to bully cracked players by
  # taking the cracked player's name and block them from joining the server, while the online player is connected.
  # Default: false
  onlineModeKickExistingPlayers: false
  # Enabled extra debug logging (only for debugging purposes).
  debug: false
  # This allows you to customize how player information such as IPs and UUIDs are forwarded to your server.
  # See the documentation for more information.
  forwarding:
    # Options: legacy, none, bungeeguard, velocity
    mode: legacy
    # The secret used if the mode is velocity.
    # Can also be set via environment variable: GATE_VELOCITY_SECRET
    #velocitySecret: secret_here
    # The secret used if the mode is bungeeguard.
    # Can also be set via environment variable: GATE_BUNGEEGUARD_SECRET
    #bungeeGuardSecret: secret_here
  # Proxy protocol (HA-Proxy) determines whether Gate should support proxy protocol for players.
  # Do not enable this if you don't know what it is.
  proxyProtocol: false
  # ForcedHosts routes players to specific servers based on the hostname they connect with.
  # This allows you to have multiple domains pointing to the same Gate proxy but route players
  # to different servers based on which domain they used to connect.
  # Available in classic mode only (when lite.enabled: false).
  #
  # Key features:
  # - Hostname-only matching (port is ignored)
  # - Case-insensitive matching
  # - Supports multiple servers per hostname for load balancing
  # - Falls back to 'try' list if no forced host matches
  #
  # Examples:
  # forcedHosts:
  #   "creative.example.com": ["server2"]           # Route creative.example.com to server2
  #   "survival.example.com": ["server1", "server3"] # Route survival.example.com to server1 or server3
  #   "lobby.example.com": ["server1"]              # Route lobby.example.com to server1
  #
  # Note: Players connecting via IP address or unmatched hostnames will use the 'try' list above.
  # For lightweight deployments, see Gate Lite mode which provides similar host-based routing.
  forcedHosts: {}
  # The quota settings allows rate-limiting IP (last block cut off) for certain operations.
  # ops: The allowed operations per second.
  # burst: The maximum operations per second (queue like). One burst unit per seconds is refilled.
  # maxEntries: The maximum IPs to keep track of in cache for rate-limiting (if full, deletes oldest).
  quota:
    # Limit how many new connections can be established by the same IP range.
    connections:
      enabled: true
      ops: 5
      burst: 10
      maxEntries: 1000
    # Limit how many login requests can be made by the same IP range.
    logins:
      enabled: true
      burst: 3
      ops: 0.4
      maxEntries: 1000
  # Whether and how Gate should reply to GameSpy 4 (Minecraft query protocol on UDP) requests.
  query:
    enabled: false
    port: 25577
    showPlugins: false
  auth:
    # Customize the base URL for the Mojang session server to authenticate online mode players using different authentication servers.
    # Defaults to https://sessionserver.mojang.com/session/minecraft/hasJoined
    #sessionServerUrl: https://example.com/mitm/session/minecraft/hasJoined

  # Lite mode is a lightweight reverse proxy mode that acts as thin layer between the client and the backend server.
  # Full documentation: https://gate.minekube.com/guide/lite
  #
  # It efficiently routes client connections based on the virtual host address received in the handshake packet.
  # This allows to protect multiple backend servers behind a single port Gate Lite proxy instance.
  # Player connections (including ping requests and player authentication) is forwarded to the destined backend server.
  # This means Lite mode supports proxy behind proxy setups, but advanced features like server switching or proxy commands are no longer available
  # and have no effect in Lite mode when extensions use higher level Gate APIs and events.
  lite:
    # Enable Lite mode.
    # If disabled, the proxy will act as a full proxy with all features enabled just like BungeeCord/Velocity.
    # If enabled, the proxy will act as a lightweight reverse proxy to support new types of deployment architecture.
    # Default: false
    enabled: false
    # The routes that the proxy redirects player connections to based on matching the virtual host address.
    # The routes are matched in order of appearance.
    # Examples:
    routes:
      # Match the virtual host address to the backend server.
      - host: localhost
        # The backend server to connect to if matched.
        backend: localhost:25566
        # The optional fallback status response when all backends of this route are offline.
        fallback:
          motd: |
            §cLocalhost server is offline.
            §eCheck back later!
          version:
            name: '§cTry again later!'
            protocol: -1
          #players:
          #  online: 0
          #  max: 1000
          # The optional favicon to show in the server list (optimal 64x64).
          # Accepts a path of an image file or the base64 data uri.
          favicon: 
      # You can also use * wildcard to match any subdomain.
      - host: '*.example.com'
        backend: 172.16.0.12:25566
        proxyProtocol: true # Use proxy protocol to connect to backend.
        tcpShieldRealIP: true # Optionally you can also use TCPShield's RealIP protocol.
      # Use hostname parameters in backend addresses with $1, $2, etc.
      # Extract parts of the hostname and use them in the backend address.
      # Example: abc.domain.com → abc.servers.svc:25565
      - host: '*.domain.com'
        backend: '$1.servers.svc:25565'
      # You can also match to multiple hosts to one or multiple backends.
      - host: [127.0.0.1, localhost]
        backend: [172.16.0.12:25566, backend.example.com:25566]
        # Load balancing strategy when multiple backends are available.
        # See https://gate.minekube.com/guide/lite#load-balancing-strategies for detailed guide.
        # Options: random, round-robin, least-connections, lowest-latency
        # Default: random
        strategy: random
        # Ping responses are cached per backend address by default.
        # To disable motd caching set it to -1.
        # Default: 10s
        cachePingTTL: 60s
        # Modifies the virtual host to match the backend address in the handshake request.
        # This is useful when backends require players to connect with a specific domain.
        # Lite will modify the player's handshake packet's virtual host field from `localhost` -> `backend.example.com`
        # before forwarding the connection to the backend.
        # Default: false
        modifyVirtualHost: true
      # Match all as last item routes any other host to a default backend.
      - host: '*'
        backend: 10.0.0.10:25565
        fallback:
          motd: §eNo server available for this host.
          version:
            name: §eTry example.com
            protocol: -1
          #players:
          #  online: 0
          #  max: 1000
          #favicon: server-icon.png

  # Bedrock Edition (mobile, console, Windows) cross-play support.
  # Enables Java and Bedrock players to play together through integrated Geyser and Floodgate.
  # See https://gate.minekube.com/guide/bedrock for detailed setup guide.
  bedrock:
    # Enable Bedrock Edition support for cross-play.
    # Default: false
    enabled: false

    # --- QUICK START ---
    # For most users, this single line enables everything:
    #managed: true

    # --- ADVANCED CONFIGURATION ---
    # If you need more control, use the structure below:

    # Gate ↔ Geyser connection settings
    # TCP address where Gate listens for connections from Geyser Standalone.
    # Default: localhost:25567 (recommended for same-machine setups)
    # Use 0.0.0.0:25567 for Docker Compose or when Geyser runs on a different machine
    #geyserListenAddr: localhost:25567

    # Bedrock player username format to avoid conflicts with Java players.
    # Use %s as placeholder for the original Bedrock username.
    # Examples: ".%s" (prefix dot), "[BE]%s" (prefix tag), "%s_BE" (suffix tag)
    # Default: ".%s"
    #usernameFormat: ".%s"

    # Path to the Floodgate encryption key file (shared between Geyser and Gate).
    # Gate can auto-generate this key in managed mode.
    # Default: "floodgate.pem"
    #floodgateKeyPath: "floodgate.pem"

    # Managed Geyser mode: Gate automatically handles Geyser Standalone process.
    # This is the recommended setup for most users.
    managed:
      # Enable managed mode (Gate downloads, configures, and runs Geyser).
      # Default: false
      enabled: false

      # Download URL for Geyser Standalone JAR file.
      # Leave empty to use the latest official release.
      # Default: https://download.geysermc.org/v2/projects/geyser/versions/latest/builds/latest/downloads/standalone
      #jarUrl: "https://download.geysermc.org/v2/projects/geyser/versions/latest/builds/latest/downloads/standalone"

      # Directory for Geyser data (JAR file, config, logs, etc.).
      # Default: ".geyser"
      #dataDir: ".geyser"

      # Path to Java executable for running Geyser.
      # Default: "java" (from PATH)
      #javaPath: "java"

      # Whether to automatically download JAR updates on startup.
      # Default: true
      #autoUpdate: true

      # Additional JVM arguments for running Geyser.
      # Default: []
      #extraArgs:
      #  - "-Xmx1G"
      #  - "-XX:+UseG1GC"

      # Custom overrides for the auto-generated Geyser config.
      # This allows you to customize the Geyser config.
      # See https://wiki.geysermc.org/geyser/understanding-the-config/ for all options.
      configOverrides:
        # Bedrock client settings
        bedrock:
          # UDP port for Bedrock clients to connect to.
          # Default: 19132
          port: 19132
          # Server list display names
          motd1: 'Gate + Geyser Cross-Play'
          motd2: 'Java & Bedrock Together!'
          # Server name shown in Bedrock client
          server-name: 'My Minecraft Server'
          # Compression level (1-9, higher = more CPU, less bandwidth)
          # Default: 6
          compression-level: 6

        # Performance and debugging
        # Enable debug logging (shows packet details)
        # Default: false
        debug-mode: false
        # Whether to forward player ping to Gate.
        # Default: true
        forward-player-ping: true

        # Bedrock-specific features
        # Show block break cooldown as title/actionbar
        # Options: title, actionbar, false
        # Default: title
        show-cooldown: title
        # Show coordinates in debug info
        # Default: true
        show-coordinates: true
        # Allow custom player skulls from Java Edition
        # Default: true
        allow-custom-skulls: true
        # Maximum visible custom skulls (performance)
        # Default: 128
        max-visible-custom-skulls: 128

        # Xbox and console features
        # Enable Xbox achievements (Xbox players only)
        # Default: false
        xbox-achievements-enabled: false
        # Add non-Bedrock items to Creative inventory
        # Default: true
        add-non-bedrock-items: true

        # Advanced networking (rarely need to change)
        # MTU size for UDP packets
        # Default: 1400
        mtu: 1400
        # Use direct connections when possible
        # Default: true
        use-direct-connection: true

        # Resource pack settings
        # Force resource packs to be applied
        # Default: true
        force-resource-packs: true
        # Enable proxy connections for resource pack downloads
        # Default: false
        enable-proxy-connections: false

        # Floodgate settings (authentication for offline Bedrock players)
        # Custom Floodgate key file path (overrides floodgateKeyPath above)
        #floodgate-key-file: "/custom/path/to/key.pem"

        # For complete list of all Geyser configuration options, see:
        # https://wiki.geysermc.org/geyser/understanding-the-config/
        #
        # Common additional settings include:
        # - passthrough-motd: true/false
        # - passthrough-player-counts: true/false
        # - ping-passthrough-interval: 3
        # - scoreboard-packet-threshold: 20
        # - disable-compression: false
        # - notify-on-new-bedrock-update: true

    # --- MANUAL SETUP (Alternative to Managed Mode) ---
    # If you prefer to run your own Geyser instance instead of using managed mode:
    # 1. Set managed.enabled: false (or omit the managed section)
    # 2. Download and run Geyser Standalone manually
    # 3. Configure Geyser to connect to Gate's geyserListenAddr (default: 25567)
    # 4. Set auth-type: floodgate and use-proxy-protocol: true in Geyser config
    # 5. Share the same floodgateKeyPath between Gate and your backend servers
    #
    # See https://gate.minekube.com/guide/bedrock#manual-setup for detailed instructions.

# Configuration for Connect, a network that organizes all Minecraft servers/proxies
# and makes them universally accessible for all players.
# Among a lot of other features it even allows players to join locally hosted
# Minecraft servers without having an open port or public IP address.
#
# Visit https://connect.minekube.com/
connect:
  # Enabling Connect makes Gate register itself to Connect network.
  # This feature is disabled by default, but you are encouraged to
  # enable it and get empowered by the additional network services
  # and by the growing community in this ecosystem.
  enabled: false
  # The endpoint name is a globally unique identifier of your server.
  # If Connect is enabled, but no name is specified a random name is
  # generated on every restart (only recommended for testing).
  #
  # It is supported to run multiple Gates on the same endpoint name for load balancing
  # (use the same connect.json token file from first Gate instance).
  #name: your-endpoint-name
  # Whether to allow offline mode players to join.
  # Default: false
  allowOfflineModePlayers: true

# Gate HTTP API configuration.
# See https://gate.minekube.com/guide/api for more information.
api:
  # Whether to enable the API for Gate.
  # Default: false
  enabled: false
  # The bind address to listen for API connections.
  # Default: localhost:8080
  bind: localhost:8080
yaml
# This is a simplified config where the rest of the
# settings are omitted and will be set by default.
# See config.yml for the full configuration options.
config:
  bind: 0.0.0.0:25565
  servers:
    server1: localhost:25566
    server2: localhost:25567
  try:
    - server1
    - server2
yaml
# This is a simplified config where the rest of the
# settings are omitted and will be set by default.
# See config.yml for the full configuration options.
config:
  # The bind address to listen for Minecraft client connections.
  bind: 0.0.0.0:25565
  # Lite mode is a lightweight reverse proxy mode that acts as thin layer between the client and the backend server.
  # Full documentation: https://gate.minekube.com/guide/lite
  #
  # It efficiently routes client connections based on the virtual host address received in the handshake packet.
  # This allows to protect multiple backend servers behind a single port Gate Lite proxy instance.
  # Player connections (including ping requests and player authentication) is forwarded to the destined backend server.
  # This means Lite mode supports proxy behind proxy setups, but advanced features like server switching or proxy commands are no longer available
  # and have no effect in Lite mode when extensions use higher level Gate APIs and events.
  lite:
    # Enable Lite mode.
    # If disabled, the proxy will act as a full proxy with all features enabled just like BungeeCord/Velocity.
    # If enabled, the proxy will act as a lightweight reverse proxy to support new types of deployment architecture.
    # Default: false
    enabled: true
    # The routes that the proxy redirects player connections to based on matching the virtual host address.
    # The routes are matched in order of appearance.
    # Examples:
    routes:
      # Match the virtual host address to the backend server.
      - host: localhost
        # The backend server to connect to if matched.
        backend: localhost:25566
        # The optional fallback status response when all backends of this route are offline.
        fallback:
          motd: |
            §cLocalhost server is offline.
            §eCheck back later!
          version:
            name: '§cTry again later!'
            protocol: -1
          #players:
          #  online: 0
          #  max: 1000
          # The optional favicon to show in the server list (optimal 64x64).
          # Accepts a path of an image file or the base64 data uri.
          favicon: 
      # You can also use * wildcard to match any subdomain.
      - host: '*.example.com'
        backend: 172.16.0.12:25566
        proxyProtocol: true # Use proxy protocol to connect to backend.
        tcpShieldRealIP: true # Optionally you can also use TCPShield's RealIP protocol.
      # Use hostname parameters in backend addresses with $1, $2, etc.
      # Example: abc.domain.com → abc.servers.svc:25565
      - host: '*.domain.com'
        backend: '$1.servers.svc:25565'
      # You can also match to multiple hosts to one or multiple backends.
      - host: [127.0.0.1, localhost]
        backend: [172.16.0.12:25566, backend.example.com:25566]
        # Load balancing strategy when multiple backends are available.
        # See https://gate.minekube.com/guide/lite#load-balancing-strategies for detailed guide.
        # Options: sequential, random, round-robin, least-connections, lowest-latency
        # Default: sequential (tries backends in config order)
        # strategy: random  # Uncomment to use random instead of sequential
        # Ping responses are cached per backend address by default.
        # To disable motd caching set it to -1.
        # Default: 10s
        cachePingTTL: 60s
        # Modifies the virtual host to match the backend address in the handshake request.
        # This is useful when backends require players to connect with a specific domain.
        # Lite will modify the player's handshake packet's virtual host field from `localhost` -> `backend.example.com`
        # before forwarding the connection to the backend.
        # Default: false
        modifyVirtualHost: true
      # Match all as last item routes any other host to a default backend.
      - host: '*'
        backend: 10.0.0.10:25565
        fallback:
          motd: §eNo server available for this host.
          version:
            name: §eTry example.com
            protocol: -1
          #players:
          #  online: 0
          #  max: 1000
          #favicon: server-icon.png

  # The follow settings from standard Gate also apply to Lite mode.
  #
  # The time Gate waits to connect to a server before timing out.
  connectionTimeout: 5s
  # The time Gate waits to receive data from a server before timing out.
  # If you use Forge, you may need to increase this setting.
  readTimeout: 30s
  # Enabled extra debug logging (only for debugging purposes).
  debug: false
  # Proxy protocol (HA-Proxy) determines whether Gate should support proxy protocol for players.
  # Do not enable this if you don't know what it is.
  proxyProtocol: false
  # The quota settings allows rate-limiting IP (last block cut off) for certain operations.
  # ops: The allowed operations per second.
  # burst: The maximum operations per second (queue like). One burst unit per seconds is refilled.
  # maxEntries: The maximum IPs to keep track of in cache for rate-limiting (if full, deletes oldest).
  quota:
    # Limit how many new connections can be established by the same IP range.
    connections:
      enabled: true
      ops: 5
      burst: 10
      maxEntries: 1000

# Configuration for Connect, a network that organizes all Minecraft servers/proxies
# and makes them universally accessible for all players.
# Among a lot of other features it even allows players to join locally hosted
# Minecraft servers without having an open port or public IP address.
#
# Visit https://connect.minekube.com/
connect:
  # Enabling Connect makes Gate register itself to Connect network.
  # This feature is disabled by default, but you are encouraged to
  # enable it and get empowered by the additional network services
  # and by the growing community in this ecosystem.
  enabled: false
  # The endpoint name is a globally unique identifier of your server.
  # If Connect is enabled, but no name is specified a random name is
  # generated on every restart (only recommended for testing).
  #
  # It is supported to run multiple Gates on the same endpoint name for load balancing
  # (use the same connect.json token file from first Gate instance).
  #name: your-endpoint-name

# Gate HTTP API configuration.
# See https://gate.minekube.com/guide/api for more information.
api:
  # Whether to enable the API for Gate.
  # Default: false
  enabled: false
  # The bind address to listen for API connections.
  # Default: localhost:8080
  bind: localhost:8080
yaml
config:
  bind: 0.0.0.0:25565
  onlineMode: true
  servers:
    server1: 0.0.0.0:25566
  try:
    - server1
  # forwarding:
  # mode: legacy
  # velocitySecret: 'bedrock-crossplay-secret'
  status:
    motd: |
      §bGate + Geyser Cross-Play
      §eJava & Bedrock Players Welcome!

  # Enable Bedrock edition support
  bedrock:
    managed: true
    # Geyser will connect to this address that Gate listens on in parallel to the bind address.
    # localhost is recommended for same-machine setups (use 0.0.0.0 for Docker Compose)
    geyserListenAddr: 'localhost:25567'
    # Username format for Bedrock players to avoid conflicts
    usernameFormat: '.%s'
    # Path to Floodgate key for authentication
    floodgateKeyPath: '.examples/bedrock/geyser/key.pem'
yaml
# Minimal Gate configuration
# All other settings will use their default values
config: {}

For most users, the full configuration is recommended. You can generate it and then edit the servers section to point to your backend Minecraft servers.

Released under the Apache 2.0 License. (web version: dev)