This repository is a demo of using Apollo Federation to build a single schema on top of multiple services. The microservices are located under the ./services
folder and the gateway that composes the overall schema is in the gateway.js
file.
To run this demo locally, pull down the repository then run the following commands:
npm install
This will install all of the dependencies for the gateway and each underlying service.
npm run start-services
This command will run all of the microservices at once. They can be found at http://localhost:4001, http://localhost:4002, http://localhost:4003, and http://localhost:4004.
In another terminal window, run the gateway by running this command:
npm run start-gateway
This will start up the gateway and serve it at http://localhost:4000
This demo showcases four partial schemas running as federated microservices. Each of these schemas can be accessed on their own and form a partial shape of an overall schema. The gateway fetches the service capabilities from the running services to create an overall composed schema which can be queried.
To see the query plan when running queries against the gateway, click on the Query Plan
tab in the bottom right hand corner of GraphQL Playground
To learn more about Apollo Federation, check out the docs
This is based upon https://medium.com/webill/run-a-federated-graphql-server-with-minikube-1d0f913ee8a8
https://minikube.sigs.k8s.io/docs/start/
New-Item -Path 'c:' -Name 'minikube' -ItemType Directory -Force Invoke-WebRequest -OutFile 'c:\minikube\minikube.exe' -Uri 'https://github.com/kubernetes/minikube/releases/latest/download/minikube-windows-amd64.exe' -UseBasicParsing
$oldPath = [Environment]::GetEnvironmentVariable('Path', [EnvironmentVariableTarget]::Machine)
if ($oldPath.Split(';') -inotcontains 'C:\minikube'){ [Environment]::SetEnvironmentVariable('Path', $('{0};C:\minikube' -f $oldPath), [EnvironmentVariableTarget]::Machine)
}
minikube start
minikube dashboard
https://argo-cd.readthedocs.io/en/stable/getting_started/
kubectl create namespace argocd kubectl apply -n argocd -f https://raw.githubusercontent.com/argoproj/argo-cd/stable/manifests/install.yaml
kubectl port-forward svc/argocd-server -n argocd 8080:443
mkdir argocd
cd .\argocd
$version = (Invoke-RestMethod https://api.github.com/repos/argoproj/argo-cd/releases/latest).tag_name
$url = "https://github.com/argoproj/argo-cd/releases/download/" + $version + "/argocd-windows-amd64.exe"
$output = "argocd.exe"
Invoke-WebRequest -Uri $url -OutFile $output
$oldPath = [Environment]::GetEnvironmentVariable('Path', [EnvironmentVariableTarget]::Machine)
if ($oldPath.Split(';') -inotcontains 'C:\argocd'){ [Environment]::SetEnvironmentVariable('Path', $('{0};C:\argocd' -f $oldPath), [EnvironmentVariableTarget]::Machine)
}
argocd login 127.0.0.1:8080
docker build -f .\dockerfiles\accounts.dockerfile -t accounts . && docker tag accounts:latest pauljpearson/accounts:latest && docker push pauljpearson/accounts:latest
docker build -f .\dockerfiles\inventory.dockerfile -t inventory . && docker tag inventory:latest pauljpearson/inventory:latest && docker push pauljpearson/inventory:latest
docker build -f .\dockerfiles\products.dockerfile -t products . && docker tag products:latest pauljpearson/products:latest && docker push pauljpearson/products:latest
docker build -f .\dockerfiles\reviews.dockerfile -t reviews . && docker tag reviews:latest pauljpearson/reviews:latest && docker push pauljpearson/reviews:latest
docker build -f .\dockerfiles\gateway.dockerfile -t gateway . && docker tag gateway:latest pauljpearson/gateway:latest && docker push pauljpearson/gateway:latest
cd .\manifests
kubectl apply -f .
In minikube we need to expose the nodeport service.
Note: this will lock the terminal, but will give a url where it is exposed.
minikube service gateway -n <namespace> --url
minikube service gateway -n default --url
Then call the url to open the apollo graph studio against the local server
Run in via argocd.