A CLI to install the New Relic AWS Lambda integration and layers.
- Features
- Runtimes Supported
- Requirements
- Recommendations
- Installation
- Usage
- Docker
- Contributing
- Code Style
- Running Tests
- Troubleshooting
- 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
- nodejs10.x
- nodejs12.x
- python2.7
- python3.6
- python3.7
- python3.8
- Python >= 3.3
- Retrieve your New relic Account ID and User API Key
- Install the AWS CLI and configure your environment with
aws configure
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
Note: You may need to use python3
and/or pip3
in the commands above if you have Python 2.7 installed.
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-account-name or -l |
Yes | A label for the New Relic Linked Account. This is how this integration will appear in New Relic. |
--enable-logs or -e |
No | Enables forwarding logs to New Relic Logging. This is disabled by default. Make sure you run newrelic-lambda subscriptions install --function ... --filter-pattern "" afterwards. |
--memory-size or -m |
No | Memory size (in MiB) for the New Relic log ingestion function. Default to 128MB. |
--nr-region |
No | The New Relic region to use for the integration. Can use the NEW_RELIC_REGION environment variable. Can be either eu or us . Defaults to us . |
--timeout or -t |
No | Timeout (in seconds) for the New Relic log ingestion function. Defaults to 30 seconds. |
--role-name |
No | Role name for the ingestion function. If you prefer to create and manage an IAM role for the function to assume out of band, do so and specify that role's name here. This avoids needing CAPABILITY_IAM. |
--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-policy |
No | Specify an alternative IAM role policy ARN for this 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. |
--force or -f |
No | Forces uninstall non-interactively |
--nr-account-id or -a |
No | The New Relic Account ID for the integration. Only required if also uninstalling the New Relic AWS Lambda integration. Can also use the NEW_RELIC_ACCOUNT_ID environment variable. |
Updates the New Relic log ingestion function to the latest version. Existing ingestion function parameters will retain their values, unless you specify different values on the command line.
newrelic-lambda integrations update
Option | Required? | Description |
---|---|---|
--nr-account-id or -a |
No | The New Relic Account ID for the integration. Only required if changing the account to which the logs are sent. Can also use the NEW_RELIC_ACCOUNT_ID environment variable. |
--nr-api-key or -k |
No | Your New Relic User API Key. Can also use the NEW_RELIC_API_KEY environment variable. Only required if changing the account to which the logs are sent. |
--disable-logs or -d |
No | Disables forwarding logs to New Relic Logging. Make sure you run newrelic-lambda subscriptions install --function ... afterwards. |
--enable-logs or -e |
No | Enables forwarding logs to New Relic Logging. Make sure you run newrelic-lambda subscriptions install --function ... --filter-pattern "" afterwards. |
--memory-size or -m |
No | Memory size (in MiB) for the New Relic log ingestion function. |
--nr-region |
No | The New Relic region to use for the integration. Can use the NEW_RELIC_REGION environment variable. Can be either eu or us . Defaults to us . |
--timeout or -t |
No | Timeout (in seconds) for the New Relic log ingestion function. |
--role-name |
No | Role name for the ingestion function. If you prefer to create and manage an IAM role for the function to assume out of band, do so and specify that role's name here. This avoids needing CAPABILITY_IAM. |
--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. |
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. Can provide multiple --function arguments. Will also accept all , installed and not-installed similar to newrelic-lambda functions list . |
--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. |
--exclude or -e |
No | A function name to exclude while installing layers. Can provide multiple --exclude arguments. Only checked when all , installed and not-installed are used. See newrelic-lambda functions list for function names. |
--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. |
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. Can provide multiple --function arguments. Will also accept all , installed and not-installed similar to newrelic-lambda functions list . |
--exclude or -e |
No | A function name to exclude while uninstalling layers. Can provide multiple --exclude arguments. Only checked when all , installed and not-installed are used. See newrelic-lambda functions list for function names. |
--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. |
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 . |
--output or -o |
No | Specify the desired output format. Supports table and text . Defaults to table . |
--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 this command. Can use AWS_DEFAULT_REGION environment variable. Defaults to AWS session region. |
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. Can provide multiple --function arguments. Will also accept all , installed and not-installed similar to newrelic-lambda functions list . |
--exclude or -e |
No | A function name to exclude while installing subscriptions. Can provide multiple --exclude arguments. Only checked when all , installed and not-installed are used. See newrelic-lambda functions list for function names. |
--filter-pattern |
No | Specify a custom log subscription filter pattern. To collect all logs use --filter_pattern "" . |
--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. |
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. Can provide multiple --function arguments. Will also accept all , installed and not-installed similar to newrelic-lambda functions list . |
--exclude or -e |
No | A function name to exclude while uninstalling subscriptions. Can provide multiple --exclude arguments. Only checked when all , installed and not-installed are used. See newrelic-lambda functions list for function names. |
--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. |
Now, you can run newrelic-lambda-cli as a container.
docker build -t newrelic-lambda-cli .
docker run -e AWS_PROFILE=your_profile -v $HOME/.aws:/home/newrelic-lambda-cli/.aws newrelic-lambda-cli functions list
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.
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.
python setup.py test
Upgrade the CLI: A good first step, as we push updates frequently.
pip install --upgrade newrelic-lambda-cli
UnrecognizedClientException:
(UnrecognizedClientException) when calling the GetFunction operation: The security token included in the request is invalid.
If you see this error, it means that specifying the region is necessary, and you need to supply the --aws-region
flag to your command.
Unable to locate credentials:
Function: None, Region: None, Error: Failed to set up lambda integration: 'Unable to locate credentials. You can configure credentials by running "aws configure".'
- The AWS profile may not be properly configured; review documentation to Configure your AWS Profile (make sure the default region is set!).
- If there are multiple AWS profiles and the correct one is not specified, you can run
export AWS_DEFAULT_PROFILE=MY_OTHER_PROFILE
to set the environment variable to the proper profile.
SimulatePrincipalPolicy:
botocore.errorfactory.InvalidInputException: An error occurred (InvalidInput) when calling the SimulatePrincipalPolicy operation: Invalid Entity Arn: arn:aws:sts::123456789012:assumed-role/u-admin/botocore-session-0987654321 does not clearly define entity type and name.
Some AWS accounts can have permission to operate on resources without having access to SimulatePrincipalPolicy.
If this is the case, supply the --no-aws-permissions-check
flag to your command.
Error adding new region to integration:
Linking New Relic account to AWS account Traceback (most recent call last): ... File "/Users/USER/PYTHONPATH/lib/python3.8/site-packages/newrelic_lambda_cli/gql.py", line 131, in link_account return res["cloudLinkAccount"]["linkedAccounts"][0] IndexError: list index out of range
This error can happen if you have an existing AWS integration, and are running newrelic-lambda integrations install
with a different --linked-account-name
(for instance, to add a new region to the integration). The linked account name can be whatever you want it to be, but needs to be consistent with the previously linked AWS account.