AWS Chalice

面向 AWS 的 Python 无服务器微框架。Chalice 是一个用 Python 编写无服务器应用程序的框架。它允许您快速创建和部署使用 AWS Lambda 的应用程序。「Python Serverless Microframework for AWS. Chalice is a framework for writing serverless apps in python. It allows you to quickly create and deploy applications that use AWS Lambda.」

Github星跟踪图

AWS Chalice

Gitter

Documentation Status

Chalice Logo

Chalice is a framework for writing serverless apps in python. It allows
you to quickly create and deploy applications that use AWS Lambda. It
provides:

  • A command line tool for creating, deploying, and managing your app
  • A decorator based API for integrating with Amazon API Gateway,
    Amazon S3, Amazon SNS, Amazon SQS, and other AWS services.
  • Automatic IAM policy generation

You can create Rest APIs:

from chalice import Chalice

app = Chalice(app_name="helloworld")

@app.route("/")
def index():
    return {"hello": "world"}

Tasks that run on a periodic basis:

from chalice import Chalice, Rate

app = Chalice(app_name="helloworld")

# Automatically runs every 5 minutes
@app.schedule(Rate(5, unit=Rate.MINUTES))
def periodic_task(event):
    return {"hello": "world"}

You can connect a lambda function to an S3 event:

from chalice import Chalice

app = Chalice(app_name="helloworld")

# Whenever an object is uploaded to 'mybucket'
# this lambda function will be invoked.

@app.on_s3_event(bucket='mybucket')
def handler(event):
    print("Object uploaded for bucket: %s, key: %s"
          % (event.bucket, event.key))

As well as an SQS queue:

from chalice import Chalice

app = Chalice(app_name="helloworld")

# Invoke this lambda function whenever a message
# is sent to the ``my-queue-name`` SQS queue.

@app.on_sqs_message(queue='my-queue-name')
def handler(event):
    for record in event:
        print("Message body: %s" % record.body)

And several other AWS resources.

Once you've written your code, you just run chalice deploy and
Chalice takes care of deploying your app.

$ chalice deploy
...
https://endpoint/dev

$ curl https://endpoint/api
{"hello": "world"}

Up and running in less than 30 seconds. Give this project a try and
share your feedback with us here on Github.

The documentation is available here.

Quickstart

In this tutorial, you'll use the chalice command line utility to
create and deploy a basic REST API. This quickstart uses Python 3.7, but
AWS Chalice supports all versions of python supported by AWS Lambda,
which includes python3.6, python3.7, python3.8, python3.9, python3.10,
python3.11. You can find the latest versions of python on the Python
download page
.

To install Chalice, we'll first create and activate a virtual
environment in python3.7:

$ python3 --version
Python 3.7.3
$ python3 -m venv venv37
$ . venv37/bin/activate

Next we'll install Chalice using pip:

$ python3 -m pip install chalice

You can verify you have chalice installed by running:

$ chalice --help
Usage: chalice [OPTIONS] COMMAND [ARGS]...
...

Credentials

Before you can deploy an application, be sure you have credentials
configured. If you have previously configured your machine to run boto3
(the AWS SDK for Python) or the AWS CLI then you can skip this section.

If this is your first time configuring credentials for AWS you can
follow these steps to quickly get started:

$ mkdir ~/.aws
$ cat >> ~/.aws/config
[default]
aws_access_key_id=YOUR_ACCESS_KEY_HERE
aws_secret_access_key=YOUR_SECRET_ACCESS_KEY
region=YOUR_REGION (such as us-west-2, us-west-1, etc)

If you want more information on all the supported methods for
configuring credentials, see the boto3
docs
.

Creating Your Project

The next thing we'll do is use the chalice command to create a new
project:

$ chalice new-project helloworld

This will create a helloworld directory. Cd into this directory.
You'll see several files have been created for you:

$ cd helloworld
$ ls -la
drwxr-xr-x   .chalice
-rw-r--r--   app.py
-rw-r--r--   requirements.txt

You can ignore the .chalice directory for now, the two main files
we'll focus on is app.py and requirements.txt.

Let's take a look at the app.py file:

from chalice import Chalice

app = Chalice(app_name='helloworld')


@app.route('/')
def index():
    return {'hello': 'world'}

The new-project command created a sample app that defines a single
view, /, that when called will return the JSON body
{"hello": "world"}.

Deploying

Let's deploy this app. Make sure you're in the helloworld directory
and run chalice deploy:

$ chalice deploy
Creating deployment package.
Creating IAM role: helloworld-dev
Creating lambda function: helloworld-dev
Creating Rest API
Resources deployed:
  - Lambda ARN: arn:aws:lambda:us-west-2:12345:function:helloworld-dev
  - Rest API URL: https://abcd.execute-api.us-west-2.amazonaws.com/api/

You now have an API up and running using API Gateway and Lambda:

$ curl https://qxea58oupc.execute-api.us-west-2.amazonaws.com/api/
{"hello": "world"}

Try making a change to the returned dictionary from the index()
function. You can then redeploy your changes by running
chalice deploy.

Next Steps

You've now created your first app using chalice. You can make
modifications to your app.py file and rerun chalice deploy to
redeploy your changes.

At this point, there are several next steps you can take.

  • Tutorials

    - Choose from among several guided tutorials that will give you
    step-by-step examples of various features of Chalice.

  • Topics - Deep
    dive into documentation on specific areas of Chalice. This contains
    more detailed documentation than the tutorials.

  • API Reference - Low level
    reference documentation on all the classes and methods that are part
    of the public API of Chalice.

If you're done experimenting with Chalice and you'd like to cleanup,
you can use the chalice delete command, and Chalice will delete all
the resources it created when running the chalice deploy command.

$ chalice delete
Deleting Rest API: abcd4kwyl4
Deleting function aws:arn:lambda:region:123456789:helloworld-dev
Deleting IAM Role helloworld-dev

Feedback

We'd also love to hear from you. Please create any Github issues for
additional features you'd like to see over at
https://github.com/aws/chalice/issues. You can also chat with us on
gitter: https://gitter.im/awslabs/chalice

主要指标

概览
名称与所有者aws/chalice
主编程语言Python
编程语言Makefile (语言数: 3)
平台
许可证Apache License 2.0
所有者活动
创建于2016-05-27 23:27:13
推送于2025-05-29 16:45:37
最后一次提交2025-05-29 15:43:55
发布数95
最新版本名称1.32.0 (发布于 2025-05-29 15:43:56)
第一版名称0.0.1 (发布于 2016-07-11 13:14:18)
用户参与
星数10.9k
关注者数235
派生数1k
提交数2.5k
已启用问题?
问题数1245
打开的问题数418
拉请求数637
打开的拉请求数68
关闭的拉请求数184
项目设置
已启用Wiki?
已存档?
是复刻?
已锁定?
是镜像?
是私有?