Слайд 2WHAT IS S3?
Object storage
Almost unlimited amount of data, accessible from anywhere
99.999999999% durability
data:image/s3,"s3://crabby-images/bfd71/bfd71e0824359bafb1beab43f99fa89c54740d9d" alt="WHAT IS S3? Object storage Almost unlimited amount of data, accessible from"
(that’s eleven nines!)
Cheapest way to store data on AWS
Can even host static websites
Supports BitTorrent, too
Integrates with many AWS services
Слайд 3COMMON USE CASES
Backup and recovery
Data archiving
Data lakes
Hybrid cloud storage
Cloud-native application data
data:image/s3,"s3://crabby-images/5d663/5d6638cad0cff3b3cc7d2a5e1503087c06094ca3" alt="COMMON USE CASES Backup and recovery Data archiving Data lakes Hybrid cloud storage Cloud-native application data"
Слайд 4BUCKET – CONTAINER RESOURCE
Logical resource, similar to directory
Region-specific, but has globally unique
data:image/s3,"s3://crabby-images/e4d55/e4d554db8c18f70c220aaebb4929ab2ed56d7399" alt="BUCKET – CONTAINER RESOURCE Logical resource, similar to directory Region-specific, but has"
name
Has its own set of access policies and ACLs
Has multiple bucket-wide options:
Versioning
Lifecycle management
Logging
Notifications
Cross-region replication
And many more
Слайд 5OBJECT – KEY-VALUE RESOURCE
Object is a key-value pair: key is file name,
data:image/s3,"s3://crabby-images/e4a7a/e4a7a0b789de4046efa04af6190c5fe5104b400b" alt="OBJECT – KEY-VALUE RESOURCE Object is a key-value pair: key is file"
value is the content
Can be versioned
Metadata is a set of key-value pairs that store information about an object
Has subresources, such as torrent and ACL
Each object has a storage class associated with it
Слайд 6STORAGE CLASSES
Standard (STANDARD & RRS) – default storage class
STANDARD – millisecond access
data:image/s3,"s3://crabby-images/b58c1/b58c1db1b0ea54ba781348e182430b46d00640a5" alt="STORAGE CLASSES Standard (STANDARD & RRS) – default storage class STANDARD –"
times, full durability/availability
RRS – reduced redundancy storage – is meaningless now, don’t use it
Infrequent access (STANDARD_IA & ONEZONE_IA) – for infrequently accessed files
STANDARD_IA: millisecond access times, cheaper storage, expensive requests
ONEZONE_IA: like standard, but less available/resilient, so its somewhat cheaper
Suitable for files over 128KB that you plan to store for at least 30 days
Glacier – for archiving data
Not available in real time! You need to restore objects first
Very cheap storage, very expensive requests
Слайд 7STORAGE CLASSES – IN NUMBERS
data:image/s3,"s3://crabby-images/2b02f/2b02f4e9903509cb7212d2dec899ba409bae04c7" alt="STORAGE CLASSES – IN NUMBERS"
Слайд 8VERSIONING
Off by default
Useful to prevent unintended deletions or overwrites
Once versioning is enabled,
data:image/s3,"s3://crabby-images/860d3/860d3b0ea22a4c69a327c942c38f493165d6dd25" alt="VERSIONING Off by default Useful to prevent unintended deletions or overwrites Once"
you cannot disable it (you can still suspend it)
Each object version is stored separately (takes more space)
GET request returns the latest version by default – you can specify version id to get specific version
DELETE request does not delete all versions, it just puts a delete marker as a current version. You can still permanently delete specific versions of an object
Слайд 9ACL – ACCESS CONTROL LISTS
A resource-based access policy
Applies both to buckets and
data:image/s3,"s3://crabby-images/3adf2/3adf20de83ef9b78a2cb57f41ded72d74435476c" alt="ACL – ACCESS CONTROL LISTS A resource-based access policy Applies both to"
objects, each has an ACL attached as a subresource
Works on account / group level
Can be used to grant read/write permissions to other accounts
Limitations:
Cannot be used to grant permissions to IAM users
No conditional permissions
No deny rules
Слайд 10ACL - GRANTEE
A Grantee is an entity that receives permissions
A Grantee could
data:image/s3,"s3://crabby-images/9e1d5/9e1d5b8e83a1992d9346f7f274a58fe859482f69" alt="ACL - GRANTEE A Grantee is an entity that receives permissions A"
be:
An AWS account (identified by a Canonical User Id)
A predefined group (represented by a URL):
Authenticated Users (http://acs.amazonaws.com/groups/global/AuthenticatedUsers)
All Users (http://acs.amazonaws.com/groups/global/AllUsers)
Log Delivery (http://acs.amazonaws.com/groups/s3/LogDelivery)
Слайд 11ACL - PERMISSION
Permissions describe which actions a Grantee is allowed to perform
data:image/s3,"s3://crabby-images/f2c86/f2c869768ace528ae020a4f15cf1b824980a04ba" alt="ACL - PERMISSION Permissions describe which actions a Grantee is allowed to"
on a resource
You can grant following permissions:
Слайд 13POLICIES – POLICY LANGUAGE
JSON-based documents
User policies (IAM) and Bucket policies (S3)
Policies consist
data:image/s3,"s3://crabby-images/b58c5/b58c5d12eb720d94a704ab3b5f857e7b3c514883" alt="POLICIES – POLICY LANGUAGE JSON-based documents User policies (IAM) and Bucket policies"
of following sections:
Resources: buckets and objects in S3, identified by ARN
Actions: for each resource you can define a set of operations that will be allowed or denied
Effect: allow or deny
Principal: account, user, service, or other entity affected by the policy
Condition (optional): lets you specify conditions for when your policy is in effect
Слайд 14POLICIES – AN EXAMPLE
{
"Version": "2012-10-17",
"Id": "ExamplePolicy01",
"Statement": [{
"Sid": "ExampleStatement01",
"Effect": "Allow",
"Principal": {
"AWS": "arn:aws:iam::Account-ID:user/Dave"
},
"Action": [
"s3:GetObject",
"s3:GetBucketLocation",
"s3:ListBucket"
],
"Resource":
data:image/s3,"s3://crabby-images/6a39f/6a39fb91f441ff937ce1c3b45ca49ea9ef266388" alt="POLICIES – AN EXAMPLE { "Version": "2012-10-17", "Id": "ExamplePolicy01", "Statement": [{ "Sid":"
[
"arn:aws:s3:::examplebucket/*",
"arn:aws:s3:::examplebucket"
]
}]
}
Слайд 15POLICIES – SPECIFYING RESOURCES
Resources are specified by ARN
Arn format: arn:partition:service:region:namespace:relative-id
Partition : commonly
data:image/s3,"s3://crabby-images/bce71/bce713256b83364f21fa84f8677de0276cc4963b" alt="POLICIES – SPECIFYING RESOURCES Resources are specified by ARN Arn format: arn:partition:service:region:namespace:relative-id"
just “aws”, “aws-cn” in China
Service: “s3” in our case
Region: not needed for s3
Namespace: not needed for s3
Relative-id: either bucket name or bucket-name/object-key.
You can use wildcards (* and ?), but they cannot span segments
You can also use policy variables, such as ${aws:username} (requires version 2012-10-17)
Слайд 16POLICIES – SPECIFYING PRINCIPALS
Can be an account, user, service, or other entity
To
data:image/s3,"s3://crabby-images/f1af3/f1af37c9779b14e6bd42175fa12a7a649ba45007" alt="POLICIES – SPECIFYING PRINCIPALS Can be an account, user, service, or other"
grant permissions to an account:
"Principal":{"AWS":"arn:aws:iam::accountid:root"}
"Principal":{"CanonicalUser":“canonical_user_id“}
To grant permissions to an user:
"Principal":{"AWS":"arn:aws:iam::accountid:user/username"}
To grant permissions to everyone:
"Principal":"*“
"Principal":{"AWS":"*"}
Слайд 17POLICIES – SPECIFYING PERMISSION
Permissions are keywords that map to S3 operations (GET,
data:image/s3,"s3://crabby-images/e78f3/e78f3a023a694229d161ec5b3a0c18ffd621ab88" alt="POLICIES – SPECIFYING PERMISSION Permissions are keywords that map to S3 operations"
PUT, DELETE, etc).
Format: s3:
Common Actions are: Get, Put/Create, Delete, Abort, Restore, List
Common Resources are: Object, Bucket, MultipartUpload,
Common Properties: Acl, Version, Tagging, Parts
Wildcards are allowed
Examples:
s3:ListBucket
s3:List*
s3:GetBucketAcl
s3:DeleteObjectVersion
Слайд 18POLICIES – SPECIFYING CONDITIONS
Access policies allow you to specify conditions when policy
data:image/s3,"s3://crabby-images/46be2/46be2d6e833ba369c42ca3f24a15dce1379dac09" alt="POLICIES – SPECIFYING CONDITIONS Access policies allow you to specify conditions when"
takes effect
Use Boolean operators and special expressions to match your condition against values in the request
https://docs.aws.amazon.com/AmazonS3/latest/dev/amazon-s3-policy-keys.html