- Newest
- Most votes
- Most comments
Thanks for trying EFS!
You're under the correct impression that reading and writing from EFS should work just like local file system operations, except that the files will be available in a shared file system.
At first glance, I think your issue may be that you're calling your write API with a relative file path rather than absolute by starting with a ".". When you save to "./efs-mount-point/filename.txt", the OS will resolve to "current-directory/efs-mount-point/filename.txt", where "current-directory" is likely the workspace of your Node app. Assuming you mounted EFS to "/efs-mount-point", try changing your API call to say "/efs-mount-point/filename.txt" and see if the files appear in EFS.
Will @ AWS
Thank you for your response, but unfortunately, I am still not able to write or read my EFS volume using my Node.js application.
You were right about the relative read path causing problems. When I tried to read the directory of my EFS mount point, I was previously getting a directory does not exist error. When I changed the readFile path name from "./efs-mount-point" to "/home/ec2-user/efs-mount-point", my Node app produced a "permission denied" error instead, which leads me to believe this is a step in the right direction. Unfortunately, I am unable to determine why permission is denied.
I can manually write files to my "/home/ec2-user/efs-mount-point" directory in SSH console using the "touch testFile.txt" command, so I think I've given the root user sufficient permissions. I've even tried opening up my Security Group settings to allow all traffic on both inbound and outbound, but I still get the same permission denied error in my Node app.
I would note that I am using Elastic Beanstalk to launch my Node application, and the EC2 instance and EFS volume are in different security groups (as instructed in the AWS docs). I am using NSF4 to mount my EFS volume automatically on reboot. It only successfully mounts on reboot when I specify the mount path as "/home/ec2-user/efs-mount-point". The path "/efs-mount-point" does not mount successfully. Am I mounting my EFS volume incorrectly, or do you think it's some security setting I've overlooked?
Great to hear we're getting closer. For the next issue you're running into it sounds like the user the Node.js application is running as doesn't have permissions to the data in EFS. By default EFS file systems are owned by root. When you SSH in as ec2-user you're operating as root, so thats why you're able to read/write from the linux shell. I'm not super familiar with Node, but i'd guess that when you launch a node application it executes as a non-root user (maybe called "node"), and since that user hasn't been granted access to any EFS directories or files you're getting permission denied.
The easiest way to fix this is to issue a 'chmod 777 /myefsmountpoint'. This gives all users read/write/execute permissions to the root directory, allowing them to create new files and read/write to them. You may have to 'chmod 777 /myefsmountpoint/somefile' for any data that already exists that you want Node to have access to. We have a doc that talks a little more about this -
https://docs.aws.amazon.com/efs/latest/ug/accessing-fs-nfs-permissions.html
To the issue about mounting at boot, the only thing I can think of is that when you reboot your instance the directory you're trying to mount to isn't there. This may happen if EBS is only backing your home directory and not root. If this was the case, each time you rebooted your / directory would be rebuilt from the AMI. If true, you could workaround it by either automating the creation of the directory, or mounting to a path backed by EBS (like home).
Thank you for your response. You were right that I had to run the chmod 777 command to enable access to my node application, but in order to get it to work, I had to run it on the home directory, ec2-user directory, and efs-mount-point directory. Without running the command on all 3 directories, it doesn't work. Example:
sudo chmod 777 home
sudo chmod 777 ec2-user
sudo chmod 777 efs-mount-point
You were also right that if I try to save my Node documents to a subdirectory, like efs-mount-point/data, then I also have to run the chmod command a 4th time. Example:
sudo chmod 777 data
The good news is I am now able to read and write files to my efs-mount-point directory! Everything seems to be working as expected, so I will mark this question as answered. Thanks again.
Relevant content
- asked a year ago
- AWS OFFICIALUpdated a month ago
- AWS OFFICIALUpdated 3 months ago
- AWS OFFICIALUpdated 2 years ago
- How do I mount an Amazon EFS volume to an application directory in an Elastic Beanstalk environment?AWS OFFICIALUpdated 8 months ago