Deploying Lambda Functions & Generating Trace Data
Now that we know how to apply manual instrumentation to the functions and services we wish to capture trace data for, let’s go about deploying our Lambda functions again, and generating traffic against our producer-lambda
endpoint.
Initialize Terraform in the manual
directory
Seeing as we’re in a new directory, we will need to initialize Terraform here once again.
Ensure you are in the
manual
directory:pwd
- The expected output would be ~/o11y-lambda-workshop/manual
If you are not in the
manual
directory, run the following command:cd ~/o11y-lambda-workshop/manual
Run the following command to initialize Terraform in this directory
terraform init
Deploy the Lambda functions and other AWS resources
Let’s go ahead and deploy those resources again as well!
Run the terraform plan command, ensuring there are no issues.
terraform plan
Follow up with the terraform apply command to deploy the Lambda functions and other supporting resources from the main.tf file:
terraform apply
Respond yes when you see the Enter a value: prompt
This will result in the following outputs:
Outputs: base_url = "https://______.amazonaws.com/serverless_stage/producer" consumer_function_name = "_____-consumer" consumer_log_group_arn = "arn:aws:logs:us-east-1:############:log-group:/aws/lambda/______-consumer" consumer_log_group_name = "/aws/lambda/______-consumer" environment = "______-lambda-shop" lambda_bucket_name = "lambda-shop-______-______" producer_function_name = "______-producer" producer_log_group_arn = "arn:aws:logs:us-east-1:############:log-group:/aws/lambda/______-producer" producer_log_group_name = "/aws/lambda/______-producer"
As you can tell, aside from the first portion of the base_url and the log gropu ARNs, the output should be largely the same as when you ran the auto-instrumentation portion of this workshop up to this same point.
Send some traffic to the producer-lambda
endpoint (base_url)
Once more, we will send our name
and superpower
as a message to our endpoint. This will then be added to a record in our Kinesis Stream, along with our trace context.
Ensure you are in the
manual
directory:pwd
- The expected output would be ~/o11y-lambda-workshop/manual
If you are not in the
manual
directory, run the following command:cd ~/o11y-lambda-workshop/manual
Run the
send_message.py
script as a background process:nohup ./send_message.py --name CHANGEME --superpower CHANGEME &
Next, check the contents of the response.logs file for successful calls to ourproducer-lambda endpoint:
cat response.logs
You should see the following output among the lines printed to your screen if your message is successful:
{"message": "Message placed in the Event Stream: hostname-eventStream"}
If unsuccessful, you will see:
{"message": "Internal server error"}
Important
If this occurs, ask one of the workshop facilitators for assistance.
View the Lambda Function Logs
Let’s see what our logs look like now.
Check the producer.logs file:
cat producer.logs
And the consumer.logs file:
cat consumer.logs
Examine the logs carefully.
Workshop Question
Do you notice the difference?
Copy the Trace ID from the consumer-lambda
logs
This time around, we can see that the consumer-lambda log group is logging our message as a record
together with the tracecontext
that we propagated.
To copy the Trace ID:
- Take a look at one of the
Kinesis Message
logs. Within it, there is adata
dictionary - Take a closer look at
data
to see the nestedtracecontext
dictionary - Within the
tracecontext
dictionary, there is atraceparent
key-value pair - The
traceparent
key-value pair holds the Trace ID we seek- There are 4 groups of values, separated by
-
. The Trace ID is the 2nd group of characters
- There are 4 groups of values, separated by
- Copy the Trace ID, and save it. We will need it for a later step in this workshop