- Lab
- A Cloud Guru
Storing Container Data in AWS S3
Using Docker volumes is the preferred method of storing container data locally. Volume support is built directly into Docker, making it an easy tool to use for storage, as well as more portable. However, storing container data in Docker volumes still requires you to back up the data in those volumes on your own. There is another option - storing your container data in the cloud. It's not a solution for every problem, but after this lab, you'll have another tool at your disposal. This lab will show you how to mount an S3 bucket onto your local system as a directory. You will then mount that directory into your Docker container. We will use an httpd container to serve the contents of that bucket as a webpage, but you can use it to share any common data between containers. This will demonstrate how flexible Docker can be. You can make changes to your bucket and all of your containers using the S3 bucket will near-instantly have access to the content.
Path Info
Table of Contents
-
Challenge
Configuration and Installation
- Install the AWS CLI.
- Configure the AWS CLI for your user.
- Use the Access Key ID and Secret Access Key provided in your lab credentials.
- Use
us-east-1
as the default region. - Output is optional, but
json
is a good choice.
- Copy the credentials to the
root
user. - Install
s3fs-fuse
. This package is in EPEL, which is already installed on the server.
-
Challenge
Prepare the Bucket
- Create a mount point on the server.
- Enable the allow_other option in fuse.conf to make the S3 bucket mount accessible to non-root users or processes via:
sudo sed -i 's/^# user_allow_other/user_allow_other/' /etc/fuse.conf
- Mount the S3 bucket.
- Use the bucket name provided to you with the lab credentials. It is helpful to set this as an environment variable.
- To prevent a lot of extra calls to S3 that will increase your AWS bill, enable local file system caching by setting the
use_cache
option when mounting.
- Copy the website files into the bucket.
- Verify the files are in the folder.
- Verify the files are in the S3 bucket.
-
Challenge
Use the S3 Bucket Files in a Docker Container
- Run an
httpd
container to serve the website. Remember to mount the bucket and publish the web server port. - View the webpage in a browser. Use the server's public IP provided with the lab.
- Create a new page in the bucket, called
newPage.html
, by making a copy of an existing page. - View the new webpage in a browser. This will be at:
http://<ServerPublicIP>/newPage.html
. - Verify that the new webpage is in the S3 bucket.
- Run an
What's a lab?
Hands-on Labs are real environments created by industry experts to help you learn. These environments help you gain knowledge and experience, practice without compromising your system, test without risk, destroy without fear, and let you learn from your mistakes. Hands-on Labs: practice your skills before delivering in the real world.
Provided environment for hands-on practice
We will provide the credentials and environment necessary for you to practice right within your browser.
Guided walkthrough
Follow along with the author’s guided walkthrough and build something new in your provided environment!
Did you know?
On average, you retain 75% more of your learning if you get time for practice.