Serve media files efficiently with a Lightsail bucket and CDN distribution - Amazon Lightsail

Serve media files efficiently with a Lightsail bucket and CDN distribution

This tutorial describes the steps required to configure your Amazon Lightsail bucket as the origin of a Lightsail content delivery network (CDN) distribution. It also describes how to configure your WordPress website to upload and store media (such as images and movies files) on your bucket, and deliver media from your distribution. One example of how to do this is with the WP Offload Media Lite plugin. The following diagram illustrates this configuration.

The WP Offload Media Lite plugin workflow.

Storing website media in a Lightsail bucket takes the load off your instance from having to store and serve those files. Caching and serving media from a Lightsail distribution speeds up the delivery of those files to your website visitors, and can improve overall website performance. For more information about distributions, see Content delivery network distributions. For more information about buckets, see Object storage.

Contents

Step 1: Complete the prerequisites

Complete the following prerequisites if you haven't already:

Step 2: Modify your bucket permissions

Complete the following procedure to give your WordPress instance and the WP Offload Media Lite plugin access to your bucket. The permissions of your bucket must be set to Individual objects can be made public (read only). You must also attach your WordPress instance to your bucket. For more information about bucket permissions, see Bucket permissions.

  1. Sign in to the Lightsail console.

  2. On the Lightsail home page, choose the Storage tab.

  3. Choose the name of the bucket that you want to use with your WordPress website.

    The Lightsail bucket.
  4. Choose the Permissions tab on the Bucket management page.

  5. Choose Change permissions under the Bucket access permissions section of the page.

    The Change permissions button.
  6. Choose Individual objects can be made public and read only.

    The Individual objects can be made public and read only option.
  7. Choose Save.

  8. Choose Yes, save in the confirmation prompt that appears.

    The Yes, save button.

    After a few moments, your bucket will be configured to allow for individual object access. This ensures that objects uploaded to your bucket from your WordPress website using the Offload Media Lite plugin are readable to your customers.

  9. Scroll to the Resource access section of the page, and choose Attach instance.

    The Attach instance option.
  10. Choose the name of your WordPress instance in the drop-down that appears, and then choose Attach.

    The Attach option.

    After a few moments, your WordPress instance is attached to your bucket. This gives your WordPress instance access to manage your bucket and its objects.

Step 3: Create a distribution with a bucket as the origin

Complete the following procedure to create a Lightsail distribution and choose your Lightsail bucket as the origin.

  1. Choose Home on the top navigation menu of the Lightsail console.

  2. On the Lightsail home page, choose the Networking tab.

  3. Choose Create distribution.

    The Create distribution button in the Lightsail console.
  4. In the Choose your origin section of the page, choose the AWS Region in which you created your bucket.

    Distributions are global resources. They can reference a bucket in any AWS Region, and distribute its content globally.

    The AWS Region selector in the Choose your origin pane.
  5. Choose your bucket as the origin.

    The bucket dropdown list in the Choose your origin pane.
    Note

    The permissions of your bucket must be set to Individual objects can be made public (read only). Only individual objects that are public will be cached and served by the distribution. When you choose a bucket as the origin of a distribution, the options to specify the origin protocol policy, caching behavior, default behavior, and directory and file overrides become unavailable and cannot be edited. The origin protocol policy defaults to HTTP only for buckets, and the caching behavior defaults to Cache everything. You can change the advanced cache settings of the distribution after it's created.

  6. Choose your distribution plan.

  7. Enter a name for your distribution.

    The name input field for your distribution.

    Distribution names:

    • Must be unique within each AWS Region in your Lightsail account.

    • Must contain 2-255 characters.

    • Must start and end with an alphanumeric character or number.

    • Can include alphanumeric characters, numbers, periods, dashes, and underscores.

  8. Choose Create distribution.

    The Create distribution button.

    Your distribution is created after a few moments. When your new distribution reaches an Enabled state, it is ready to serve and cache objects that are in your bucket.

