Adding permissions to host directory with docker-compose

I’m trying to set up a development environment using docker-compose
and my container does not seem to have permissions to the host directory
that is mounted to the container, i’m getting this error when running
a grunt task that tries to modify folders inside the volume:

app_1                   | Warning: Unable to delete ".tmp" file (EACCES, permission denied '.tmp'). Use --force to continue.

here’s my docker file:

  • pcregrep with multiple capturing groups
  • How to docker exec to IBM bluemix containers
  • How to copy a specific docker image layer from one host to another?
  • How can I point stack at docker daemon started without using the socket file?
  • Docker rancher/agent won't start
  • Docker - any way to give access to host USB or serial device?
  • FROM node:0.10
    
    RUN mkdir -p /usr/src/app
    WORKDIR /usr/src/app
    
    RUN apt-get update \
        && apt-get install -y --no-install-recommends ruby-sass \
        && rm -rf /var/lib/apt/lists/* \
        && apt-get clean -y \
        && apt-get autoremove -y
    
    RUN npm install -g grunt-cli bower
    
    RUN groupadd -r node \
    &&  useradd -r -m -g node node
    
    RUN chown -R node:node /usr/src/app
    
    USER node
    
    EXPOSE 8080
    

    and my docker-compose file:

    app:
      build: .
      dockerfile: Dockerfile.dev
      ports:
       - "9000:9000"
      env_file:
       - ./server/config/env/development.env
      volumes:
       - ./:/usr/src/app:Z
      command: bash -c "npm install && bower install && grunt dev && npm start"
    
    db:
      ports:
       - "27017:27017"
    
    • I’m running ubuntu 15.10 with docker-compose version 1.5.2, build 7240ff3
    • Note that I am using the :Z permission

  • Unable to run mongod inside ubuntu docker container through ssh (Docker is started using “--net=host”)
  • Running Unity3d for automated builds inside a docker container
  • Why is my docker node container exiting
  • node.js proxy app in docker behind nginx proxy
  • How do I communicate from Docker Hub to Jenkins via web hook?
  • docker akka and scala, app start and stop just after without reason
  • One Solution collect form web for “Adding permissions to host directory with docker-compose”

    It’s just a file permissions thing.

    The first thing to realise is that the volume you are mounting has different permissions to the folder you create and chown in the Dockerfile. The node user presumably doesn’t have permissions to access this folder. You can fix this by running something like:

    $ docker run -u root -v $(pwd):/usr/src/app:Z my_app_image chown -R node:node /usr/src/app
    

    This will change the permissions of the folder on the host.

    Alternatively, if you need to be root to run the npm install && bower install, you could leave the root user as the default user then change to the node user to run the application. Something like:

    npm install && bower install && gosu node npm start
    

    Here I’ve used the gosu tool, which you will need to install in the image. It’s a little nicer than sudo, as it doesn’t start a second process.

    Docker will be the best open platform for developers and sysadmins to build, ship, and run distributed applications.