メインコンテンツまでスキップ

Dockerを使用せずにインストール

TianjiをインストールするにはDockerを使用するのが最適な方法ですが、環境問題を考慮する必要はありません。

しかし、サーバーがDockerをサポートしていない場合は、手動でインストールを試みることができます。

必要条件

以下が必要です:

  • Node.js 18.12+ / 20.4+
  • pnpm 9.x(9.7.1が望ましい)
  • Git
  • postgresql
  • pm2 - Tianjiをバックグラウンドで実行するため
  • apprise - 通知が必要な場合はオプション

コードをクローンしてビルド

git clone https://github.com/msgbyte/tianji.git
cd tianji
pnpm install

pnpm build

環境ファイルの準備

src/server.envファイルを作成

DATABASE_URL="postgresql://user:[email protected]:5432/tianji?schema=public"
JWT_SECRET="replace-me-with-a-random-string"

データベースのURLが正しいことを確認してください。また、データベースを事前に作成することを忘れないでください。

より詳細な環境に関しては、このドキュメントを確認してください environment

可能であれば、エンコーディングがen_US.utf8であることを確認するのが望ましいです。例えば: createdb -E UTF8 -l en_US.utf8 tianji

サーバーを実行

npm install pm2 -g && pm2 install pm2-logrotate

# データベースの移行を初期化
cd src/server
pnpm db:migrate:apply

# サーバーを起動
pm2 start ./dist/src/server/main.js --name tianji

デフォルトでは、Tianjihttp://localhost:12345で実行されます。

新しいバージョンへのコードの更新

# 新しいリリース/タグをチェックアウト
cd tianji
git fetch --tags
git checkout -q <version>

# 依存関係を更新
pnpm install

# プロジェクトをビルド
pnpm build

# データベースの移行を実行
cd src/server
pnpm db:migrate:apply

# サーバーを再起動
pm2 restart tianji

よくある質問

isolated-vmのインストールが失敗する

Python 3.12を使用している場合、以下のようなエラーが報告されます:

ModuleNotFoundError: No module named 'distutils'

これは、Python 3.12からdistutilsがビルトインモジュールから削除されたためです。現在、解決策があります。

Pythonのバージョンを3.12から3.9に切り替えることで解決できます。

brew管理のPythonでの解決方法

brew install [email protected]
rm /opt/homebrew/bin/python3
ln -sf /opt/homebrew/bin/python3 /opt/homebrew/bin/python3.9

その後、python3 --versionでバージョンを確認できます。