Step 1
Update all the packages if required
(RHEL/CentOS)
yum update
(Debian/Ubuntu)
apt-get update
Install all the dependencies require to configure
(RHEL/CentOS)
sudo yum install automake fuse fuse-devel gcc-c++ git libcurl-devel libxml2-devel make openssl-devel
sudo apt-get install automake autotools-dev fuse g++ git libcurl4-gnutls-dev libfuse-dev libssl-dev libxml2-dev make pkg-config
Clone the s3fs repository from the GitHub
(RHEL Family and Debian Family)
git clone https://github.com/s3fs-fuse/s3fs-fuse.git
Now change directory to just clone from the GitHub and compile and setup the s3fs-fuse
cd s3fs-fuse./autogen.sh./configure --prefix=/usr --with-opensslmakesudo make install
Run the following command to check if every set up correctly
which s3fs
Output
/usr/bin/s3fsStep 6
Now, Go to IAM and create a user name "s3user" and give him Programmatic Access and attached the Policy "AmazonS3FullAccess".
While creating a user, it will provide you "Access key ID" and "Secret access key". Note it down into a notepad or download the CSV file. We will need this for configuring the configuration file for s3fs.
Step 7
Now create a configuration file name "passwd-s3fs" under etc folder
vi /etc/passwd-s3fs
Access-key-ID:Secret-access-key
eg. AKIATJAADJMXQVLQIOSR:gUSMAUjXPJy4sAPa00+nntGpIjR0eWnL96M9AHOx
Step 8
Change the permission of the file
chmod 640 /etc/passwd-s3fs
Step 9
Now, create a directory into your ec2 instance where you want to mount the S3 Bucketmkdir /gautam-bucket
Now mount the S3 Bucket into created directory name "gautam-bucket"
sudo s3fs gautam-bucket /gautam-bucket -o passwd_file=/etc/passwd-s3fs
In-case your system compromise, hacker can easily steal your data. To overcome this situation we use roles.
Now we will umount the S3 Bucket and remove the passwd-s3fs file. We will now use the Roles to achieve this.
Step 11
Now we will create a role for ec2 to give permission "AmazonS3FullAccess"
Step 12
Go to ec2 instance dashboard select the instance, go to instance setting and attached the s3role with the instance.
Step 13
Now, mount the S3 Bucket again with IAM Role
s3fs -o iam_role="s3role" gautam-bucket /gautam-bucket
Congratulations. You have setup the S3 Bucket privately from your EC2 instance.