Step 4: Enable a custom subdomain for your distribution

When you create your distribution, it is configured with a default domain that is similar to 123abc.cloudfront.net. You can specify that default domain as the source of your media files when you configure the WP Offload Media Lite plugin. But we highly recommend that you enable a custom domain for your distribution. The custom domain that you enable for your distribution should be a subdomain of the domain that you're using with your WordPress website. For example, if you're using mycustomdomain.com with your WordPress website, then you might choose to use the custom domain media.mycustomdomain.com with your distribution. Using the same domain and subdomain combination between your WordPress website and your distribution helps improve the search engine optimization score of your website.

Complete the following steps to configure a custom domain for your distribution:

  1. Create a Lightsail SSL/TLS certificate for your domain to use it with your distribution. Lightsail distributions require HTTPS, so you must request an SSL/TLS certificate for your domain before you can use it with your distribution. For more information, see Create SSL/TLS certificates for your distribution.

  2. Enable custom domains for your distribution to use your domain with your distribution. Enabling custom domains requires that you specify the Lightsail SSL/TLS certificate that you created for your domain. This adds your domain to your distribution and enables HTTPS. For more information, see Enable custom domains for your distribution.

  3. Add an alias record to your domain's DNS. After you add the alias record, users who visit your domain are routed through your distribution. For more information, see Point your domain to a distribution.

Step 5: Install the WP Offload Media Lite plugin on your WordPress website

Complete the following procedure to install the WP Offload Media Lite plugin on your WordPress website. This plugin automatically copies images, videos, documents, and any other media added through WordPress' media uploader to your Lightsail bucket. It can also be configured to serve media from your bucket through your Lightsail distribution. For more information, see WP Offload Media Lite in the WordPress website.

  1. Sign in to the dashboard of your WordPress website as an administrator.

    For more information, see Getting the application user name and password for your Bitnami instance in Amazon Lightsail.

  2. Pause on Plugins in the left navigation menu, and choose Add New.

    Add new plugin menu item in the WordPress dashboard.
  3. Search for WP Offload Media Lite.

  4. In the search results, choose Install Now next to the WP Offload Media Lite plugin.

    WP Offload Media Lite plugin for WordPress.
  5. Choose Activate after the plugin is done installing.

    Activate the WP Offload Media Lite plugin for WordPress.
  6. In the left navigation menu, choose Settings, then choose Offload Media.

    Wordpress dashboard settings.
  7. In the Offload Media Lite page, choose Amazon S3 as the storage provider.

    WP Offload Media page.
  8. Choose My server is on Amazon Web Services and I'd like to use IAM Roles.

    WP Offload Media page.
  9. Choose Next.

  10. Choose Browse existing buckets in the What bucket would you like to use? page that appears.

    WP Offload Media page.
  11. Choose the name of the bucket that you created to use with your WordPress instance.

    WP Offload Media page.
  12. In the Offload Media Lite Settings page that appears, turn on Force HTTPS and Remove Files From Server.

    • The Force HTTPS setting must be turned on because Lightsail buckets use HTTPS by default to serve media files. If you don't turn this feature on, media files that are uploaded to your Lightsail bucket from your WordPress website won't be served correctly to your website visitors.

      The Remove Files From Server setting ensures that media that is uploaded to your Lightsail bucket isn't also stored on your instance's disk. If you don't turn this feature on, media files that are uploaded to your Lightsail bucket are also stored on the local storage of your WordPress instance.

    WP Offload Media page.
  13. Under the Delivery section of the page, choose Change next to the Amazon S3 label.

    The Change option.
  14. In the How would you like to deliver your media? page that appears, select Amazon CloudFront.

    The Amazon CloudFront option.
  15. Choose Save Delivery Provider.

  16. In the Offload Media Lite Settings page that appears, turn on Custom Domain (CNAME). Then, enter the domain of your Lightsail distribution into the text box. This could be the default domain of your distribution (for example, 123abc.cloudfront.net) or the custom domain for your distribution (for example, media.mycustomdomain.com), if you enabled it.

    The Turn on Custom Domain (CNAME) option.
  17. Choose Save Changes.

    Note

    To return to the Offload Media Lite Settings page later, pause on Settings in the left navigation menu, and choose Offload Media.

    Your WordPress website is now configured to use the Media Lite Plugin. The next time you upload a media file through WordPress, that file is automatically uploaded to your Lightsail bucket, and is served by the distribution. To test the configuration, continue to the next section of this tutorial.

