Joplin Server のインストール方法:Docker Compose で作るプライベート同期サーバー

Joplin Server を Docker Compose で構築する実用ガイド。PostgreSQL、APP_BASE_URL、管理者初期設定、一般ユーザーの有効化、クライアント同期、HTTPS リバースプロキシ、バックアップを整理します。

Joplin Server は、Joplin 公式の同期サーバーです。自分で立てれば、ノートデータを自分の VPS、NAS、または家庭用サーバーに置き、デスクトップやスマートフォンのクライアントを第三者のクラウドストレージに頼らず同期できます。

現在いちばん扱いやすい方法は Docker Compose です。PostgreSQL コンテナを 1 つ、Joplin Server コンテナを 1 つ用意し、APP_BASE_URL を正しく設定すれば使い始められます。

この手順は、Ubuntu、Debian、CentOS、Synology、Unraid、OpenMediaVault など、Docker が動く環境を想定しています。

事前準備

始める前に、次を確認してください。

  • 長時間稼働できるサーバーまたは NAS;
  • Docker と Docker Compose がインストール済み;
  • LAN 内だけで同期するなら内部 IP;
  • 外部から同期するなら、ドメイン名と HTTPS リバースプロキシ;
  • データベース用の強いパスワード。サンプルのまま使わないこと。

家の中の数台だけで同期するなら、http://内網IP:22300 のようなアドレスで動かせます。外出先のスマートフォンからも同期したい場合は、Nginx Proxy Manager、Caddy、Traefik などで HTTPS を使ってください。裸の HTTP サービスをそのままインターネットに公開するのは避けたほうが安全です。

Joplin 用の作業ディレクトリを作る

まず、Joplin Server の設定とデータベースデータを置くディレクトリを作ります。

1
2
mkdir -p /data/joplin
cd /data/joplin

パスは /opt/joplin/volume1/docker/joplin など、自分の環境に合わせて構いません。重要なのは、PostgreSQL のデータディレクトリを永続化することです。コンテナを消したときにデータまで消えないようにします。

docker-compose.yml を書く

作業ディレクトリで Compose ファイルを作成します。

1
nano docker-compose.yml

次の設定を貼り付けます。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
version: '3.8'

services:
  db:
    image: postgres:16
    container_name: joplin-db
    restart: unless-stopped
    volumes:
      - ./data/postgres:/var/lib/postgresql/data
    environment:
      - POSTGRES_USER=joplin
      - POSTGRES_PASSWORD=change_this_database_password
      - POSTGRES_DB=joplin

  app:
    image: joplin/server:latest
    container_name: joplin-app
    depends_on:
      - db
    restart: unless-stopped
    ports:
      - "22300:22300"
    environment:
      - APP_PORT=22300
      - APP_BASE_URL=http://your-server-ip:22300
      - DB_CLIENT=pg
      - POSTGRES_USER=joplin
      - POSTGRES_PASSWORD=change_this_database_password
      - POSTGRES_DATABASE=joplin
      - POSTGRES_HOST=db
      - POSTGRES_PORT=5432

特に変更が必要なのは次の 2 つです。

  • POSTGRES_PASSWORD:データベースのパスワード。dbapp の両方で完全に一致させます;
  • APP_BASE_URL:Joplin クライアントがサーバーへアクセスする固定 URL。

APP_BASE_URL は非常に重要です。クライアントが実際に開けるアドレスを指定してください。

  • LAN のみ:http://192.168.1.10:22300
  • 公開 IP:http://your-public-ip:22300
  • ドメインと HTTPS:https://joplin.example.com

あとでアクセス先を変える場合は、APP_BASE_URL も変更してサービスを再起動してください。そうしないと、クライアント同期、Web のリダイレクト、添付ファイルリンクで問題が出ることがあります。

Joplin Server を起動する

docker-compose.yml があるディレクトリで実行します。

1
docker compose up -d

コンテナ状態を確認します。

1
docker compose ps

初回起動に時間がかかる場合はログを見ます。

1
docker compose logs -f

通常、Joplin Server は 22300 ポートで待ち受けます。ブラウザーで設定した APP_BASE_URL を開き、ログインページが表示されれば基本的なデプロイは成功です。

初回管理者ログイン

Joplin Server の初期管理者アカウントは次のとおりです。

1
admin@localhost

初期パスワードは次のとおりです。

1
admin

初回ログイン後、最初に必ず管理者パスワードを変更してください。特にインターネットからアクセスできる場合、初期パスワードを残すのは危険です。

管理画面にログインしたら、Change Password ページで admin を強いパスワードに変更します。

普段使いの同期アカウントを作る

日常のノート同期に管理者アカウントを直接使うのはおすすめしません。一般ユーザーを作成し、PC やスマートフォンではそのアカウントを使うほうが安全です。

管理画面での手順は次のとおりです。

  1. Users を開く;
  2. Add user をクリックする;
  3. 普段使うメールアドレスとパスワードを入力する;
  4. ユーザーを作成する。

ここでよくある落とし穴があります。SMTP メールサーバーを設定していない場合、Joplin Server は有効化メールを送ったと表示しますが、実際には受信できません。

