systemd、EnvironmentFile、変数の再利用 - どのように?

systemd、EnvironmentFile、変数の再利用 - どのように?

私は次から移住しています。突然現れる到着システム。変換に問題があります。環境ファイル指示する。私はこれを得ることができません環境ファイル働く:

########################################################
# Catalina Settings
CLUSTER_BASE=/d01/tomcat/prod/xyz
CATALINA_BASE=$CLUSTER_BASE/1
CATALINA_TMPDIR=$CATALINA_BASE/temp
CATALINA_HOME=/usr/share/tomcat7
CATALINA_PID=/run/tomcat/tc-prod-xyz-1.pid

########################################################
# Java Settings
JAVA_HOME=/usr/lib/jvm/default-java/jre
JAVA_OPTS=-Djava.awt.headless=true
JAVA_OPTS=$JAVA_OPTS -server
JAVA_OPTS=$JAVA_OPTS -Xms2048m
JAVA_OPTS=$JAVA_OPTS -Xmx2048m
JAVA_OPTS=$JAVA_OPTS -XX:MaxPermSize=2048m
JAVA_OPTS=$JAVA_OPTS -XX:+UseParallelGC
JAVA_OPTS=$JAVA_OPTS -XX:+AggressiveHeap
JAVA_OPTS=$JAVA_OPTS -javaagent:$CLUSTER_BASE/newrelic/newrelic.jar

このタイプのステートメントで変数を再利用するようです。

JAVA_OPTS=$JAVA_OPTS -XX:+UseParallelGC

サポートしていないシステムまるで突然現れる。するシステムあなたはこのようなことを支持していますか、それとも私が長くて読みにくい声明をするべきですか?

答え1

残念ながら、あなたが持っているファイルは実際にはシェルスクリプトです。以前は、ほとんどのinitシステム/スクリプトがシェルを使用して環境変数を提供するファイルを解釈していたため、そのファイルでシェル操作を実行できました。ただし、Systemdはこれを行いません。環境ファイルは実際にはスクリプトではなく環境ファイルです。この内容は次のように記録されます。systemd.execマニュアルページ:

文字列内では変数拡張は行われませんが、指定子拡張は可能です。 $文字には特別な意味はありません。

したがって、2つのオプションがあります。

  1. すべての変数を手動で拡張します。を使うという意味ですCATALINA_BASE=/d01/tomcat/prod/xyz/1

  2. シェルを使用してファイルを評価します。
    ExecStart=/bin/bash -ac '. /path/to/env_file; exec /path/to/program'

答え2

長くて読みにくい文を書くべきですか?

いいえ

バックスラッシュで終わる行は次の行に関連付けられ、複数行の変数定義が可能です。

答え3

bin/setenv.shTomcatの特定の場合(この質問のように)、ほとんどの設定は起動時にTomcatによって実行され、期待どおりにシェルスクリプトの変数を評価するのがより簡単であることがわかりました。

だからandの変数を/etc/systemd/system/tomcat.service指定し、残りを入れます。EnvironmentCATALINA_BASECATALINA_HOME${CATALINA_BASE}/bin/setenv.sh

答え4

別のオプション:このユニットの前にヘルパーユニットを実行してEnvironmentFile使用できるユニットを作成することです。https://stackoverflow.com/a/42841480/32453

たとえば、補助装置は bash を使用できます。systemdenvをインポートする方法のようです。 :|

関連情報