Skip to content

Configuration

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.
    #velocitySecret: secret_here
    # The secret used if the mode is bungeeguard.
    #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.
      # 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

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