回避方法は簡単です。

  1. 管理画面に戻る;
  2. Emails メニューを開く;
  3. 未送信の有効化メールを見つける;
  4. 中の有効化リンクをコピーする;
  5. ブラウザーの新しいタブで開き、アカウントを有効化する。

有効化後、この一般ユーザーでクライアント同期ができます。

Joplin クライアントの同期設定

デスクトップ版またはモバイル版の Joplin App で設定します。

  1. 設定 または Options を開く;
  2. 同期 または Synchronization に入る;
  3. 同期先として Joplin Server を選ぶ;
  4. Joplin Server URLAPP_BASE_URL を入力する;
  5. Email / Username に、有効化した一般ユーザーのメールアドレスを入力する;
  6. Password にそのユーザーのパスワードを入力する;
  7. Check sync configuration を実行する。

チェックが通れば保存して同期を開始できます。

失敗する場合は、まず次を確認します。

  • クライアントから APP_BASE_URL をブラウザーで開けるか;
  • APP_BASE_URL が Compose ファイルと一致しているか;
  • 一般ユーザーが作成済みだけでなく、有効化済みか。

外部アクセスには HTTPS を使う

家庭内 Wi-Fi や LAN だけで使うなら HTTP でも通常は問題ありません。外部から同期するなら、リバースプロキシと HTTPS を使うのがおすすめです。

よく使われる方法は次のとおりです。

  • Nginx Proxy Manager;
  • Caddy;
  • Traefik;
  • 手動の Nginx 設定。

リバースプロキシを使う場合、APP_BASE_URL はクライアントが最終的にアクセスする HTTPS アドレスにします。

1
- APP_BASE_URL=https://joplin.example.com

Nginx を手動で設定する場合、少なくとも次の 2 点に注意します。

  • アップロード上限を上げる。例:client_max_body_size 100M;。大きな添付ファイル付きノートの同期失敗を避けるためです;
  • HostX-Forwarded-ForX-Forwarded-Proto などの header を正しく転送し、Joplin Server が URL やプロトコルを誤判定しないようにする。

簡単な Nginx リバースプロキシ例です。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
server {
    listen 443 ssl http2;
    server_name joplin.example.com;

    client_max_body_size 100M;

    location / {
        proxy_pass http://127.0.0.1:22300;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
    }
}

Nginx Proxy Manager を使う場合は、通常ドメインをサーバーの 22300 ポートへプロキシし、SSL 証明書を有効にするだけで済みます。Compose の APP_BASE_URL も HTTPS ドメインに変更するのを忘れないでください。

よくある問題

APP_BASE_URL を変更しても反映されない

docker-compose.yml を変更したら、コンテナを再作成します。

1
docker compose up -d

それでもおかしい場合は、コンテナ内の環境変数が本当に更新されているか確認します。ファイルを書き換えただけでサービスを再起動していない、というケースがよくあります。

クライアント同期でネットワークエラーが出る

まず次を確認してください。

  • スマートフォンや PC のブラウザーで Joplin Server を開けるか;
  • リバースプロキシの証明書が正常か;
  • APP_BASE_URL がクライアントから実際にアクセスするアドレスか;
  • ファイアウォールで 22300 または HTTPS ポートが許可されているか;
  • 一般ユーザーが有効化済みか。

大きな添付ファイルの同期に失敗する

Nginx や他のリバースプロキシ経由でアクセスしている場合、まずアップロードサイズ制限を確認してください。Nginx のデフォルト制限は小さいことがあるため、次のように設定します。

1
client_max_body_size 100M;

添付ファイルがさらに大きい場合は、値を上げます。

SMTP なしでも使えるか

使えます。個人や家庭用途なら SMTP なしでも動きます。ユーザー作成後の有効化メールは、管理画面の Emails ページから直接確認し、有効化リンクをコピーできます。

複数人のチームで長期利用するなら、SMTP を設定したほうがユーザー登録、パスワードリセット、通知がきちんと動きます。

バックアップのすすめ

Joplin Server で最も重要なデータは PostgreSQL にあります。今回の例では次の場所です。

1
/data/joplin/data/postgres

このディレクトリを定期的にバックアップするか、PostgreSQL の pg_dump でデータベースバックアップを取ってください。Joplin Server コンテナだけをバックアップしても意味は薄いです。コンテナは再取得できますが、同期データはデータベースにあります。

クライアント側にもノートデータのコピーは残りますが、それだけを唯一のバックアップにしないほうが安全です。サーバーデータベースのバックアップ + クライアント側コピー + 必要に応じた JEX エクスポート、という形が安定します。

まとめ

Joplin Server の Docker Compose デプロイは難しくありません。実際に詰まりやすいのは主に次の 3 点です。

  • APP_BASE_URL はクライアントが実際にアクセスするアドレスにする;
  • 初期管理者パスワード admin はすぐ変更する;
  • SMTP がない場合、新規ユーザーは管理画面の Emails ページから有効化リンクをコピーする。

LAN 内で使うなら http://IP:22300 で同期できます。外部から使うなら HTTPS リバースプロキシを用意し、アップロードサイズ制限も調整してください。これらを押さえれば、Joplin Server は安定したプライベートノート同期環境になります。

参考ソース

记录并分享
Hugo で構築されています。
テーマ StackJimmy によって設計されています。