Ingress Flashcards

1
Q

wat is ingress

A

een Kubernetes-resource die het mogelijk maakt om HTTP- en HTTPS-verkeer van buiten het cluster naar specifieke applicaties binnen het cluster te sturen. Het zorgt voor routing van inkomend verkeer naar de juiste service, afhankelijk van de URL of het domein.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
2
Q

wat zijn de 3 belangrijste onderdelen van Ingress?

A
  • ingress resource
  • ingress controller
  • service
How well did you know this?
1
Not at all
2
3
4
5
Perfectly
3
Q

wat is een ingress resource?

A

Dit is een Kubernetes-object (specificeer je routing-regels) dat je aanmaakt om te bepalen hoe het verkeer naar je services moet worden geleid.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
4
Q

wat is een ingress controler?

A

Dit is een component die in je cluster draait en verantwoordelijk is voor het daadwerkelijk verwerken van de Ingress-regels. Het zorgt ervoor dat verkeer via de juiste poort (meestal 80 voor HTTP en 443 voor HTTPS) naar de juiste services wordt gestuurd.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
5
Q

wat is een service?

A

Dit zijn de applicaties binnen je cluster die je wilt bereiken via Ingress. Elke service heeft een specifieke URL of pad dat je in de Ingress-regels definieert.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
6
Q

Wat is het verschil tussen een Ingress en een Service in Kubernetes

A

Een Service biedt een interne netwerktoegang tot applicaties binnen het cluster, terwijl een Ingress inkomend verkeer van buiten het cluster naar de services binnen het cluster routet op basis van regels (bijvoorbeeld URL-paden en domeinen).

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
7
Q

Hoe installeer je een Ingress Controller in een Kubernetes-cluster?

A

n Ingress Controller kan meestal worden geïnstalleerd met behulp van een Helm-chart, kubectl, of via een specifieke YAML-manifest van bijvoorbeeld NGINX, Traefik of andere controllers. Voor NGINX kan het bijvoorbeeld via deze stap:

bash
Code kopiëren
kubectl apply -f https://raw.githubusercontent.com/kubernetes/ingress-nginx/main/deploy/static/provider/cloud/deploy.yaml

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
8
Q

Wat doet de host-parameter in een Ingress-regel?

A

De host-parameter specificeert het domein of de subdomeinen waarop de Ingress-regels van toepassing zijn. Bijvoorbeeld, www.mijnsite.com of api.mijnsite.com.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
9
Q

Wat is het verschil tussen de path en pathType in een Ingress-resource?

A

