身内向けマイクラ鯖をDockerで構築する

By OldBigBuddha

3月の下旬頃から友人向けにマイクラのサーバーを建て、約1か月ほど運用を続けてきました。家に物理サーバーが一台しかないので、ほぼすべてのソフトウェアを Docker で動かしてサービスを提供しています。MineCraft もその一例です。

この記事では私が実際に使っている docker-compose.yml を公開し、1か月使って気がついた Tips などを紹介します。

利用する Docker Image

Docker で MineCraft を動かすにあたって用いるイメージは以下の2つです。

1つ目がサーバーそのもの、2つ目がバックアップ用のイメージです。バックアップ用なので、後述する配布ワールドの利用や単発的に使うサーバーでは使わなくて良いかもしれません。ここらへんは好みです。

実際に使っている docker-compose.yml

さて、本題の docker-compose.yml です。ポート等の設定は少し変えていますが、ほぼそのままのファイルです。

version: "3"

services:
  # Application
  mc-vanilla:
    image: itzg/minecraft-server
    ports:
      - 25565:25565
    environment:
      EULA: "TRUE"
      MEMORY: 2G
    volumes:
      - ./data:/data
      - /etc/timezone:/etc/timezone:ro
    tty: true
    stdin_open: true
    restart: always
    deploy:
      resources:
        limits:
          memory: 2.5G

  # Backup
  backup:
    image: itzg/mc-backup
    depends_on:
    - mc-vanilla
    volumes:
      - ./data:/data:ro
      - ./mc-backups:/backups
      - /etc/timezone:/etc/timezone:ro
    network_mode: "service:mc-vanilla"

この設定は公式のサンプルに少し手を加えたものとなっています。

mc-vanilla は起動時の最新バージョンでマイクラ鯖が構築されます。EULA とは「MineCraft END USER LICENSE AGREEMENT」のことで、これに同意がなければ MineCraft サーバーを運用することができません。熟読した上で "TRUE" を設定しましょう。MEMORY はその名の通りサーバーのメモリ割り当て(正確には JVM オプション)です。デフォルトでは 1G となりますが、ちょっと不安だったので 2G にしています。今のところ4人のサーバーで問題点は報告されていません。その他細かい設定(バージョンの変更やポートの変更やなどなどたくさん)が環境変数を通じて行えますので、詳しくは公式の README をご覧ください。

また、マイクラ鯖のコンテナにはメモリの使用量制限をかけています。MEMORY を設定しているので予想以上にリソースを持っていかれてしまう、ということはないのかもしれませんが念の為です。ここのメモリ上限ですが公式リポジトリの方にベストプラクティスとして MEMORY(Java Heap) + 25% が良いと記述があります。今回はヒープに 2GB を割り当てていますので 1.25 倍の 2.5 GB を上限としています。

バックアップコンテナは決められた時間(BACKUP_INTERVAL で設定可能、デフォルトは 24h)で自動バックアップを行い、バックアップファイルは一定期間(PRUNE_BACKUPS_DAYSで設定可能、デフォルトは7)保存されます。もっとも気をつけたほうが良い変数は INITIAL_DELAY です。この値はコンテナが起動した後どれくらいで初回のバックアップを始めるかを指定するものです。MineCraft のサーバーが起動するまで(jar ファイルのダウンロード等も含めて)少し時間がかかるので、この時間はお手元の環境に合わせて変更してください。デフォルトは 2m で、私のサーバーでは十分な数値でした。こちらのイメージもいくつか環境変数で調節ができるので上のドキュメントも合わせてご覧ください。作者が同じなのでデフォルトの設定がベストだとは思います。

各プロパティの意味を公式リポジトリで確認してから活用するのがベストというのは言わずもがなですが、とりあえず今日(2021/04/18)現在では上のファイルをコピペすれば動くかと思います。同階層にデータ用の data/ とバックアップ用の mc-backups が生成されますのでご注意ください。

Tips: RCON クライアント

MineCraft には RCON と呼ばれるマイクラ鯖管理者用の遠隔コマンド実行プロトコルが 1.9pre4 から実装されています。今回紹介したイメージでは標準で RCON が有効になっています。そのため、以下のコマンドで World 外からマイクラコマンドを入力できます。

docker exec {container_name} rcon-cli {MineCraft Command}

Tips: MODサーバー

上で紹介したイメージは MOD サーバーも簡単に構築できます。たとえば Forge サーバーにしたい場合、環境変数として TYPE="FORGE" を設定すると Forge サーバーとして起動します。あとはいつも通り mods ディレクトリに MOD ファイルを投入するだけです。他にも Fabric や Bukkit、Spigot など有名どころには対応しているので、公式ドキュメントのここらへんからご確認ください。

私のサーバーでは Fabric サーバーとして起動し、PhosphorLithium などの軽量化 MOD を導入することでゲーム性を変更することなく快適なゲーム環境を構築しています。軽量化 MOD を導入してるときとしていないときで明らかな差がメモリの使用量に出ていたので、サーバー機のリソースに不安がある方はあえて MOD サーバーとして起動しても良いかもしれませんね。軽量化 MOD のみならクライアントに導入してもらう必要もないので。余談ですが Fabric の MOD はいつもここから探しています。

Tips: 配布マップ

配布マップを使うための設定も存在します。が、上手く起動できる確率が低いです。これまで3つほど配布ワールドを試してきましたが、上手く起動できたのは1つだけでした。私はもともと MineCraft にとても明るいわけではないので、もしかしたら本来しないといけない下準備を忘れいていたりドキュメントの一部を誤って理解しているのかもしれません。「この配布マップだと上手くいったよ〜」という報告は大歓迎なので僕の Twitter アカウントにメンションを飛ばしてください。

気をつけるべき点としては VERSION を適切に設定するところと、WORLD に適切なファイルパスを設定することです。以下に上手くいったときの docker-compose.yml を貼っつけておきます。

version: "3"

services:
  mc-athletic:
    image: itzg/minecraft-server
    ports:
      - 25565:25565
    volumes:
      - ./data:/data
      - ./worlds:/worlds:ro
      - /etc/timezone:/etc/timezone:ro
    environment:
      EULA: "TRUE"
      VERSION: "1.16.4"
      MODE: "adventure"
      WORLD: /worlds/athletic
    tty: true
    stdin_open: true
    restart: always