Skip to main content

A CLI to install the New Relic AWS Lambda integration and layers.

Project description

A CLI to install the New Relic AWS Lambda integration and layers.

Features

  • Installs the New Relic AWS Lambda integration onto your AWS account

  • Installs and configures a New Relic AWS Lambda layer onto your AWS Lambda functions

  • Automatically selects the correct New Relic layer for your function’s runtime and region

  • Wraps your AWS Lambda functions without requiring a code change

  • Supports Node.js and Python AWS LAmbda runtimes

  • Easily uninstall the AWS Lambda layer with a single command

Runtimes Supported

  • nodejs10.x

  • nodejs12.x

  • python2.7

  • python3.6

  • python3.7

  • python3.8

Requirements

Recommendations

  • Install the AWS CLI and configure your environment with aws configure

Installation

pip install newrelic-lambda-cli

Or clone this repo and run:

python setup.py install

To update the CLI, run:

pip install --upgrade newrelic-lambda-cli

Usage

AWS Lambda Integration

Install Integration

In order to instrument your AWS Lambda functions using New Relic you must first install the New Relic AWS Lambda integration and the log ingestion function in the AWS region in which your Lambda functions are located. If you have Lambda functions located in multiple regions you can run the command multiple times specifying the AWS regions with --aws-region <your aws region here>. This command only needs to be run once per AWS region. By default this command will look for a default AWS profile configured via the AWS CLI.

newrelic-lambda integrations install \
    --nr-account-id <account id> \
    --nr-api-key <api key> \
    --linked-account-name <linked account name>

Option

Required?

Description

--nr-account- id or -a

Yes

The New Relic Account ID for this integration. Can also use the NEW_RELIC_ACCOUNT_ID environment variable.

--nr-api-key` ` or ``-k

Yes

Your New Relic User API Key _. Can also use the NEW_RELIC_API_KEY environment variable.

--linked-acco unt-name or -l

Yes

A label for the New Relic Linked ACcount. This is how this integration will appear in New Relic.

--nr-region

No

The New Relic region to use for the integration. Can use the NEW_RELIC_REGION environment variable. Defaults to us.

--aws-profile `` or ``-p

No

The AWS profile to use for this command. Can also use AWS_PROFILE. Will also check AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY environment variables if not using AWS CLI.

--aws-region` ` or ``-r

No

The AWS region for the integration. Can use AWS_DEFAULT_REGION environment variable. Defaults to AWS session region.

--aws-role-po licy

No

Specify an alternative IAM role policy ARN for this integration.

Uninstall Integration

newrelic-lambda integrations uninstall

Option

Required?

Description

--aws-profile `` or ``-p

No

The AWS profile to use for this command. Can also use AWS_PROFILE. Will also check AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY environment variables if not using AWS CLI.

--aws-region` ` or ``-r

No

The AWS region for the integration. Can use AWS_DEFAULT_REGION environment variable. Defaults to AWS session region.

AWS Lambda Layers

Install Layer

newrelic-lambda layers install \
    --function <name or arn> \
    --nr-account-id <new relic account id>

Option

Required?

Description

--function or -f

Yes

The AWS Lambda function name or ARN in which to add a layer.

--nr-account- id or -a

Yes

The New Relic Account ID this function should use. Can also use the NEW_RELIC_ACCOUNT_ID environment variable.

--layer-arn or -l

No

Specify a specific layer version ARN to use. This is auto detected by default.

--upgrade or -u

No

Permit upgrade to the latest layer version for this region and runtime.

--aws-profile `` or ``-p

No

The AWS profile to use for this command. Can also use AWS_PROFILE. Will also check AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY environment variables if not using AWS CLI.

--aws-region` ` or ``-r

No

The AWS region this function is located. Can use AWS_DEFAULT_REGION environment variable. Defaults to AWS session region.

Uninstall Layer

newrelic-lambda layers uninstall --function <name or arn>

Option

Required?

Description

--function or -f

Yes

The AWS Lambda function name or ARN in which to remove a layer.

--layer-arn or -l

No

Specify a specific layer version ARN to remove. This is auto detected by default.

--aws-profile `` or ``-p

No

The AWS profile to use for this command. Can also use AWS_PROFILE. Will also check AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY environment variables if not using AWS CLI.

--aws-region` ` or ``-r

No

The AWS region this function is located. Can use AWS_DEFAULT_REGION environment variable. Defaults to AWS session region.

AWS Lambda Functions

List Functions

newrelic-lambda functions list

List functions with layer installed:

newrelic-lambda functions list --filter installed

Option

Required?

Description

--filter or -f

No

Filter to be applied to list of functions. Options are all, installed and not-installed. Defaults to all.

--aws-profile `` or ``-p

No

The AWS profile to use for this command. Can also use AWS_PROFILE. Will also check AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY environment variables if not using AWS CLI.

--aws-region` ` or ``-r

No

The AWS region to use for htis command. Can use AWS_DEFAULT_REGION environment variable. Defaults to AWS session region.

NewRelic Log Subscription

Install Log Subscription

newrelic-lambda subscriptions install \--function <name or arn>

Option

Required?

Description

--function or -f

Yes

The AWS Lambda function name or ARN in which to add a log subscription.

--aws-profile `` or ``-p

No

The AWS profile to use for this command. Can also use AWS_PROFILE. Will also check AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY environment variables if not using AWS CLI.

--aws-region` ` or ``-r

No

The AWS region this function is located. Can use AWS_DEFAULT_REGION environment variable. Defaults to AWS session region.

Uninstall Log Subscription

newrelic-lambda subscriptions uninstall --function <name or arn>

Option

Required?

Description

--function or -f

Yes

The AWS Lambda function name or ARN in which to remove a log subscription.

--aws-profile `` or ``-p

No

The AWS profile to use for this command. Can also use AWS_PROFILE. Will also check AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY environment variables if not using AWS CLI.

--aws-region` ` or ``-r

No

The AWS region this function is located. Can use AWS_DEFAULT_REGION environment variable. Defaults to AWS session region.

Contributing

We welcome code contributions (in the form of pull requests) from our user community. Before submitting a pull request please review these guidelines.

Following these helps us efficiently review and incorporate your contribution and avoid breaking your code with future changes to the agent.

Code style

We use the black code formatter.

pip install black

We recommend using it with pre-commit:

pip install pre-commit
pre-commit install

Using these together will auto format your git commits.

Running Tests

python setup.py test

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

newrelic-lambda-cli-0.1.4.tar.gz (25.3 kB view hashes)

Uploaded Source

Supported by

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