Dockerfile
を実行していますが、/etc/fail2ban/jail.local
を変更するための変数に文字列content- "PRIVATEIP"を割り当てると問題が発生します。
Dockerfile
はエラーを生成して停止します。特定のファイルの文字列の内容を変更するためにsed
を使用して変数を割り当てることについては、私にはまったくわかりません。
RUN IP=$(cat /root/ip_variable) | sed -i -r "s/PRIVATEIP/${IP}/g" /etc/fail2ban/jail.local
---> Running in 1e78ef4318ab
これを処理する別の方法がある場合はお知らせください。
================================================== =========================
2018年7月11日に以下の代替方法の説明を追加します。
Dockerfileにコマンドラインをいくつか追加します。目的は以前と同じです。または、echoを使用して次のようにスクリプトを記述します。しかし、それは奇妙です。 "sed"の "s"の後の仲間の文字 "/"がなぜこのコマンドを見逃すのですか? (コードの出力内で文字にハイライトまたはマークを追加する方法がある場合は、ありがとうございます。)この問題が解決されれば、この問題を解決できると思います。
Step 64/73 : RUN echo "#!/bin/bash\nexport PRIVATEIP=$(cat /home/ip_variable)\nsed -i -r \"s/\bPRIVATEIP\b/\${PRIVATEIP}/g\" /etc/fail2ban/jail.local\nsed -i -r \"s/\bPRIVATEIP\b/\${PRIVATEIP}/g\" /etc/opendkim/TrustedHosts" > /home/start_script.sh
---> Running in bbff59f82475
Removing intermediate container bbff59f82475
---> 0068d9d600ff
Step 65/73 : RUN cat /home/ip_variable
---> Running in faeb4bb1a6ba
172.17.0.2/16
Removing intermediate container faeb4bb1a6ba
---> f6cc35fd01e5
Step 66/73 : RUN cat /home/start_script.sh
---> Running in 95a5ef3b7d23
#!/bin/bash
export PRIVATEIP=172.17.0.2/16
sed -i -r "sPRIVATEI/${PRIVATEIP}/g" /etc/fail2ban/jail.local
sed -i -r "sPRIVATEI/${PRIVATEIP}/g" /etc/opendkim/TrustedHosts
Removing intermediate container 95a5ef3b7d23
---> 6720e7c01efc
Step 67/73 : RUN chmod 755 /home/start_script.sh
---> Running in d8ab5e04a846
Removing intermediate container d8ab5e04a846
---> decb9e147db9
Step 68/73 : RUN sh /home/start_script.sh
---> Running in fc86000f9a2f
sed: -e expression #1, char 28: unknown option to `s'
sed: -e expression #1, char 28: unknown option to `s'
The command '/bin/sh -c sh /home/start_script.sh' returned a non-zero code: 1
皆さんありがとう。問題は区切り文字です。 「/」を「:」に変更して機能させる。結果はこちらに投稿します。 「ステップ65/78」では、スクリプトの内容を印刷し、「ステップ67/78」ではスクリプトをうまく実行しています。 @xenoidと@Kusalanandaに感謝します。
Step 63/78 : RUN echo "#!/bin/sh -x\nsed -i 's:PRIVATEIP:'"$(cat /home/ip_variable)"':g' /etc/fail2ban/jail.local\nsed -i 's:PRIVATEIP:'"$(cat /home/ip_variable)"':g' /etc/opendkim/TrustedHosts" > /home/ip_change_script.sh
---> Running in 251d6741c37e
Removing intermediate container 251d6741c37e
---> 95c4aa62d74a
Step 64/78 : RUN cat /home/ip_variable
---> Running in 8825ef517fb8
172.17.0.2/16
Removing intermediate container 8825ef517fb8
---> 39672eb7021d
Step 65/78 : RUN cat /home/ip_change_script.sh
---> Running in 2161051ee4cf
#!/bin/sh -x
sed -i 's:PRIVATEIP:'172.17.0.2/16':g' /etc/fail2ban/jail.local
sed -i 's:PRIVATEIP:'172.17.0.2/16':g' /etc/opendkim/TrustedHosts
Removing intermediate container 2161051ee4cf
---> 407ccc7106f7
Step 66/78 : RUN chmod 755 /home/ip_change_script.sh
---> Running in 0f6ca7f78ba8
Removing intermediate container 0f6ca7f78ba8
---> 250afb327db0
Step 67/78 : RUN sh /home/ip_change_script.sh
---> Running in 4b209e18854b
Removing intermediate container 4b209e18854b
---> d45d024e1359
Step 68/78 : RUN touch /home/service_boot.log
---> Running in 3548dc45f466
Removing intermediate container 3548dc45f466
---> 587527e18ab2
Step 69/78 : RUN cat /home/service_boot.log
---> Running in b068b00cd584
Removing intermediate container b068b00cd584
---> 3183e6b281ed
Step 70/78 : COPY boot_service.sh /home/boot_service.sh
---> 9a73dd4fd87d
Step 71/78 : RUN chmod 755 /home/boot_service.sh
---> Running in 2f226574e28d
Removing intermediate container 2f226574e28d
---> 8a0c14218e1b
Step 72/78 : RUN cat /home/boot_service.sh
---> Running in 5fa64827b6dd
これは私にとってはうまくいきます:
FROM Alpine
COPY ipaddr /ipaddr
COPY ipconf /ipconf
RUN export IPADDR=$(cat /ipaddr) ; sed -i -r "s/IPADDR/${IPADDR}/g" /ipconf
CMD cat /ipconf
Ipconfおよびipaddrを使用
IP address is IPADDR
1.2.3.4
次に:
>docker build -t dynchange .
Sending build context to Docker daemon 5.12kB
Step 1/5 : FROM Alpine
---> 3fd9065eaf02
Step 2/5 : COPY ipaddr /ipaddr
---> Using cache
---> 1828c3157d41
Step 3/5 : COPY ipconf /ipconf
---> 4f43e88e4425
Step 4/5 : RUN export IPADDR=$(cat /ipaddr) ; sed -i -r "s/IPADDR/${IPADDR}/g" /ipconf
---> Running in 722c3d3d9d9e
Removing intermediate container 722c3d3d9d9e
---> 32e31198b70a
Step 5/5 : CMD cat /ipconf
---> Running in 72ea59543a7f
Removing intermediate container 72ea59543a7f
---> 73f8a50d650a
Successfully built 73f8a50d650a
Successfully tagged dynchange:latest
>docker run --rm dynchange
IP address is 1.2.3.4
しかし、これはまさに私がやらない方法です。より良い方法は、ビルド引数を使用することです:
FROM Alpine
COPY ipconf /ipconf
ARG IPADDR
RUN sed -i -r "s/IPADDR/${IPADDR}/g" /ipconf
CMD cat /ipconf
次に:
>docker build -t dynchange --build-arg IPADDR=4.5.6.7 .
Sending build context to Docker daemon 5.12kB
Step 1/5 : FROM Alpine
---> 3fd9065eaf02
Step 2/5 : COPY ipconf /ipconf
---> Using cache
---> f5ac88ee48d5
Step 3/5 : ARG IPADDR
---> Running in 58d972e14660
Removing intermediate container 58d972e14660
---> fc3de48160c6
Step 4/5 : RUN sed -i -r "s/IPADDR/${IPADDR}/g" /ipconf
---> Running in 8ec855697510
Removing intermediate container 8ec855697510
---> 67e946559316
Step 5/5 : CMD cat /ipconf
---> Running in a5260c593c02
Removing intermediate container a5260c593c02
---> 567a31a517d1
Successfully built 567a31a517d1
Successfully tagged dynchange:latest
>docker run --rm dynchange
IP address is 4.5.6.7
しかし、これが正しい解決策であるかどうかさえわかりません。私は:
COPY
で作成/置換します。これにより、その内容を完全に制御できます。CMD
またはENTRYPOINT
は、メインコマンドを呼び出す前にファイルにパッチを適用するスクリプトです。構成ファイルをVOLUMEとして渡すこともできます(これにより、CMDがアプリケーションユーザーとして実行され、構成へのパッチ適用にroot権限が必要な場合の問題を回避できます)。割り当ては出力を生成しないため、別のプロセスにパイプしても意味がありません。
代わりに、;
は、パイプラインを2つの連続したコマンドに分割します。
IP=$(cat /root/ip_variable); sed -i "s/PRIVATEIP/$IP/g" /etc/fail2ban/jail.local
私はDockerに慣れていないのですが、それはRUN
コマンドです。 singleコマンドのみを使用する場合は、
RUN sh -c 'IP=$(cat /root/ip_variable); sed -i "s/PRIVATEIP/$IP/g" /etc/fail2ban/jail.local'
または
RUN sed -i "s/PRIVATEIP/$(cat /root/ip_variable)/g" /etc/fail2ban/jail.local