मैं आधिकारिक tomcat
छवि से निर्मित डॉकर छवि में एक फ़ाइल जोड़ने की कोशिश कर रहा हूं । उस छवि को मूल अधिकार नहीं लगता है, जैसा कि मैं उपयोगकर्ता के रूप में लॉग इन करता tomcat
हूं यदि मैं बैश चलाता हूं:
docker run -it tomcat /bin/bash
tomcat@06359f7cc4db:/usr/local/tomcat$
यदि मैं Dockerfile
उस कंटेनर में फ़ाइल कॉपी करने का निर्देश देता हूं , तो फ़ाइल की अनुमति है 644
और स्वामी है root
। जहाँ तक मैं समझता हूँ, कि यह उचित प्रतीत होता है क्योंकि डॉकरफाइल में सभी कमांड रूट के रूप में चलाए जाते हैं। हालाँकि, अगर मैं उस फ़ाइल के स्वामित्व को बदलने की कोशिश करता हूँ, तो मुझे tomcat:tomcat
एक Operation not permitted
त्रुटि मिलती है ।
मैं उस छवि की प्रतिलिपि बनाई गई फ़ाइल की अनुमतियाँ क्यों नहीं बदल सकता?
इसे कैसे पुन: पेश किया जा सकता है:
mkdir docker-addfilepermission
cd docker-addfilepermission
touch test.txt
echo 'FROM tomcat
COPY test.txt /usr/local/tomcat/webapps/
RUN chown tomcat:tomcat /usr/local/tomcat/webapps/test.txt' > Dockerfile
docker build .
के उत्पादन docker build .
:
Sending build context to Docker daemon 3.072 kB
Sending build context to Docker daemon
Step 0 : FROM tomcat
---> 44859847ef64
Step 1 : COPY test.txt /usr/local/tomcat/webapps/
---> Using cache
---> a2ccb92480a4
Step 2 : RUN chown tomcat:tomcat /usr/local/tomcat/webapps/test.txt
---> Running in 208e7ff0ec8f
chown: changing ownership of '/usr/local/tomcat/webapps/test.txt': Operation not permitted
2014/11/01 00:30:33 The command [/bin/sh -c chown tomcat:tomcat /usr/local/tomcat/webapps/test.txt] returned a non-zero code: 1
root
? वेUSER
निर्देश को ध्यान में क्यों नहीं रखते हैं ?