Step 6: Test the connection between your WordPress website and your Lightsail bucket and distribution

Complete the following procedure to upload a media file to your WordPress instance and confirm that it is uploaded to your Lightsail bucket and is served from your distribution.

  1. Pause on Media in the left navigation menu of the WordPress dashboard, and choose Add New.

    The add new media file menu item in the WordPress dashboard.
  2. Choose Select Files on the Upload New Media page that appears.

    The Select files button in the WordPress dashboard.
  3. Choose a media file to upload from your local computer, and choose Open.

    The Open button in the WordPress dashboard.
  4. When the file is done uploading, choose Library under Media in the left navigation menu.

    The Library menu item in the WordPress dashboard.
  5. Choose the file that you recently uploaded.

    The selected file.
  6. In the details panel of the file, the name of your bucket appears in the Bucket field. The URL of your distribution appears in the File URL field.

    The name of your bucket and it's URL in the Attachment details panel.
  7. If you go to the Objects tab of the Lightsail bucket management page, you should see a wp-content folder. This folder is created by the Offload Media Lite plugin, and is used to store your uploaded media files.

    The wp-content folder in a bucket

Manage buckets and objects

These are the general steps to manage your Lightsail object storage bucket:

  1. Learn about objects and buckets in the Amazon Lightsail object storage service. For more information, see Object storage in Amazon Lightsail.

  2. Learn about the names that you can give your buckets in Amazon Lightsail. For more information, see Bucket naming rules in Amazon Lightsail.

  3. Get started with the Lightsail object storage service by creating a bucket. For more information, see Creating buckets in Amazon Lightsail.

  4. Learn about security best practices for buckets and the access permissions that you can configure for your bucket. You can make all objects in your bucket public or private, or you can choose to make individual objects public. You can also grant access to your bucket by creating access keys, attaching instances to your bucket, and granting access to other AWS accounts. For more information, see Security Best Practices for Amazon Lightsail object storage and Understanding bucket permissions in Amazon Lightsail.

    After learning about bucket access permissions, see the following guides to grant access to your bucket:

  5. Learn how to enable access logging for your bucket, and how to use access logs to audit the security of your bucket. For more information, see the following guides.

  6. Create an IAM policy that grants a user the ability to manage a bucket in Lightsail. For more information, see IAM policy to manage buckets in Amazon Lightsail.

  7. Learn about the way that objects in your bucket are labeled and identified. For more information, see Understanding object key names in Amazon Lightsail.

  8. Learn how to upload files and manage objects in your buckets. For more information, see the following guides.

  9. Enable object versioning to preserve, retrieve, and restore every version of every object stored in your bucket. For more information, see Enabling and suspending object versioning in a bucket in Amazon Lightsail.

  10. After enabling object versioning, you can restore previous versions of objects in your bucket. For more information, see Restoring previous versions of objects in a bucket in Amazon Lightsail.

  11. Monitor the utilization of your bucket. For more information, see Viewing metrics for your bucket in Amazon Lightsail.

  12. Configure an alarm for bucket metrics to be notified when the utilization of your bucket crosses a threshold. For more information, see Creating bucket metric alarms in Amazon Lightsail.

  13. Change the storage plan of your bucket if it's running low on storage and network transfer. For more information, see Changing the plan of your bucket in Amazon Lightsail.

  14. Learn how to connect your bucket to other resources. For more information, see the following tutorials.

  15. Delete your bucket if you're no longer using it. For more information, see Deleting buckets in Amazon Lightsail.