私はOracle Linux 9(Red Hat "クローン")を持ち、起動時にカールを実行するようになっているsystemctlサービスを持っています。次のエラーが発生します。
× gitlab-runner-curl.service - gitlab runner curl
Loaded: loaded (/etc/systemd/system/gitlab-runner-curl.service; enabled; vendor preset: disabled)
Active: failed (Result: exit-code) since Tue 2023-05-09 16:51:31 CEST; 27s ago
Process: 998 ExecStart=/usr/bin/curl -v -k --fail -F token=glptt-35a1ab49139cf38005a38d547ae614cba7c28862 -F ref=acc-mi-1 https>
Main PID: 998 (code=exited, status=6)
CPU: 23ms
May 09 16:51:31 serverx systemd[1]: Starting gitlab runner curl...
May 09 16:51:31 serverx curl[998]: % Total % Received % Xferd Average Speed Time Time Time Current
May 09 16:51:31 serverx curl[998]: Dload Upload Total Spent Left Speed
May 09 16:51:31 serverx curl[998]: [121B blob data]
May 09 16:51:31 serverx curl[998]: * Closing connection 0
May 09 16:51:31 serverx curl[998]: curl: (6) Could not resolve host: servery
May 09 16:51:31 serverx systemd[1]: gitlab-runner-curl.service: Main process exited, code=exited, status=6/NOTCONFIGURED
May 09 16:51:31 serverx systemd[1]: gitlab-runner-curl.service: Failed with result 'exit-code'.
May 09 16:51:31 serverx systemd[1]: Failed to start gitlab runner curl
したがって、明らかにネットワークが起動する前に実行されます(エラーのためcurl: (6) Could not resolve host: servery
)。なぜこれですか?これは私のサービスファイルです。
[Unit]
Description=gitlab runner curl
After=gitlab-runner.service network.target
[Service]
Type=oneshot
User=gitlab-runner
ExecStart=/usr/bin/curl -v -k --fail -F token=xxxxxx -F ref=acc-mi-1 https://servery/api/v4/projects/128/trigger/pipeline
RemainAfterExit=yes
[Install]
WantedBy=multi-user.target
ご覧のとおり、サービスはnetwork.startの後に開始する必要があります。カールドアはシェルで完全に機能します。
挨拶、
イヴァン
答え1
After=network.target
私はネットワークがオンラインになるのを待つことを信じていません。起動後はいつでもサービスが実行されますが、network.target
ネットワークがオンラインで接続が可能な場合は必ずしも実行されません。
~によるとnetwork*.target
各ユニットのドキュメントnetwork-online.target
あなたのサービスには次のものがあります。
[Unit]
Description=gitlab runner curl
After=gitlab-runner.service network-online.target
Wants=network-online.target