{"id":13752989,"url":"https://github.com/alextanhongpin/full-stack-microservice","last_synced_at":"2025-10-06T06:04:21.024Z","repository":{"id":79114874,"uuid":"98253122","full_name":"alextanhongpin/full-stack-microservice","owner":"alextanhongpin","description":"Architecture design for microservice","archived":false,"fork":false,"pushed_at":"2019-01-30T07:29:24.000Z","size":67919,"stargazers_count":94,"open_issues_count":1,"forks_count":30,"subscribers_count":11,"default_branch":"master","last_synced_at":"2024-11-16T05:32:31.405Z","etag":null,"topics":["api-gateway","architecture","consul","consul-template","etcd","linkerd","microservice","traefik"],"latest_commit_sha":null,"homepage":null,"language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/alextanhongpin.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null}},"created_at":"2017-07-25T02:04:38.000Z","updated_at":"2024-10-12T13:26:00.000Z","dependencies_parsed_at":"2024-01-17T15:13:18.958Z","dependency_job_id":null,"html_url":"https://github.com/alextanhongpin/full-stack-microservice","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/alextanhongpin%2Ffull-stack-microservice","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/alextanhongpin%2Ffull-stack-microservice/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/alextanhongpin%2Ffull-stack-microservice/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/alextanhongpin%2Ffull-stack-microservice/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/alextanhongpin","download_url":"https://codeload.github.com/alextanhongpin/full-stack-microservice/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":227673949,"owners_count":17802303,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["api-gateway","architecture","consul","consul-template","etcd","linkerd","microservice","traefik"],"created_at":"2024-08-03T09:01:14.092Z","updated_at":"2025-10-06T06:04:15.988Z","avatar_url":"https://github.com/alextanhongpin.png","language":"JavaScript","funding_links":[],"categories":["linkerd"],"sub_categories":[],"readme":"# full-stack-microservice\n\nThe goal is to design a working microservice architecture with the following components:\n\n![out](assets/cloud.png)\n\n## Infrastructure\n\n- Terraform\n\n## Load Balancer\n\n- Nginx\n- HAProxy\n- Traefik\n- Envoy\n- Linkerd\n- Fabio\n\n## Scheduler\n\n- Nomad\n\n## Orchestration\n\n- Docker Swarm\n- Kubernetes\n\n## API Gateway\n\n- Kong\n- Tyk\n- express-gateway\n- API Umbrella\n\n## Service Mesh\n\n- Linkerd\n- Conduit\n- Istio\n\n## Search\n\n- Elasticsearch\n- Solr\n- Bleeve\n- DNA Search\n\n## Cache\n\n- Redis (also for rate-limiting, time-series analytics)\n- Memcached\n- Varnish\n- Zipnish\n\n## Time-Series Database\n\n- TimescaleDB\n- InfluxDB (cluster is only available in Enterprise version though)\n\n\n## Tracing\n\n- OpenTracing\n- OpenZipkin\n- Jaeger\n\n## Auth\n\n- OpenId Connect\n- OAuth2\n- Identity Server 4\n\n## Secrets\n\n- DockerSecrets\n- Vault\n\n## Transport\n\n- Kafka\n- Nats\n- gRPC\n- protobuff\n- Thrift\n- Avro\n- RabbitMQ\n- ZeroMQ\n\n## Documentation\n\n- Swagger\n\n## API Standards\n\n- JSON Schema\n- JSON API\n\n## Security\n\n- letsencrypt\n\n### Others\n\n- Client/server-side service discovery (nodejs resilient, etcd, Linkerd, Consul)\n- Consul/etcd setup\n- Circuit breaker\n- Docker-compose or nomad setup\n- Dynamic ports and service registry\n- 12-Factor app practices\n- Heteregenous clients (nodejs, go, python)\n- Transport protocol (kafka, nats, rabbitmq, rpc, grpc, protobuff)\n- Caching (Redis/memcached)\n- API Gateway (kong, API Umbrella, AWS API Gateway)\n- OpenID connect\n- Sharding/Clustering of storage\n- Vault\n- RASA NLU\n- Opentracing with GRPC\n- GRPC security with Go, nodejs, python\n- GRPC with graphql adapter\n- Finanz example\n- Create architecture diagram for all the different setups\n\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Falextanhongpin%2Ffull-stack-microservice","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Falextanhongpin%2Ffull-stack-microservice","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Falextanhongpin%2Ffull-stack-microservice/lists"}