文章目录
- 前言
- 环境
- ingress安装
- 应用案例(ingress-http案例: 基于名称的负载均衡)
 
 
前言
这个是nodeport模式下的,如果需要loadbalancer模式下的,看看博主下面以前的博客
 链接: k8s学习–负载均衡器matelLB的详细解释与安装
 链接: k8s学习–ingress详细解释与应用(nginx ingress controller))
环境
虚拟机
| Ip | 主机名 | cpu | 内存 | 硬盘 | 
|---|---|---|---|---|
| 192.168.10.11 | master01 | 2cpu双核 | 4G | 100G | 
| 192.168.10.12 | worker01 | 2cpu双核 | 4G | 100G | 
| 192.168.10.13 | worker02 | 2cpu双核 | 4G | 100G | 
版本 rockylinux9.2
 已部署k8s-1.28.2
ingress安装
因为默认就是nodeport模式,所以直接通过网络路径应用配置文件即可
 注: 需要VPN
kubectl apply -f https://raw.githubusercontent.com/kubernetes/ingress-nginx/main/deploy/static/provider/baremetal/deploy.yaml
查看pod状态
kubectl get pod -n ingress-nginx

 如果网络不佳,可能过程会较长,耐心等待或者直接下载相关镜像皆可
应用案例(ingress-http案例: 基于名称的负载均衡)
1.创建并进入一个空目录
mkdir nginx && cd nginx
2.创建deployment控制器类型应用
vim nginx.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx
  namespace: ingress-nginx
spec:
  replicas: 2
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: c1
        image: nginx:1.20
        imagePullPolicy: IfNotPresent
应用yaml文件
kubectl apply -f nginx.yaml
查看pod状态
kubectl get pod -n ingress-nginx

3..创建service
vim nginx-service.yaml
apiVersion: v1
kind: Service
metadata:
  name: nginx-service
  namespace: ingress-nginx
  labels:
    app: nginx
spec:
  ports:
  - port: 80
    targetPort: 80
  selector:
    app: nginx
应用yaml文件
kubectl apply -f nginx-service.yaml
查看svc是否被成功创建
kubectl get -n ingress-nginx svc

4.创建ingress对象
vim ingress-nginx.yaml
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: ingress-nginx                    			#自定义ingress对象名称
  namespace: ingress-nginx
  annotations:									#注解,声明
    ingressclass.kubernetes.io/is-default-class: "true"		#ingress控制器由标记的class作为默认class
spec:
  ingressClassName: nginx							#此处标记出ingressClass为nginx
  rules:
  - host: www.test.com                   			# 自定义域名
    http:
      paths:
      - pathType: Prefix
        path: "/"
        backend:
          service:
            name: nginx-service     				# 对应上面创建的service名称
            port:
              number: 80
应用yaml文件
kubectl apply -f ingress-nginx.yaml
查看ingress
kubectl get ingress -n ingress-nginx
 查看ingress的详细信息
查看ingress的详细信息
kubectl get ingress -n ingress-nginx
可以看到对应的规则及podip
 
 查看podip是否一致
 这条命令是查看service的服务端点列表,也就是存放他对应pod的ip
kubectl get endpoints -n ingress-nginx nginx-service

 可以看出是一致的
为了查看轮询效果,在nginxpod中添加不一样的字母来区分
 查看pod名称
kubectl get pod -n ingress-nginx

第一个pod
[root@k8s-master01 nginx]# kubectl exec -it -n ingress-nginx nginx-65799cd94d-qj2xx -- /bin/bash
root@nginx-65799cd94d-qj2xx:/# echo "nginx1 is running" > /usr/share/nginx/html/index.html 
root@nginx-65799cd94d-qj2xx:/# exit
第二个pod
[root@k8s-master01 nginx]# kubectl exec -it -n ingress-nginx nginx-65799cd94d-sb5m8 -- /bin/bash
root@nginx-65799cd94d-sb5m8:/# echo "nginx2 is running" > /usr/share/nginx/html/index.html
root@nginx-65799cd94d-sb5m8:/# exit
在宿主机hosts中添加解析
 由于是nodeport模式,所以解析写成三个节点的哪个ip都可以,我这里就写12的ip了
192.168.10.12 www.test.com
需要注意的是,由于nodeport模式下开放的端口不固定,所以需要在域名后面加端口号
 查看需要的端口号
kubectl get svc -n ingress-nginx
我这里是31868,根据自己的来
 
 访问
 可以看到是有轮询的效果的
 

 



















