Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alexashley/cloud-native-fizzbuzz
https://github.com/alexashley/cloud-native-fizzbuzz
Last synced: 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/alexashley/cloud-native-fizzbuzz
- Owner: alexashley
- Created: 2019-10-04T23:34:19.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2021-04-17T01:31:56.000Z (over 3 years ago)
- Last Synced: 2024-03-01T05:09:15.457Z (11 months ago)
- Language: Go
- Size: 24.4 KB
- Stars: 6
- Watchers: 0
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# cloud native fizzbuzz
badges go here
## background
[FizzBuzz](https://en.wikipedia.org/wiki/Fizz_buzz) is a complex engineering problem that requires a combined mastery of advanced mathematical concepts and programming techniques, such as congruence relations and iteration.
It's often used in the final stages of job interviews, after trivial screening questions about red-black trees and system architecture.
Calculating the result requires immense computational power and cannot be done trivially; as such developers in interviews often turn to managed services in order to solve the problem -- either by writing code
that interacts with these services directly or even just mentioning that a proper engineering solution would almost certainly require the use of such a service.Unfortunately for developers, these FizzBuzz-as-a-service providers (hereafter FaaS) are often built around insecure, unscalable, and fragile legacy architectures.
For example, a common approach is to precompute the answer for various numbers, store the result in a table, and use a stored procedure to query the table for any given range.
This is often accompanied by a small SOAP web service or RPC interface that acts as a veneer to the underlying infrastructure.
Consequently, these services are difficult to use, impossible to debug, and it's common for them to ignore authentication, authorization, observability.However, there is a light at the end of the tunnel.
Thanks to the immense growth and proliferation of cloud native technologies, it's now possible to build a highly secure, infinitely scalable, and maintainable solution to this once thorny problem.
This repository is an example of the use of these technologies, specifically Go, Kubernetes, Helm, Docker, Istio, NATS, and Open Policy Agent.
It demonstrates how FizzBuzz can be split into separate, logical domains, each with their own microservices communicating via a service mesh. See the [architecture](#architecture) for more information.## architecture
## local development
You'll need the following:
- `kubectl`
- `helm`