--- sidebar_position: 1 _i18n_hash: 7b72ca055d015393e7ca37eb45f7a74b --- # Installation ohne Docker Die Verwendung von Docker zur Installation von `Tianji` ist der beste Weg, da Sie sich keine Gedanken über Umgebungsprobleme machen müssen. Wenn Ihr Server jedoch keine Dockerisierung unterstützt, können Sie versuchen, die Installation manuell durchzuführen. ## Voraussetzungen Sie benötigen: - [Node.js](https://nodejs.org/en/download/) 18.12+ / 20.4+ - [pnpm](https://pnpm.io/) 9.x (9.7.1 besser) - [Git](https://git-scm.com/downloads) - [postgresql](https://www.postgresql.org/) - [pm2](https://pm2.keymetrics.io/) - Zum Ausführen von Tianji im Hintergrund - [apprise](https://github.com/caronc/apprise) - optional, falls Sie es für Benachrichtigungen benötigen ## Code klonen und bauen ```bash git clone https://github.com/msgbyte/tianji.git cd tianji pnpm install pnpm build ``` ## Umgebungsdatei vorbereiten Erstellen Sie eine `.env`-Datei in `src/server` ```ini DATABASE_URL="postgresql://user:pass@127.0.0.1:5432/tianji?schema=public" JWT_SECRET="ersetzen-durch-einen-zufälligen-string" ``` Stellen Sie sicher, dass Ihre Datenbank-URL korrekt ist, und denken Sie daran, die Datenbank vorher zu erstellen. Weitere Umgebungsvariablen finden Sie in diesem Dokument [environment](../environment.md) > Falls möglich, stellen Sie sicher, dass Ihre Kodierung en_US.utf8 ist, zum Beispiel: `createdb -E UTF8 -l en_US.utf8 tianji` ## Server starten ```bash npm install pm2 -g && pm2 install pm2-logrotate # Datenbankmigration initialisieren cd src/server pnpm db:migrate:apply # Server starten pm2 start ./dist/src/server/main.js --name tianji ``` Standardmäßig wird `Tianji` auf `http://localhost:12345` ausgeführt. ## Code auf eine neue Version aktualisieren ```bash # Neue Release/Tags auschecken cd tianji git fetch --tags git checkout -q # Abhängigkeiten aktualisieren pnpm install # Projekt bauen pnpm build # Datenbankmigrationen ausführen cd src/server pnpm db:migrate:apply # Server neu starten pm2 restart tianji ``` # Häufig gestellte Fragen ## Installation von `isolated-vm` fehlgeschlagen Wenn Sie Python 3.12 verwenden, wird möglicherweise ein Fehler wie dieser gemeldet: ``` ModuleNotFoundError: No module named 'distutils' ``` Dies liegt daran, dass Python 3.12 `distutils` aus den integrierten Modulen entfernt hat. Jetzt gibt es eine gute Lösung dafür. Sie können das Problem beheben, indem Sie Ihre Python-Version von 3.12 auf 3.9 wechseln. ### Wie man es in mit brew verwaltetem Python behebt ```bash brew install python@3.9 rm /opt/homebrew/bin/python3 ln -sf /opt/homebrew/bin/python3 /opt/homebrew/bin/python3.9 ``` Danach können Sie die Version mit `python3 --version` überprüfen.