Getting started with AWS.
How to build RESTful API
data:image/s3,"s3://crabby-images/b062e/b062efffb4f851e12ab2332d432c2319a4b20d34" alt=""
data:image/s3,"s3://crabby-images/e80f1/e80f1dded110f0f70c4d75d0937e753d7a398706" alt=""
data:image/s3,"s3://crabby-images/9a22d/9a22df3dadd7ed4c5271d729188ef17708c40b5e" alt=""
Dzmitry Tsebruk
Junoir Software Engineer
data:image/s3,"s3://crabby-images/e9bdc/e9bdc76057600d09336353f5c2926bf060aa805b" alt=""
AWS
Junior Developer
What is FaaS?
data:image/s3,"s3://crabby-images/e2bc3/e2bc345eb58e8eb185078db27f3313e377e3d81c" alt=""
data:image/s3,"s3://crabby-images/11b56/11b5684e64560ec8c78dd84d22d47f2f84f3d1df" alt=""
AWS Overview
data:image/s3,"s3://crabby-images/8d85d/8d85dd33147bfc49f1407652c7638c3719d4351c" alt=""
data:image/s3,"s3://crabby-images/f681d/f681ddd271d5efa7de8a806639a0131237ee34db" alt=""
Lambda
data:image/s3,"s3://crabby-images/f681d/f681ddd271d5efa7de8a806639a0131237ee34db" alt=""
data:image/s3,"s3://crabby-images/f681d/f681ddd271d5efa7de8a806639a0131237ee34db" alt=""
data:image/s3,"s3://crabby-images/f681d/f681ddd271d5efa7de8a806639a0131237ee34db" alt=""
data:image/s3,"s3://crabby-images/84731/8473100f31708cdb49e92d92ce95581ffe128483" alt=""
data:image/s3,"s3://crabby-images/247a0/247a0ff6fa304c6af4b2f329a103513dccda93a7" alt=""
Cold and Warm start
How to write Lambda Function?
exports.handler = (event, context, callback) => {
https.get(url, (res) => {
callback(null, res.statusCode)
}).on('error', (e) => {
callback(Error(e))
})
}
exports.handler = async (event) => {
return new Promise((resolve, reject) => {
if (Math.random() * 2 ^ 0) {
resolve();
} else {
reject();
}
});
}
or
exports.handler = async (event) => {
return https.get(url).promise();
}
or
Livecoding
IAM
data:image/s3,"s3://crabby-images/f8b9d/f8b9dc0f7fe0b0656cd85615abd4e0d915a08947" alt=""
Livecoding
API Gateway
data:image/s3,"s3://crabby-images/a8212/a8212f4916d8535b44bd0893e8368647baa24de8" alt=""
Livecoding
Ways to manage AWS
AWS CLI usage example
# aws lambda invoke \
--function-name <value> \
<outfile>
Livecoding
Terminal
AWS SDK usage example
var lambda = new AWS.Lambda();
lambda.addLayerVersionPermission(params, function (err, data) {
if (err) console.log(err, err.stack); // an error occurred
else console.log(data); // successful response
});
var lambda = new AWS.Lambda();
lambda.addLayerVersionPermission(params).promise();
or
Database Services
data:image/s3,"s3://crabby-images/035c1/035c1fbc5de011a38ac1c55fd8004fbb0d0cb2e5" alt=""
Livecoding
AWS Free Tier
Free Tier Details
Billing Dashboard
data:image/s3,"s3://crabby-images/25f23/25f2341dffc790ad7ad40646fe7f2e94b666cbdc" alt=""
Billing Dashboard
data:image/s3,"s3://crabby-images/2ee3b/2ee3bcdb6c8bf4df9d8883d1c2634395bec77d1f" alt=""
Pros & Cons
Pros
- Cheap cost
- Auto scalable
- You can make simple things easily
Cons
- You should track what happens
- Сomplex architecture
- It's hard to make tests
- Steep learning curve
Serverless Framework
Install framework and setup credentials
# npm install -g serverless
serverless.yml
service: aws-rest-ful-api
custom:
tableName: 'table-notes-${self:provider.stage}'
dynamodb:
start:
migrate: true
provider:
name: aws
runtime: nodejs8.10
stage: dev
region: us-east-1
environment:
NOTES_TABLE: ${self:custom.tableName}
serverless.yml
functions:
create:
handler: src/handler.create
events:
- http:
path: notes
method: post
cors: true
getAll:
handler: src/handler.getAll
events:
- http:
path: notes
method: get
cors: true
delete:
handler: src/handler.delete
events:
- http:
path: notes/{id}
method: delete
cors: true
...
serverless.yml
resources:
Resources:
NotesDynamoDBTable:
Type: 'AWS::DynamoDB::Table'
Properties:
AttributeDefinitions:
-
AttributeName: id
AttributeType: S
KeySchema:
-
AttributeName: id
KeyType: HASH
ProvisionedThroughput:
ReadCapacityUnits: 1
WriteCapacityUnits: 1
TableName: ${self:custom.tableName}
serverless.yml
NotesDynamoDBIamPolicy:
Type: AWS::IAM::Policy
DependsOn: NotesDynamoDBTable
Properties:
PolicyName: lambda-dynamodb
PolicyDocument:
Version: '2012-10-17'
Statement:
- Effect: Allow
Action:
- dynamodb:Query
- dynamodb:Scan
- dynamodb:GetItem
- dynamodb:PutItem
- dynamodb:UpdateItem
- dynamodb:DeleteItem
Resource: arn:aws:dynamodb:*:*:table/${self:custom.tableName}
Roles:
- Ref: IamRoleLambdaExecution
How to build RESTful API
src/handler.js
const AWS = require('aws-sdk');
const uuidv1 = require('uuid/v1');
const message = require('./message');
const dynamoDb = new AWS.DynamoDB.DocumentClient();
const { NOTES_TABLE } = process.env;
module.exports.create = async (event) => {
...
};
module.exports.getOne = async (event) => {
...
};
module.exports.getAll = async () => {
...
};
module.exports.update = async (event) => {
...
};
module.exports.delete = async (event) => {
...
};
src/handler.js
module.exports.getOne = async (event) => {
const { id } = event.pathParameters;
const params = {
TableName: NOTES_TABLE,
Key: {
id,
},
};
return new Promise((resolve) => {
dynamoDb.get(params, (error, result) => {
if (error) {
global.console.log(error);
message(400, 'Could not get the note!', resolve);
}
if (result.Item) {
message(200, JSON.stringify(result.Item), resolve);
} else {
message(404, 'Note is not found', resolve);
}
});
});
};
src/message.js
module.exports = (statusCode, body, callback) => {
const message = {
statusCode,
body,
};
message.headers = {
'Access-Control-Allow-Origin': '*',
'Access-Control-Allow-Credentials': true,
};
if (statusCode !== 200) {
message.headers['Content-Type'] = 'text/plain';
}
callback(message);
};
Deploying
# serverless deploy
Deploying
data:image/s3,"s3://crabby-images/43fb8/43fb8e7ca70fbdd481dbd2b71b1b995ed8580eea" alt=""
Now we can use endpoints ...
Thank You!
Links
- https://github.com/mikhama
- https://github.com/mikhama/aws-rest-ful-api
- https://aws.amazon.com/free/
- https://console.aws.amazon.com/billing/home
- https://docs.aws.amazon.com/cli/latest/reference/
- https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/
- https://serverless.com/framework/docs/providers/aws/guide/quick-start/
- https://serverless.com/framework/docs/providers/aws/guide/credentials/
Q&A
AWS
By Dzmitry Tsebruk
AWS
- 269