systemdサービスでコマンドログを確認しますか?

systemdサービスでコマンドログを確認しますか?

ngrokを実行するシステムサービスがあります。

[Unit]
Description=Ngrok
After=network.service

[Service]
type=simple
User=ubuntu
WorkingDirectory=/home/ubuntu
ExecStart=/snap/bin/ngrok http 4000 --host-header="localhost:4000"
Restart=on-failure

[Install]
WantedBy=multi-user.target

このサービスの状態:

● ngrok.service - Ngrok
     Loaded: loaded (/etc/systemd/system/ngrok.service; enabled; vendor preset: enabled)
     Active: active (running) since Sat 2022-04-23 14:30:57 UTC; 7min ago
   Main PID: 24333 (ngrok)
      Tasks: 0 (limit: 4435)
     CGroup: /system.slice/ngrok.service
             ‣ 24333 /snap/ngrok/56/ngrok http 3000 --host-header=localhost:4000

Apr 23 14:30:57 pi-ubuntu systemd[1]: Started Ngrok.

ただし、URLを取得するにはngrokの出力を調べる必要があります。出力をどのように表示できますか?応援systemd サービスのコマンドは次のとおりです。

~> ngrok http 4000 --host-header="localhost:4000"
    ngrok                                                                                                                                       (Ctrl+C to quit)                                                                                                                                                            Session Status                online
    Account                       Amod Amatya (Plan: Free)
    Version                       3.0.2
    Region                        Europe (eu)
    Latency                       27.47694ms
    Web Interface                 http://127.0.0.1:4040
    Forwarding                    https://xyz-testing.ngrok.io -> http://localhost:4000                                                                                                                                                                                                    Connections                   ttl     opn     rt1     rt5     p50     p90
                                  0       0       0.00    0.00    0.00    0.00

PS。 Journalctlはコマンドの完全なログも表示しません。

答え1

URLを取得するには、ngrokの出力を調べる必要があります。

もっと良い方法があるでしょう!これは重要な動作属性であるため、標準出力を介してのみ表示されるべきではありません。Ngrok実行中のサービスからこれを読む方法があると確信しています。私はngrokを使ったことがありませんが、それが一種のポート転送サービスであることを知っています。アクティビティエンドポイントクエリ非常に使いやすい

curl \
    -H "Authorization: Bearer {API_KEY}" \
    -H "Ngrok-Version: 2" \
    https://api.ngrok.com/endpoints

Journalctlはコマンドの完全なログも表示しません。

その後、ngrokはあなたが望むものを記録しません。とても簡単です。サービスファイルで実行されたコマンドの標準出力が探しているものですjournalct -u ngrok.service。何もなければ、まだ印刷されていないという意味です。

関連情報