s3sup may be better than other S3 syncing solutions (e.g. s3sync
) if you host
a static site on S3. Main features include:
- MIME type detection, with
Content-Type
set correctly for most files. - Fast and efficient synchronisation to S3 through maintaining a catalogue of content/metadata checksums for files already uploaded.
- Hierarchical configuration of important HTTP headers (e.g.
Cache-Control
andContent-Disposition
) on groups of files or individually.
Demo of new site being uploaded to S3:
Other features:
- Ordering of uploads to prevent HTML files referencing static assets that haven't been uploaded yet.
- Deletes files from S3 that no longer exist in the local project directory.
This can also be prevented with
--nodelete
command line option orpreserve_deleted_files
config file key, should you want them to stick around.
Follow these steps to get a new site uploaded to S3 with s3sup.
Inside your local static site directory, add an s3sup configuration file for the first time using:
s3sup init
Then edit the skeleton configuration file created at ./s3sup.toml
. For a
guide to the configuration settings, see section below. To verify the
destination path, HTTP headers and defaults that s3sup will set for an
individual file, use:
s3sup inspect <filepath>
AWS credentials can be configured using any method that the underlying boto3 library supports.
For most users, this will mean creating a credentials file at
~/.aws/credentials
following this template:
[default]
aws_access_key_id=foo
aws_secret_access_key=bar
Or alternatively credentials can be provided as environment variables
AWS_ACCESS_KEY_ID
and AWS_SECRET_ACCESS_KEY
.
Check what changes s3sup thinks needs to be made to S3. At the beginning, this will indicate that all files are new and need to be uploaded:
s3sup status
Then upload changes to S3:
s3sup push
s3sup can be installed using pip
. Please note s3sup
supports Python 3 only:
pip3 install s3sup
No distribution specific packages are available yet, please use the pip
installation method or download source from
GitHub.
To see the commands available, run s3sup with --help
:
$ s3sup --help
Usage: s3sup [OPTIONS] COMMAND [ARGS]...
s3sup - Amazon S3 static site uploader
Options:
--help Show this message and exit.
Commands:
init Create a skeleton s3sup.toml in the current directory.
inspect Show calculated metadata for individual files.
push Synchronise local static site to S3.
status Show S3 changes that will be made on next push.
Each command also provides a --help
:
$ s3sup push --help
Usage: s3sup push [OPTIONS]
Synchronise local static site to S3.
Use --dryrun to test behaviour without changes actually being made to S3.
Or use "s3sup status".
This command has two other aliases: upload or sync.
Options:
-v, --verbose Output more informational messages than normal.
-p, --projectdir TEXT Specify local s3sup static site directory (containing
s3sup.toml). By default the current directory is
used.
-n, --nodelete Do not delete any files on S3, add/modify operations
only. Alternatively set "preserve_deleted_files" in
s3sup.toml.
-d, --dryrun Simulate changes to be made. Do not modify files on
S3.
--help Show this message and exit.
s3sup expects an s3sup.toml
configuration file within the root directory of
your static site. Only the [aws]
section must be included at minimum:
These settings must be placed at the top of the s3sup.toml
file otherwise
schema validation errors will occur (TOML interprets them as as belonging to
the previous section otherwise):
Configuration key | Required | Default | Type | Expected value |
---|---|---|---|---|
preserve_deleted_files |
Optional | false |
Boolean | Setting to true will prevent files being deleted from S3 when they are deleted in the local project. This can be useful if your site has a long cache lifetime and you don't want cached pages to reference stylesheets/JavaScript files that suddenly disappear. This feature only prevents file deletions, it doesn't prevent file contents being overwritten if updated locally. This can also be achieved by supplying --nodelete as a command line option. |
charset |
Optional | 'utf-8' |
String | Specify the character encoding of text files within this s3sup project. The charset is appended to Content-Type header. This can also be overriden on a [[path_specific]] basis. |
Configuration settings related to AWS:
Configuration key | Required | Default | Type | Expected value |
---|---|---|---|---|
region_name |
Required | N/A | String | AWS region that the S3 bucket is located in. E.g. 'eu-west-1'. |
s3_bucket_name |
Required | N/A | String | Name of the S3 bucket. E.g. 'mywebsitebucketname' |
s3_project_root |
Optional | Bucket root | String | S3 sub path where the local project should be uploaded to, without a leading slash. E.g. 'staging/'. By default the local project is uploaded to the root of the S3 bucket. |
One or more [[path_specific]]
sections may be included. Each
[[path_specific]]
section must contain a path
specification for which the
directives in that section should apply to. The path
can be the relative
path to a file within the project directory, or a regular expression matching
multiple paths.
If multiple [[path_specific]]
entries match the same path, directives are
combined from all matching [[path_specific]]
entries, with the last matching
[[path_specific]]
directive entry in the configuration file winning for
equivalent directive keys.
Along with path
, the following directives can be set:
Configuration key | Required | Default | Type | Expected value |
---|---|---|---|---|
path |
Required | N/A | String | Regular expression matching multiple relative paths, or an individual relative path to a file. |
ACL |
Optional | 'public-read' |
String | S3 access permissions for the matching paths. One of: private, public-read, authenticated-read. |
StorageClass |
Optional | 'STANDARD' |
String | S3 storage resiliency class. One of: STANDARD, REDUCED_REDUNDANCY, STANDARD_IA, ONEZONE_IA, INTELLIGENT_TIERING or GLACIER. |
WebsiteRedirectLocation |
Optional | None | String | Instead of serving the file when a client requests this path, instruct S3 to respond with a redirect to the specified URL instead. Note that URLs must be absolute, e.g. 'https://www.example.com/new_home'. |
Cache-Control |
Optional | max-age=10 |
String | Set HTTP header value to control cache lifetime. A short default cache lifetime is set to provide basic origin shielding should an explicit one not be set. |
Content-Disposition |
Optional | None | String | Set HTTP header value to control whether the browser should display the file contents or provide a download dialog to the user |
Content-Type |
Optional | Automatic | String | Override Content-Type HTTP header value. Only override this if absolutely necessary as s3sup MIME type detection normally sets this header correctly. |
charset |
Optional | 'utf-8' |
String | Manually specify the character encoding of text containing files. This is appended to Content-Type HTTP header. Usually setting charset in the global configuration section is adequate but this directives allows control on a path level. |
Content-Encoding |
Optional | Automatic | String | Set Content-Encoding HTTP header value. Only override this if absolutely necessary as s3sup detects encoding automatically. For wide browser support, it is recommended to store content uncompressed in S3 and then use dynamic gzip compression in a CDN layer. |
Use s3sup inspect <filename>
to check the attributes that s3sup will set
based on your configuration settings and defaults.
Optional, usually not required. Provide manual mappings of file extensions to MIME type, which will take precedence over any automatic MIME type detection that s3sup has made. This can be useful for very modern MIME types E.g.
[mimetype_overrides]
'.woff3' = 'font/woff3'
'.oml' = 'application/oml'
The following example configuration:
- Sets all files with a cache lifetime of two minutes by default.
- Sets a longer cache lifetime on PDFs and a response header to trigger the browser to download the file rather than display it.
Example s3sup.toml
:
[aws]
region_name = 'eu-west-1'
s3_bucket_name = 'mys3websitebucket'
[[path_specific]]
path = '^.*$'
Cache-Control = 'max-age=120'
[[path_specific]]
path= '^/assets/download/[0-9]+.pdf$'
Content-Disposition = 'attachment'
Cache-Control = 'max-age=360'