Your task is to set up a Kubernetes cluster and deploy a REST API and a frontend that consumes the REST API into it.
- Set up a Kubernetes cluster. However you like. We're leaving this purposefully open for you to do your own research on how you want to go about it. You can roll your own cluster using, for example, kops or you can leverage existing cluster services such as AWS EKS or Google Cloud's Kubernetes Engine. Or you can go really deep and do it the hard way by manually bootstrapping it.
- When you have a running cluster, deploy an API of your choice and a frontend application of your choice that consumes the API into the cluster. This can be a handwritten hello world application or any other ready-made docker images.
- Document how to access and use the applications you deployed
- Let us know you're ready to review by sending us documentation and access to the cluster via email to [email protected]
- Your Kubernetes cluster is up and running
- Your frontend application is running and accessible under a domain of your choice
- The frontend displays data from the API
- The code you've written to create the cluster and deploy the applications is accessible, for example in a GitHub repo
- Your application is available via SSL
- Automate the cluster setup, e.g. through shell scripts or terraform etc.
- Your application is auto-scaling. Meaning when you put load on it (via Apache Workbench for example) it automatically auto-scales horizontally by adding more pods
- Your API is hooked up to a database (can be inside the cluster or outside)
- You have isolated staging and production environments for your application
Prioritised from most important to least important, here are our evaluation criteria:
- Feature Completeness: Does your cluster fulfil all acceptance criteria?
- Code Quality: If you've written any code to achieve the task, is the code clean, well-structured and easy to understand?
- Documentation: How good is the documentation?
- The extra mile: Did you hit any bonus goals?
You do not need to hit all points, but obviously, the more the better :)