Monitoring platform for keeping systems up and running at all times.
Full stack visibility across the entire stack.
Detect and resolve any incident in record time.
Conform to industry best practices.
In this article, we will build a CI/CD pipeline with the AWS Cloud Development Kit (CDK) and debug a test it using Dashbird’s observability tool.
In 2021, continuous integration and continuous delivery, or short CI/CD, should be part of every modern software development process. It helps deliver new features and bug fixes much faster. If the code doesn’t have to sit days or weeks before it gets deployed, it has a higher chance that a developer remembers what they were thinking when they wrote it. And with good code quality tools, you can prevent problems before buggy code gets deployed anywhere.
API-based web or mobile apps are a well-known example for serverless systems, but CI/CD pipelines can include serverless technology too! AWS offers managed services to build serverless CI/CD pipelines in the cloud, so you only have to pay what you use.
Learn more about CDK in this crash course article.
This tutorial requires:
The project with all the code needed already exists on GitHub. You just have to fork it into your own account. This is required to give AWS CodePipeline access to your GitHub hooks.
To fork the repository, open it in your browser and click the “Fork” button on the top right.
The next step is to initialize the project on your development machine. For this, you can simply clone your own fork.
$ git clone git@github.com:<YOUR_GITHUB_USERNAME>/dashbird-cicd-example.git
And finally, you need to update the credentials.json, so the project works with your own fork and AWS account.
credentials.json
{ "github": { "username":"GITHUB_USERNAME", "repository": "GITHUB_REPOSITORY" }, "aws": { "account":"AWS_ACCOUNT_ID", "region":"AWS_REGION" } }
GITHUB_USERNAME
GITHUB_REPOSITORY
dashbird-cicd-example
AWS_ACCOUNT_ID
AWS_REGION
You also need a personal access token so that the pipeline can access your GitHub repository.
The GitHub docs explain how you get that token. The token needs the repo and admin:repo_hook scopes. In turn, the AWS docs explain how to add the token as a secret to the AWS Secrets Manager. The token should be a plain text secret with the name github-token.
repo
admin:repo_hook
github-token
If everything is set up correctly, the project can be deployed with just two commands. One command to bootstrap the CDK in your AWS account and one to deploy the project.
But let’s go over the project before we deploy, so you get a sense of what will happen.
In short, this project is basically two systems in one. One is the CI/CD pipeline that listens to our repository changes and executes pipeline steps when pushes happen. The other one is the actual application we want to deploy.
bin/pipeline.js
lib/pipeline-stack.js
lib/webservice/stage.js
lib/webservice/stack.js
lib/webservice/lambda/handler.js
The nice thing about CDK pipelines is that changes to our application code, to our application infrastructure, and our pipeline infrastructure are all handled by that same pipeline.
Let’s deploy the project. If you haven’t used the CDK before with the account and region combination you added to the credentials.json; you need to bootstrap the CDK first with the following command:
$ cdk bootstrap \ --profile account1-profile \ --cloudformation-execution-policies arn:aws:iam::aws:policy/AdministratorAccess \ aws://<AWS_ACCOUNT_ID>/<AWS_REGION>
If the bootstrap worked correctly, you could now deploy the project with this CDK command:
$ cdk deploy
This can take a few minutes.
As mentioned before, this will deploy the CI/CD pipeline and not the application. After the pipeline is up and running, it will pull the repository and deploy our API Gateway and Lambda based application.
If you open the AWS console and navigate to CodePipeline (in the category Developer Tools and your chosen AWS region), you can see the pipeline working on the deployment. The last step will fail!
Now that the CI/CD pipeline is up and running, we can finally have look if our application works correctly. If you open the CodePipeline in the AWS console and scroll down to the bottom, you should see the below error.
If you followed the Dashbird getting started guide, all your Lambda functions will be monitored automatically, even the one that is freshly deployed by our pipeline. This means you can find that error right in the Dashbird dashboard; it should look like this:
If you have more than one Lambda function, you can find it by its generated name, which consists of:
PreProd
WebService
Lambda
If you click on this error, you should see the event that led to it. Below, you see the stack trace that Dashbird provides.
While the filename handler.js, line number 2, and the error type are correct, the location is different. It was in the lib/webservice/lambda directory on our development machine, but when deployed, it ended up in the Lambda owned /var/task directory inside the AWS Cloud. You should keep in mind to give your Lambda functions code file a name that helps to find it later.
lib/webservice/lambda
/var/task directory
To fix this error, we simply remove that erroneous line from our handler.js file, commit the change and push it to GitHub. This will trigger our CI/CD pipeline to run again without the error.
Continuous delivery pipelines are crucial for modern software and should be part of your development process, and serverless technology is a good foundation for building your pipeline. With the CDK, such pipelines are easy to set up and maintain.
Because Dashbird follows observability principles, you don’t have to think about monitoring explicitly when creating your systems. You will get automatic preconfigured insights into and alarms for every AWS service supported by Dashbird, even the Lambda functions that are part of your CI/CD pipeline. This way, you stay up to date on your systems’ internal state and won’t get any surprises in production.
This project is based on an AWS own example project created for the AWS blog. A bit cleaned up for easier reproduction, but it’s mainly the same, so you can read the AWS article if you want to get some extra information.
Today we are announcing a new, updated pricing model and the end of free tier for Dashbird.
In this article, we’re covering 4 tips for AWS Lambda optimization for production. Covering error handling, memory provisioning, monitoring, performance, and more.
In this article we’ll go through the ins and outs of AWS Lambda pricing model, how it works, what additional charges you might be looking at and what’s in the fine print.
Dashbird was born out of our own need for an enhanced serverless debugging and monitoring tool, and we take pride in being developers.
Dashbird gives us a simple and easy to use tool to have peace of mind and know that all of our Serverless functions are running correctly. We are instantly aware now if there’s a problem. We love the fact that we have enough information in the Slack notification itself to take appropriate action immediately and know exactly where the issue occurred.
Thanks to Dashbird the time to discover the occurrence of an issue reduced from 2-4 hours to a matter of seconds or minutes. It also means that hundreds of dollars are saved every month.
Great onboarding: it takes just a couple of minutes to connect an AWS account to an organization in Dashbird. The UI is clean and gives a good overview of what is happening with the Lambdas and API Gateways in the account.
I mean, it is just extremely time-saving. It’s so efficient! I don’t think it’s an exaggeration or dramatic to say that Dashbird has been a lifesaver for us.
Dashbird provides an easier interface to monitor and debug problems with our Lambdas. Relevant logs are simple to find and view. Dashbird’s support has been good, and they take product suggestions with grace.
Great UI. Easy to navigate through CloudWatch logs. Simple setup.
Dashbird helped us refine the size of our Lambdas, resulting in significantly reduced costs. We have Dashbird alert us in seconds via email when any of our functions behaves abnormally. Their app immediately makes the cause and severity of errors obvious.