Integrate EC2 Instance with Lambda Instance

Integrating an EC2 instance with an AWS Lambda function enables seamless execution of tasks like monitoring, automation, and data exchange between the compute resources. This guide provides a step-by-step approach to achieving this integration, leveraging AWS IAM roles, VPC configurations, and secure communication protocols.




1. Prerequisites

Before starting, ensure you have:

AWS CLI installed and configured with appropriate permissions.

An active EC2 instance and a Lambda function deployed in the same region.

Basic knowledge of AWS services such as IAM, VPC, and CloudWatch.





2. Create an IAM Role for Lambda

1. Navigate to the IAM Console:

Go to Roles > Create Role.



2. Attach Policies:

Select the AWS Lambda trusted entity.

Attach the required policies, such as:

AmazonEC2FullAccess (to interact with EC2).

CloudWatchLogsFullAccess (for logging).




3. Add Inline Policy for Specific Permissions:

{
  “Version”: “2012-10-17”,
  “Statement”: [
    {
      “Effect”: “Allow”,
      “Action”: [
        “ec2:DescribeInstances”,
        “ec2:StartInstances”,
        “ec2:StopInstances”
      ],
      “Resource”: “*”
    }
  ]
}


4. Name and Create the Role: Assign a meaningful name, such as LambdaToEC2Role.





3. Attach the Role to the Lambda Function

1. Navigate to the AWS Lambda Console.


2. Select your Lambda function.


3. Under the Configuration tab, choose Permissions > Execution Role.


4. Attach the previously created IAM role (LambdaToEC2Role).






4. Configure VPC Access for Lambda

If your EC2 instance is within a VPC, the Lambda function must also access the same VPC.

1. Navigate to the Lambda function’s VPC settings.


2. Specify the VPC ID, subnets, and security groups that allow communication with the EC2 instance.


3. Update the Lambda function settings.






5. Write the Lambda Function Code

The Lambda function will use AWS SDK for Python (boto3) to interact with the EC2 instance.
Example:

import boto3

def lambda_handler(event, context):
    ec2 = boto3.client(‘ec2’)
   
    # Describe EC2 instances
    response = ec2.describe_instances(Filters=[{‘Name’: ‘instance-state-name’, ‘Values’: [‘running’]}])
    instance_ids = [instance[‘InstanceId’] for reservation in response[‘Reservations’] for instance in reservation[‘Instances’]]
   
    # Stop instances
    if instance_ids:
        ec2.stop_instances(InstanceIds=instance_ids)
        return f”Stopped instances: {instance_ids}”
    else:
        return “No running instances found.”




6. Test the Lambda Function

1. Trigger Manually:

Use a test event in the Lambda console or invoke the function via CLI:

aws lambda invoke –function-name LambdaFunctionName output.txt



2. Verify Logs:

Check the CloudWatch Logs to ensure the Lambda function executed correctly.







7. Automate the Integration

Integrate the Lambda function with AWS CloudWatch Events to automatically trigger actions based on conditions, such as high CPU usage on the EC2 instance.

1. Create a CloudWatch Rule:

Example: Trigger the Lambda function when an EC2 instance exceeds a CPU threshold.



2. Set the Target:

Add the Lambda function as the target for the rule.







8. Secure Communication

Ensure your EC2 instance’s security group allows access only from trusted sources, such as the Lambda function’s subnet.

Use environment variables in Lambda to store sensitive data securely.





Conclusion

Integrating EC2 with Lambda enables robust automation and monitoring within your AWS environment. By leveraging IAM roles, VPC configurations, and the AWS SDK, this integration ensures secure and efficient communication between compute resources. Always follow security best practices, such as restricting permissions and monitoring logs, to maintain a secure infrastructure.

The article above is rendered by integrating outputs of 1 HUMAN AGENT & 3 AI AGENTS, an amalgamation of HGI and AI to serve technology education globally.

(Article By : Himanshu N)