aws-lambda
サーバーレスフレームワーク
サーチ…
前書き
オープンソースのアプリケーションフレームワークで、AWS Lambdaなどでサーバーレスのアーキテクチャを簡単に構築できます。このセクションでは、アプリケーション開発のためのサーバーレスフレームワークを関連する例で設定する方法について説明します。
備考
「Serverless」はフレームワークです: https : //serverless.com/
サーバレス
グローバルにサーバーレスでインストールする
npm install serverless -g
Node.jsにAWS Lamdba関数を作成する
serverless create --template aws-nodejs
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
ライブAWSアカウントにデプロイする
serverless deploy
シンプルなCRUD操作を作成する
サーバレスフレームワークを使用した簡単なCRUD操作の作成
グローバルにServerlessフレームワークをインストールする
npm install serverless -g
簡単なラムダサービスを作成する
serverless create --template aws-nodejs --path myService
含まれるmyServiceディレクトリに移動します。
- serverless.yml
- handler.js
- event.json
すべてのServerlessサービス設定はserverless.ymlによって管理されます
CRUDサービスを定義するために内容を変更してください。
serverless.ymlファイルの例
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'
このファイル定義
- ラムダ関数プログラミング言語
- ラムダ関数実行ポリシー
- Dynamodbテーブルの作成とポリシー
- HTTPエンドポイント(APIゲートウェイエンドポイント)
次に、handler.jsファイルにラムダ関数(例:node.js)を定義する必要があります。これを定義することができます。
'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);
});
};
次に、CRUD関数を定義するための新しいファイルを作成する必要があります
これらのファイルを作成する
- todos-create.js
- todos-read-all.js
- todos-read-one.js
- todos-update.js
- todos-delete.js
次に、これらの関数を各ファイルで定義します。
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);
});
};
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);
});
};
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);
});
};
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);
});
};
これらのアプリケーションを実行するには、npmの依存関係をインストールする必要があります
-
npm init
npm初期化 -
npm install aws-sdk --save
インストールしますnpm install aws-sdk --save
aws-sdkをインストールします -
npm install uuid --save
配置
これらのプロジェクトを展開することができます
cd myService
プロジェクトディレクトリにあることを確認してからコードをデプロイできます
serverless deploy
エンドポイントを使用する
あなたが正常に展開した場合は、コンソールにapi gatewayの終点名を表示してください。
エンドポイントの作成をテストする
curl -X POST https://XXXX.execute-api.region.amazonaws.com/dev/todos --data '{ "body" : "Learn Serverless" }'
読み取りエンドポイントのテスト(すべて読み取り)
curl https://XXXX.execute-api.region.amazonaws.com/dev/todos
読み取りエンドポイントのテスト(読み取り)
curl https://XXXX.execute-api.region.amazonaws.com/dev/todos/<id>
更新エンドポイントのテスト
curl -X PUT https://XXXX.execute-api.region.amazonaws.com/dev/todos/<id> --data '{ "body" : "Understand Serverless" }'
エンドポイントの削除のテスト
`curl -X DELETE https://XXXX.execute-api.region.amazonaws.com/dev/todos/<id`>