gcsfuse gives a Input/output error when reading or writing to mounted directory in docker

I am using gcsfuse within a docker container (base image centos7) and am not able to read or write to the mounted directory.

I am mounting the directory with gcsfuse like this:

  • How to update docker version in AWS ECS
  • Logstash crashes as soon as it starts
  • Passing file as argument to Docker container
  • Switching app versions with docker container
  • nginx & nodejs: connect() failed (111: Connection refused) while connecting to upstream
  • Optimizations for ng build at runtime
  • [root@6c24c3a6cc28 /]# gcsfuse --foreground --key-file=/src/gcloud_service_account.json my-bucket /gcloud/
    Using mount point: /gcloud
    Opening GCS connection...
    Opening bucket...
    Mounting file system...
    File system has been successfully mounted.
    

    When I try and read or write to the mounted directory, I get this error:
    [root@6c24c3a6cc28 /]# ls -la /gcloud/
    ls: reading directory /gcloud/: Input/output error
    total 0

    gcsfuse prints out debug info saying:

    fuse: 2016/01/14 01:33:41.110260 *fuseops.ReadDirOp error: readAllEntries: ReadEntries: ListObjects: Get https://www.googleapis.com/storage/v1/b/my-bucket/o? delimiter=%2F&projection=full: private key should be a PEM or plain PKSC1 or PKCS8; parse error: asn1: structure error: tags don’t match (16 vs {class:1 tag:27 length:123 isCompound:true}) {optional:false explicit:false application:false defaultValue: tag: stringType:0 timeType:0 set:false omitEmpty:false} pkcs1PrivateKey @2

    I am running docker like this:
    docker run -p 3000:3000 \

    –privileged \

    –cap-add SYS_ADMIN \

    –device /dev/fuse \

    –name gcsfuseTest \

    gcsfuseImage

    I am not 100% certain what –cap-add SYS_ADMIN and –device /dev/fuse get me. I put them in based on other users who are mounting using fuse on docker.

  • Decrypt with gpg from inside a docker container
  • I cannot access a MySQL container using a hostname, but I can with it's IP address
  • Access service on subdomain in Kubernetes
  • How can I restart docker service using puppet…?
  • How do I connect to a docker container running on a different host on a mac?
  • Using docker-compose volumes_from option does not work
  • One Solution collect form web for “gcsfuse gives a Input/output error when reading or writing to mounted directory in docker”

    I was able to figure this out by turning on some debug flags when running gcsfuse like this:

    gcsfuse --foreground --debug_gcs --debug_http --debug_fuse --debug_invariants --key-file=/src/gcloud_service_account.json dev-my-bucket /gcloud

    This returned lots of info, along with this:

    “code”: 403,
    “message”: “Access Not Configured. The API (Cloud Storage JSON API) is not enabled for your project. Please use the Google Developers Console to update your configuration.”

    I enabled this API within the Google Devlopers Console, then after a couple minutes, vuala, it worked.

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