De path geeft het URL-pad aan waarop de Ingress-regel moet matchen, bijvoorbeeld /api/*.
De pathType bepaalt hoe de padvergelijking wordt uitgevoerd:
Prefix: Het pad moet beginnen met de opgegeven waarde.
Exact: Het pad moet exact overeenkomen met de opgegeven waarde.
ImplementationSpecific: Het pad wordt bepaald door de Ingress Controller.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
10
Q

welke pathTypes zijn er?

A

Prefix: Het pad moet beginnen met de opgegeven waarde.
Exact: Het pad moet exact overeenkomen met de opgegeven waarde.
ImplementationSpecific: Het pad wordt bepaald door de Ingress Controller.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
11
Q

Kun je meerdere regels in één Ingress-resource gebruiken?

A

Ja, je kunt meerdere regels toevoegen in één Ingress-resource om verkeer naar verschillende services te routeren op basis van verschillende hosts of paden.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
12
Q

Kun je SSL-terminatie configureren met een Ingress?

A

Ja, je kunt SSL-terminatie configureren door een TLS-secret te maken en dit te verwijzen in de Ingress-resource. Het stelt de Ingress-controller in staat om HTTPS-verkeer af te handelen en het als HTTP naar de achterliggende services door te sturen.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
13
Q

Wat is een backend in een Ingress-resource?

A

De backend definieert de service en de poort naar welke het verkeer wordt gestuurd wanneer het overeenkomt met de Ingress-regels (bijvoorbeeld een specifieke host of pad)

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
14
Q

Wat gebeurt er als je meerdere Ingress-resources hebt voor dezelfde host?

A

Als meerdere Ingress-resources voor dezelfde host bestaan, kan de Ingress Controller afhankelijk van zijn configuratie conflicten oplossen. Sommige controllers gebruiken de regels op volgorde van definitie, terwijl andere de regels combineren. Het is aanbevolen om duidelijke en unieke Ingress-regels te definiëren om conflicten te vermijden.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
15
Q

Kun je Ingress gebruiken met een LoadBalancer-type Service?

A

Ja, je kunt Ingress gebruiken met een LoadBalancer-type Service. In dit geval wordt het externe verkeer naar de LoadBalancer gestuurd, die dan door de Ingress Controller naar de juiste service binnen het cluster wordt gerouteerd.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
16
Q

Hoe kun je een Ingress-regel testen?

A

Je kunt een Ingress-regel testen door het domein of IP-adres waarop het verkeer wordt verwacht aan te roepen in een webbrowser of met tools zoals curl. Zorg ervoor dat de Ingress Controller actief is en de regels correct zijn toegepast.

17
Q

Kun je Ingress gebruiken om niet-HTTP-verkeer, zoals TCP of UDP, te routeren?

A

Nee, Ingress is bedoeld voor HTTP(S)-verkeer. Voor niet-HTTP-verkeer zoals TCP of UDP, gebruik je Services van het type ClusterIP, NodePort of LoadBalancer, afhankelijk van de behoeften van je applicatie.

18
Q

verschil tussen ingress en egress

A

ingress is verkeerd dat naar je pod toe komt. egress is verkeer dat uit je pod vertrekt.

19
Q

networkpolicy: netwerkbeleid is?

A

helpt om te regelen welk verkeer je pods binnen het cluster kunnen ontvangen of versturen.

20
Q

hoe werkt networkpolicy

A

Het werkt met labels en selectors om te bepalen welke pods met elkaar kunnen communiceren.

21
Q

Wat is het verschil tussen een podSelector en een namespaceSelector in een netwerkbeleid

A

Een podSelector selecteert pods op basis van labels binnen een bepaalde namespace, terwijl een namespaceSelector pods selecteert op basis van de namespace waarin ze zich bevinden. Bijvoorbeeld, je kunt een namespaceSelector gebruiken om verkeer alleen van pods in een specifieke namespace (zoals prod) toe te staan, terwijl de podSelector bepaalt welke pods binnen die namespace toegang hebben.

22
Q

Wat als je een externe server (zoals een back-up server) toegang wilt geven tot de databasepod?

A

Als de externe server geen pod is binnen het Kubernetes-cluster, kun je een ipBlock gebruiken in je netwerkbeleid. Hiermee kun je een specifiek IP-adres (bijvoorbeeld het IP van de back-up server) toestaan om verbinding te maken met de databasepod.

23
Q

Hoe kun je meerdere API-pods in verschillende namespaces beperken tot alleen toegang tot de databasepod in de prod namespace?

A

Je kunt dit doen door zowel een podSelector als een namespaceSelector toe te voegen aan het netwerkbeleid. De podSelector zorgt ervoor dat alleen de API-pods toegang hebben, en de namespaceSelector zorgt ervoor dat alleen de API-pods in de prod namespace toegang krijgen tot de databasepod.

24
Q

Wat gebeurt er als je geen namespaceSelector of podSelector gebruikt in een netwerkbeleid?

A

Als je geen namespaceSelector of podSelector gebruikt, zou dit betekenen dat alle pods binnen de opgegeven namespace toegang kunnen krijgen tot de databasepod, ongeacht de labels van de pods. Dit is meestal niet wenselijk, omdat het te breed kan zijn en ongewenst verkeer kan toestaan.

25
Q

Waarom zou je zowel een namespaceSelector als een podSelector gebruiken?

A

Je zou beide selectors gebruiken als je zowel de namespace als de labels van de pods wilt controleren. Bijvoorbeeld, je wilt alleen verkeer toestaan van API-pods in de prod namespace met een specifiek label (zoals rol: api). Dit maakt je netwerkbeleid strikter en veiliger.

26
Q

Wat moet je doen als je een back-upserver buiten het Kubernetes-cluster hebt en deze toegang wilt geven tot de databasepod?

A

Als de back-upserver buiten het Kubernetes-cluster is, kun je een ipBlock gebruiken in het netwerkbeleid. Hiermee kun je verkeer toestaan van een specifiek IP-adres (bijvoorbeeld het IP van de back-upserver) naar de databasepod.

27
Q

Welke resource type is de ingress controller

A

deployment

28
Q

tussen service en deployment zit een link via labels, niet via ports

A

tussen service en ingress zit een link via port en name.

Ingress: De poort waarop de Ingress de service beschikbaar maakt voor extern verkeer. Dit komt van de Service en wordt gedefinieerd in de Ingress-resource (service.port.number).

29
Q

welke links zijn er in kubernetes resources?

A

Deployment ↔ Pod:
Link: De Deployment maakt Pods aan op basis van een pod template. Elke pod die door de Deployment wordt aangemaakt heeft een label (bijv. app: my-app), die belangrijk is voor de Service om te bepalen naar welke pods verkeer gestuurd moet worden.

Service ↔ Pod (via Deployment):
Link: De Service gebruikt een selector om pods te vinden die bij de Service horen, op basis van de labels die door de Deployment zijn ingesteld (bijv. app: my-app). Dit maakt de verbinding tussen de Service en de pods.

Ingress ↔ Service:
Link: De Ingress heeft regels die verkeer naar een specifieke Service doorsturen, op basis van het host en pad. De poort van de Service wordt hierbij opgegeven, waardoor het verkeer naar de juiste achterliggende service en poort wordt geleid.

30
Q

Deployment ↔ ReplicaSet: Deployment maakt een ReplicaSet aan om de gewenste replica’s van pods te behouden.
StatefulSet ↔ Pod: StatefulSet maakt pods met een stabiele identiteit.
PersistentVolume ↔ PersistentVolumeClaim: PVC’s vragen opslag aan, PV’s leveren opslag.
ConfigMap ↔ Pod: Pods kunnen configuratie-instellingen uit een ConfigMap lezen.
Secret ↔ Pod: Pods kunnen gevoelige informatie uit een Secret gebruiken.
NetworkPolicy ↔ Pod: Netwerkbeleid controleert het verkeer naar/van een Pod.
HorizontalPodAutoscaler ↔ Deployment/ReplicaSet: HPA past het aantal replicas aan op basis van prestaties.
Pod ↔ Service: Services routeren verkeer naar de juiste Pods op basis van selectors.
Job ↔ Pod: Jobs creëren en beheren Pods voor éénmalige taken.
CronJob ↔ Job ↔ Pod: CronJobs plannen periodieke Jobs die Pods aanmaken om taken uit te voeren.

A