Skip to content

Latest commit

 

History

History
89 lines (61 loc) · 2.93 KB

File metadata and controls

89 lines (61 loc) · 2.93 KB

Deploy

Serverless URL Shortener with Redis Cache and HttpServer

A sample URL shortener SPA that uses the high-level cloud.Table and cloud.HttpServer components. The example shows to combine serverless functions along with containers. This shows that you can create your own cloud.*-like abstractions for your own use, your team's, or to share with the community using your language's package manager.

Deploying and running the program

Note: some values in this example will be different from run to run. These values are indicated with ***.

  1. Create a new stack:

    $ pulumi stack init url-cache-testing
    
  2. Set AWS or Azure as the provider:

    $ pulumi config set cloud:provider aws
    # or
    $ pulumi config set cloud:provider azure
    
  3. If using AWS configure Pulumi to use AWS Fargate, which is currently only available in us-east-1, us-east-2, us-west-2, and eu-west-1:

    $ pulumi config set aws:region us-west-2
    $ pulumi config set cloud-aws:useFargate true
    
  4. If using Azure set an appropriate location like:

    $ pulumi config set cloud-azure:location "West US 2"
    
  5. Set a value for the Redis password. The value can be an encrypted secret, specified with the --secret flag. If this flag is not provided, the value will be saved as plaintext in Pulumi.url-cache-testing.yaml (since url-cache-testing is the current stack name).

    $ pulumi config set --secret redisPassword S3cr37Password
    
  6. Add the 'www' directory to the uploaded function code so it can be served from the http server:

    $ pulumi config set cloud-aws:functionIncludePaths
    #or
    $ pulumi config set cloud-azure:functionIncludePaths
    
  7. Restore NPM modules via npm install or yarn install.

  8. Compile the program via tsc or npm run build or yarn run build.

  9. Preview and run the deployment via pulumi update. The operation will take about 5 minutes to complete.

    $ pulumi update
    Previewing stack 'url-cache-testing'
    ...
    
    Updating stack 'url-cache-testing'
    Performing changes:
    
    #:  Resource Type                            Name
    1:  pulumi:pulumi:Stack                      url-shortener-cache-url-
    ...
    49: aws:apigateway:Stage                     urlshortener
    
    info: 49 changes performed:
        + 49 resources created
    Update duration: ***
    
  10. To view the API endpoint, use the stack output command:

    $ pulumi stack output endpointUrl
    https://***.us-east-1.amazonaws.com/stage/
    
  11. Open this page in a browser and you'll see a single page app for creating and viewing short URLs.

Clean up

To clean up resources, run pulumi destroy and answer the confirmation question at the prompt.