Red Hat Training

A Red Hat training course is available for OpenShift Container Platform

2.9.2. イメージに埋め込まれたスクリプトの呼び出し

通常、ビルダーイメージは、最も一般的なユースケースを含む、独自のバージョンの S2I スクリプトを提供します。これらのスクリプトで各自のニーズが満たされない場合、S2I は、.s2i/bin ディレクトリーにカスタムのスクリプトを追加して上書する方法を提供します。ただし、カスタムのスクリプトを追加すると、標準のスクリプトを完全に置き換えてしまいます。スクリプトの置き換えは許容できる場合もありますが、場合によっては、イメージに含まれるスクリプトのロジックを保持しつつ、スクリプトの前後にコマンドをいくつか実行することをお勧めします。このような場合には、カスタムロジックを実行し、イメージ内のデフォルトのスクリプトに追加の作業を委任するラッパースクリプトを作成することができます。

ビルダーイメージ内のスクリプトの場所を判別するには、io.openshift.s2i.scripts-url ラベルの値を確認します。以下のように docker inspect を使用します。

$ docker inspect --format='{{ index .Config.Labels "io.openshift.s2i.scripts-url" }}' openshift/wildfly-100-centos7
image:///usr/libexec/s2i

openshift/wildfly-100-centos7 ビルダーイメージを検査し、スクリプトが /usr/libexec/s2i ディレクトリーにあることを確認できます。

これに基づいて、呼び出しをラップして、独自のスクリプトからこれらのスクリプトを呼び出します。

例2.1 .s2i/bin/assemble スクリプト

#!/bin/bash
echo "Before assembling"

/usr/libexec/s2i/assemble
rc=$?

if [ $rc -eq 0 ]; then
    echo "After successful assembling"
else
    echo "After failed assembling"
fi

exit $rc

以下の例では、メッセージを出力するカスタムの assemble スクリプトを表示し、イメージから標準の assemble スクリプトを実行して、assemble スクリプトの終了コードに応じて別のメッセージを出力します。

run スクリプトをラップする場合は、スクリプトの呼び出しに exec を実行して、シグナルが正しく処理されるようにする必要があります。残念ながら、exec を使用すると、デフォルトのイメージ run スクリプトを呼び出した後に、追加でコマンドを実行できなくなります。

例2.2 .s2i/bin/run スクリプト

#!/bin/bash
echo "Before running application"
exec /usr/libexec/s2i/run