CKA考试知识点分享(9)---gateway api

CKA 版本:1.32

第九套题是涉及gateway api相关。

注意:本文不是题目,只是为了学习相关知识点做的实验。仅供参考

实验目的

创建一个gateway api,来实现后端镜像的外部访问。

gateway api 通过nginx实现

实验开始

安装nginx gateway

第一步 安装gateway api 资源

https://github.com/kubernetes-sigs/gateway-api/releases/tag/v1.3.0

确定资源安装完成。

第二步 安装crd

kubectl apply -f https://raw.githubusercontent.com/nginx/nginx-gateway-fabric/v2.0.0/deploy/crds.yaml

第三步 安装nginx Gateway Fabric

kubectl apply -f https://raw.githubusercontent.com/nginx/nginx-gateway-fabric/v2.0.0/deploy/default/deploy.yaml

#国内镜像下载很慢,需要等待较长时间。

检查pod

检查gc

kubectl get gc

可以看到 gc已经安装完成。

创建后端service

yaml 复制代码
apiVersion: apps/v1
kind: Deployment
metadata:
  name: whoaim
spec:
  selector:
    matchLabels:
      app: whoaim
  replicas: 1
  template:
    metadata:
      labels:
        app: whoaim
    spec:
      containers:
      - name: whoaim
        image: docker.io/containous/whoami:v1.5.0
        imagePullPolicy: IfNotPresent
        ports:
        - containerPort: 80
---
apiVersion: v1
kind: Service
metadata:
  name: whoaim
  labels:
    app: whoaim
spec:
  ports:
  - port: 80
  selector:
    app: whoaim

验证gateway api

创建gateway

yaml 复制代码
apiVersion: gateway.networking.k8s.io/v1
kind: Gateway
metadata:
  name: nginx-gateway
spec:
  gatewayClassName: nginx
  listeners:
  - name: http
    protocol: HTTP
    port: 80

检查gateway

注意 这里创建gateway后,会在gateway所在的创建一个pod,来实现流量监控。

出现新的pod

检查,出现新的svc

注意: gateway删除后,自动生成的svc和pod都会被删除。

创建http route

yaml 复制代码
apiVersion: gateway.networking.k8s.io/v1
kind: HTTPRoute
metadata:
  name: httproute
spec:
  parentRefs:
  - name: nginx-gateway
  hostnames:
  - "www.example.com"
  rules:
  - matches:
    - path:
        type: PathPrefix
        value: /login
    backendRefs:
    - name: whoaim
      port: 80

添加dns解析:192.168.100.41 www.example.com

访问测试:

curl www.example.com:31930/login

通过地址成功访问。

删除gateway,自动生成的pod被删除。

参考链接:

https://docs.nginx.com/nginx-gateway-fabric/install/manifests/

相关推荐
2501_920047034 小时前
k8s-ingress控制器
云原生·容器·kubernetes
K_i1345 小时前
Docker、容器、虚拟机到底是什么
docker·微服务·云原生·容器·kubernetes
Broken Arrows21 小时前
k8s学习(二)——kubernetes整体架构及组件解析
学习·架构·kubernetes
落日漫游1 天前
DockerCE与cri-docker核心区别解析
运维·docker·kubernetes
K_i1341 天前
Ansible实战:VMware下K8s自动化部署指南
kubernetes·自动化·ansible
lingggggaaaa1 天前
小迪安全v2023学习笔记(九十七天)—— 云原生篇&Kubernetes&K8s安全&API&Kubelet未授权访问&容器执行
java·笔记·学习·安全·网络安全·云原生·kubernetes
yuezhilangniao1 天前
基础架构安全和云原生安全的融合~K8S安全和传统安全~K8S和安全融合~综合安全大饼
安全·云原生·kubernetes
nvd112 天前
用terraform 创建一个GKE private cluster
云原生·kubernetes·terraform·gke
小雨凉如水2 天前
k8s学习-pod的生命周期
java·学习·kubernetes
Q飞了2 天前
深入理解k8s中pod、service、deployment和statefulSet等工作负载--图文篇
云原生·容器·kubernetes