Workshop and lab content for Amazon Aurora MySQL compatible databases. This code will contain a series of templates, instructional guides and sample code to educate users on how to use Amazon Aurora features. The AWS CloudFormation templates will create the relevant resources in a user's account, the Bash and Python scripts will support the lab, by automating tasks, generating load or execute changes on resources created using AWS CloudFormation.
To run and use the labs, visit the website at: https://awsauroralabsmy.com
The instructional guides are packaged into a website that can be deployed using AWS CloudFormantion, Amazon CloudFront, Amazon S3 and AWS Lambda. If you wish to contribute to the project follow the installation and deployment steps below.
NOTE: This project is currently under active development. If you encounter any inaccuracies in the instructions below, please report them to us via Issues
The website is built using the mkdocs project and supporting libraries. We use node.js, grunt and Python 3 throughout the project, therefore these dependencies also need to be installed. The AWS CloudFormation templates are tested using taskcat.
Install dependencies:
brew install python3
brew install mkdocs
brew install node
brew install jq
pip3 install virtualenv
virtualenv venv
source venv/bin/activate
pip3 install -r requirements.txt
npm install -g npm
npm install -g grunt-cli
Install project dependencies (from [project root] folder):
npm install
To build the website only, locally, from the root folder of the project run:
mkdocs serve
To build the project assets and deploy them in AWS, run the following commands from the root of the project folder.
NOTE: The website has to be deployed in the us-east-1 region due to dependencies on AWS Lambda@Edge.
Build the full project for development:
grunt deploy-all --region-us-east-1 --bucket=<your_bucket> --cfnstack=<your_name_letters_and_dashes_only>
Build the project but skip changing (or redeploying the website infrastructure):
grunt deploy-skipinfra --region-us-east-1 --bucket=<your_bucket> --cfnstack=<your_name_letters_and_dashes_only>
The AWS CloudFormation templates for the labs are located in the [project root]/templates/
folder. They contain placeholder expressions (such as [[website]]
) that are replaced by the build process above, with the final URIs of the website you deploy in AWS. Final build versions of these templates are placed in the folder: [project root]/build/templates/
Taskcat assets are located in [project root]/taskcat/ci
. Because the templates have hardcoded resource names to satisfy requirements with external tools, you cannot test more than one template at a time via taskcat. It is therefore necessary to customize the [project root]/taskcat/ci/taskcat.yml
config file to indicate which template to test.
Once the config file is changed appropriately, from the root of the project folder run:
grunt run-taskcat --region-us-east-1 --bucket=<your_bucket> --cfnstack=<your_name_letters_and_dashes_only>
This sample code is made available under the MIT-0 license. See the LICENSE file.
Additionally, this project installs the following software for the purposes of deploying and running the labs into the lab environment:
- mysql-client package. MySQL open source software is provided under the GPL License.
- sysbench available using the GPL License.
- test_db available using the Creative Commons Attribution-Share Alike 3.0 Unported License.
- Percona's sysbench-tpcc available using the Apache License 2.0.
- Apache Superset available using the Apache License 2.0.