It is a micro service which calls a set of Endpoints collecting the results.
There are two kind of Endpoints:
- External: These are URLs with unknown result
- Recursive: These are URLs where instances of this micro-service is deployed, so the result format is well known
It is a very simple application that allows us to test communication and lack of it.
It is mainly useful to test networking policies. It was created to help us on AKS Regulated Cluster, but it can be used base on your needs.
It is a basic .Net 9.0 web application. It was created using Visual Studio 2022.
Before deploying on Kubernetes we need to create the docker image. There is a DockerFile as part of the solution.
cd SimpleChainApi
docker build -f ".\SimpleChainApi\Dockerfile" --force-rm -t aks-endpoint-caller:1.0 --target final .
If you are using Azure Kubernetes Service you need to push your image on a Azure Container Registry
It is an example of a deployment on AKS.
apiVersion: v1
kind: Service
metadata:
name: ingress-endpoint-service
labels:
app: ingress-endpoint-service
spec:
type: LoadBalancer
ports:
- port: 80
targetPort: 8080
name: ingress-endpoint-http
selector:
app: ingress-endpoint
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: ingress-endpoint
spec:
selector:
matchLabels:
app: ingress-endpoint
replicas: 1
template:
metadata:
labels:
app: ingress-endpoint
spec:
containers:
- name: ingress-endpoint
image: aks-endpoint-caller:1.0
ports:
- containerPort: 8080
env:
- name: SELF_HOSTS_DEPENDENCIES
value: ""
- name: EXTERNAL_DEPENDENCIES
value: "https://whatismyip.io/"
- name: "DEPTH"
value: "1"
We need to define some environment variables:
EXTERNAL_DEPENDENCIES
- These are URLs with an unknown result; as a comma-separated listSELF_HOSTS_DEPENDENCIES
- These are URLs where instances of this micro service is deployed, so the result format is well known; as a comma-separated list.DEPTH
- This value is for doing the recursive calls. The default is0
, meaning no dependencies are called. If the value is larger than0
the dependencies are call, and the recursive dependencies are called using (DEPTH-1
). This parameter avoid infinite calls. This parameter is needed to be set only in the entry point of micro services components.
We can create the configuration which is useful for the situation we want to test. An example setup is:
- Ingress Endpoint is the starting point, and calls: https://www.microsoft.com, https://serviceA, https://serviceB, https://serviceC
- serviceA calls: https://www.microsoft.com, https://serviceA, https://serviceB, https://serviceC
- serviceB calls: https://www.microsoft.com, https://serviceA, https://serviceB, https://serviceC
- serviceC calls: https://www.microsoft.com, https://serviceA, https://serviceB, https://serviceC
Some arrows are not display as draw simplification
Navigating the root of the ingress micro service endpoint and it will throws the test and shows a result like:
Please see our contributor guide.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.
With ❤️ from Microsoft Patterns & Practices, Azure Architecture Center.