README.md 2,91 ko
Newer Older
Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
<!--
title: 'Serverless Framework Node Express API on AWS'
description: 'This template demonstrates how to develop and deploy a simple Node Express API running on AWS Lambda using the Serverless Framework.'
layout: Doc
framework: v4
platform: AWS
language: nodeJS
priority: 1
authorLink: 'https://github.com/serverless'
authorName: 'Serverless, Inc.'
authorAvatar: 'https://avatars1.githubusercontent.com/u/13742415?s=200&v=4'
-->
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
# Serverless Framework Node Express API on AWS
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
This template demonstrates how to develop and deploy a simple Node Express API service running on AWS Lambda using the Serverless Framework.
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
This template configures a single function, `api`, which is responsible for handling all incoming requests using the `httpApi` event. To learn more about `httpApi` event configuration options, please refer to [httpApi event docs](https://www.serverless.com/framework/docs/providers/aws/events/http-api/). As the event is configured in a way to accept all incoming requests, the Express.js framework is responsible for routing and handling requests internally. This implementation uses the `serverless-http` package to transform the incoming event request payloads to payloads compatible with Express.js. To learn more about `serverless-http`, please refer to the [serverless-http README](https://github.com/dougmoscrop/serverless-http).
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
## Usage
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
### Deployment
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
Install dependencies with:
Akram DOUBLI's avatar
Akram DOUBLI a validé

```
Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
npm install
Akram DOUBLI's avatar
Akram DOUBLI a validé
```

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
and then deploy with:
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
```
serverless deploy
```
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
After running deploy, you should see output similar to:
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
```
Deploying "aws-node-express-api" to stage "dev" (us-east-1)
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
✔ Service deployed to stack aws-node-express-api-dev (96s)
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
endpoint: ANY - https://xxxxxxxxxx.execute-api.us-east-1.amazonaws.com
functions:
  api: aws-node-express-api-dev-api (2.3 kB)
```
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
_Note_: In current form, after deployment, your API is public and can be invoked by anyone. For production deployments, you might want to configure an authorizer. For details on how to do that, refer to [`httpApi` event docs](https://www.serverless.com/framework/docs/providers/aws/events/http-api/).
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
### Invocation
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
After successful deployment, you can call the created application via HTTP:
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
```
curl https://xxxxxxx.execute-api.us-east-1.amazonaws.com/
```
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
Which should result in the following response:
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
```json
{ "message": "Hello from root!" }
```
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
### Local development
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
The easiest way to develop and test your function is to use the `dev` command:
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
```
serverless dev
```
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
This will start a local emulator of AWS Lambda and tunnel your requests to and from AWS Lambda, allowing you to interact with your function as if it were running in the cloud.
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
Now you can invoke the function as before, but this time the function will be executed locally. Now you can develop your function locally, invoke it, and see the results immediately without having to re-deploy.
Akram DOUBLI's avatar
Akram DOUBLI a validé

Akram DOUBLI's avatar
.  
Akram DOUBLI a validé
When you are done developing, don't forget to run `serverless deploy` to deploy the function to the cloud.