Skip to main content

Pythonic Microservices on AWS Lambda

Project description

Psychic Disco

  • Are you a poor dope with a program to deploy?

  • Need to produce a demo, but haven’t yet hit pay dirt?

  • Love python development, but not product delivery?

Then let Psychic Disco be your principal delegate for publicly displaying your work!

By leveraging the pioneering domains of AWS Lambda and the Serverless Web, Psychic Disco allows even plebian dummies like you and I to scale the platforms of our dreams on the cheap.

Stinking Badges

https://travis-ci.org/robertdfrench/psychic-disco.svg?branch=master https://coveralls.io/repos/github/robertdfrench/psychic-disco/badge.svg?branch=master

Installing

Install like so:

pip install psychic_disco

Assumptions

  • All your microservices live in python modules

  • All your entrypoints are decorated with @lambda_entry_point

Declaring Entrypoints and API methods

Make a new entrypoint:

@lambda_entry_point
def handler(event, context):
  # important code here

Making a new api method automatically registers the entrypoint:

@api_method("POST", "/cereal"):
def create_cereal(event, context):
  # cereal creation logic here

Definitions for your API methods are available in psychic_disco.Api.

Discovering Entrypoints

Do this thing:

psychic_disco discover_entrypoints

Or, if your code lives elsewhere:

psychic_disco --repo path/to/st/elsewhere discover_entrypoints

Creating a Deployment Package

Do this thing:

psychic_disco bundle

That will make a virtualenv, install your dependencies, and zip it all up for you. This assumes that you have psychic_disco.config.default_s3_bucket defined in your psychic_disco_config.py

Deploying Lambda Functions

Once a deployment package has been uploaded to Amazon S3, you can install the lambda functions you defined like so:

psychic_disco deploy_lambdas

This assumes that you have psychic_disco.config.default_iam_role defined in your psychic_disco_config.py

Querying AWS

You can see what has already been configured on AWS by running:

psychic_disoc show_installed_routes <api-name>

Which will output something like:

verb

path

lambda-function

GET

/users

users-list_all

POST

/users

users-create_new

PATCH

/user/7

users-update

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

psychic_disco-0.10.0.tar.gz (9.5 kB view details)

Uploaded Source

File details

Details for the file psychic_disco-0.10.0.tar.gz.

File metadata

File hashes

Hashes for psychic_disco-0.10.0.tar.gz
Algorithm Hash digest
SHA256 ab2189a7bab2f06c8aa5308e329e4980d7f554063924289d9a8eecb52f9546aa
MD5 30ee76cf7a9a38908866adc7520dfb4e
BLAKE2b-256 026d82fd0a7de983398d7192ef9f2ff08646b1ad86b079a223d947a812cfb622

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page