aws-lambda
Serverloos Framework
Zoeken…
Invoering
Het open-source toepassingskader om eenvoudig serverloze architecturen te bouwen op AWS Lambda & meer. Dit gedeelte bevat informatie over het instellen van een serverloos framework voor applicatie-ontwikkeling met relevante voorbeelden.
Opmerkingen
"Serverless" is een framework: https://serverless.com/
Serverless
Wereldwijd serverloos installeren
npm install serverless -g
Maak een AWS Lamdba-functie in Node.js
serverless create --template aws-nodejs
Voorbeeld van een handler.js
'use strict'; // Your first function handler module.exports.hello = (event, context, cb) => cb(null, { message: 'Go Serverless v1.0! Your function executed successfully!', event } ); // You can add more handlers here, and reference them in serverless.yml
Implementeren naar live AWS-account
serverless deploy
Maak eenvoudige CRUD-bewerking
Maak eenvoudige CRUD-bewerking met behulp van Serverless Framework
Installeer Serverless framework wereldwijd
npm install serverless -g
Maak een eenvoudige Lambda-service
serverless create --template aws-nodejs --path myService
Ga naar de myService-directory die het zou moeten bevatten
- serverless.yml
- handler.js
- event.json
Alle serverloze serviceconfiguratie wordt beheerd door serverless.yml
Wijzig de inhoud om de CRUD-service te definiëren.
Voorbeeld serverless.yml-bestand
service: serverless-crud
provider:
name: aws
runtime: nodejs4.3
region: us-east-1
stage: dev
iamRoleStatements:
- Effect: Allow
Action:
- dynamodb:DescribeTable
- dynamodb:Query
- dynamodb:Scan
- dynamodb:GetItem
- dynamodb:PutItem
- dynamodb:UpdateItem
- dynamodb:DeleteItem
Resource: "arn:aws:dynamodb:us-east-1:*:*"
functions:
create:
handler: handler.create
events:
- http:
path: todos
method: post
cors: true
readAll:
handler: handler.readAll
events:
- http:
path: todos
method: get
cors: true
readOne:
handler: handler.readOne
events:
- http:
path: todos/{id}
method: get
cors: true
update:
handler: handler.update
events:
- http:
path: todos/{id}
method: put
cors: true
delete:
handler: handler.delete
events:
- http:
path: todos/{id}
method: delete
cors: true
resources:
Resources:
TodosDynamoDbTable:
Type: 'AWS::DynamoDB::Table'
DeletionPolicy: Retain
Properties:
AttributeDefinitions:
-
AttributeName: id
AttributeType: S
KeySchema:
-
AttributeName: id
KeyType: HASH
ProvisionedThroughput:
ReadCapacityUnits: 1
WriteCapacityUnits: 1
TableName: 'todos'
Dit bestand definieert
- Lambda-functie programmeertaal
- Lambda-functie uitvoeringsbeleid
- Dynamodb-tabellen maken en het beleid
- HTTP-eindpunt (API Gateway End Point)
Vervolgens moet u de lambdafunctie (ex. Node.js) in het bestand handler.js definiëren, u kunt deze definiëren.
'use strict';
const todosCreate = require('./todos-create.js');
const todosReadAll = require('./todos-read-all.js');
const todosReadOne = require('./todos-read-one.js');
const todosUpdate = require('./todos-update.js');
const todosDelete = require('./todos-delete.js');
module.exports.create = (event, context, callback) => {
todosCreate(event, (error, result) => {
const response = {
statusCode: 200,
headers: {
"Access-Control-Allow-Origin" : "*"
},
body: JSON.stringify(result),
};
context.succeed(response);
});
};
module.exports.readAll = (event, context, callback) => {
todosReadAll(event, (error, result) => {
const response = {
statusCode: 200,
headers: {
"Access-Control-Allow-Origin" : "*"
},
body: JSON.stringify(result),
};
context.succeed(response);
});
};
module.exports.readOne = (event, context, callback) => {
todosReadOne(event, (error, result) => {
const response = {
statusCode: 200,
headers: {
"Access-Control-Allow-Origin" : "*"
},
body: JSON.stringify(result),
};
context.succeed(response);
});
};
module.exports.update = (event, context, callback) => {
todosUpdate(event, (error, result) => {
const response = {
statusCode: 200,
headers: {
"Access-Control-Allow-Origin" : "*"
},
body: JSON.stringify(result),
};
context.succeed(response);
});
};
module.exports.delete = (event, context, callback) => {
todosDelete(event, (error, result) => {
const response = {
statusCode: 200,
headers: {
"Access-Control-Allow-Origin" : "*"
},
body: JSON.stringify(result),
};
context.succeed(response);
});
};
Vervolgens moet u nieuwe bestanden maken om uw CRUD-functies te definiëren
Maak deze bestanden aan
- todos-create.js
- todos-read-all.js
- todos-read-one.js
- todos-update.js
- todos-delete.js
Definieer vervolgens deze functies in elk bestand.
voor todos-create.js
'use strict';
const AWS = require('aws-sdk');
const dynamoDb = new AWS.DynamoDB.DocumentClient();
const uuid = require('uuid');
module.exports = (event, callback) => {
const data = JSON.parse(event.body);
data.id = uuid.v1();
data.updatedAt = new Date().getTime();
const params = {
TableName: 'todos',
Item: data
};
return dynamoDb.put(params, (error, data) => {
if (error) {
callback(error);
}
callback(error, params.Item);
});
};
Voor todos-read-all.js
'use strict';
const AWS = require('aws-sdk');
const dynamoDb = new AWS.DynamoDB.DocumentClient();
module.exports = (event, callback) => {
const params = {
TableName: 'todos',
};
return dynamoDb.scan(params, (error, data) => {
if (error) {
callback(error);
}
callback(error, data.Items);
});
};
For todos-read-one.js <br>
'use strict';
const AWS = require('aws-sdk');
const dynamoDb = new AWS.DynamoDB.DocumentClient();
module.exports = (event, callback) => {
const params = {
TableName: 'todos',
Key: {
id: event.pathParameters.id
}
};
return dynamoDb.get(params, (error, data) => {
if (error) {
callback(error);
}
callback(error, data.Item);
});
};
Voor todos-update.js
'use strict';
const AWS = require('aws-sdk');
const dynamoDb = new AWS.DynamoDB.DocumentClient();
module.exports = (event, callback) => {
const data = JSON.parse(event.body);
data.id = event.pathParameters.id;
data.updatedAt = new Date().getTime();
const params = {
TableName : 'todos',
Item: data
};
return dynamoDb.put(params, (error, data) => {
if (error) {
callback(error);
}
callback(error, params.Item);
});
};
Voor todos-delete.js
'use strict';
const AWS = require('aws-sdk');
const dynamoDb = new AWS.DynamoDB.DocumentClient();
module.exports = (event, callback) => {
const params = {
TableName : 'todos',
Key: {
id: event.pathParameters.id
}
};
return dynamoDb.delete(params, (error, data) => {
if (error) {
callback(error);
}
callback(error, params.Key);
});
};
Voor het uitvoeren van deze applicatie heb je npm-afhankelijkheden nodig
-
npm init
npm initialisatie -
npm install aws-sdk --save
aws-sdk -
npm install uuid --save
Deployment
Nu kunt u deze projecten inzetten
cd myService
verifieert dat u zich in de projectmap bevindt en vervolgens uw code kunt implementeren
serverless deploy
Gebruik eindpunt
Als u met succes bent geïmplementeerd, ziet u de namen van api-gateway-eindpunten in uw console.
Test Maak Eindpunt
curl -X POST https://XXXX.execute-api.region.amazonaws.com/dev/todos --data '{ "body" : "Learn Serverless" }'
Test voor gelezen eindpunt (Alles lezen)
curl https://XXXX.execute-api.region.amazonaws.com/dev/todos
Test voor Read End Point (Read One)
curl https://XXXX.execute-api.region.amazonaws.com/dev/todos/<id>
Test voor update- eindpunt
curl -X PUT https://XXXX.execute-api.region.amazonaws.com/dev/todos/<id> --data '{ "body" : "Understand Serverless" }'
Test voor eindpunt verwijderen
`curl -X DELETE https://XXXX.execute-api.region.amazonaws.com/dev/todos/<id`>