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
デフォルトでは、Tianjiはhttp://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でバージョンを確認できます。